mirror of https://github.com/Wilfred/difftastic/
Add 'vendored_parsers/tree-sitter-scss/' from commit 'c478c6868648eff49eb04a4df90d703dc45b312a'
git-subtree-dir: vendored_parsers/tree-sitter-scss git-subtree-mainline:pull/573/head462f5d4b7egit-subtree-split:c478c68686
commit
4b43221b9a
@ -0,0 +1,2 @@
|
|||||||
|
/src/** linguist-vendored
|
||||||
|
/examples/* linguist-vendored
|
||||||
@ -0,0 +1,4 @@
|
|||||||
|
node_modules
|
||||||
|
build
|
||||||
|
*.log
|
||||||
|
package-lock.json
|
||||||
@ -0,0 +1,26 @@
|
|||||||
|
[package]
|
||||||
|
name = "tree-sitter-scss"
|
||||||
|
description = "scss grammar for the tree-sitter parsing library"
|
||||||
|
version = "0.0.1"
|
||||||
|
keywords = ["incremental", "parsing", "scss"]
|
||||||
|
categories = ["parsing", "text-editors"]
|
||||||
|
repository = "https://github.com/tree-sitter/tree-sitter-javascript"
|
||||||
|
edition = "2018"
|
||||||
|
license = "MIT"
|
||||||
|
|
||||||
|
build = "bindings/rust/build.rs"
|
||||||
|
include = [
|
||||||
|
"bindings/rust/*",
|
||||||
|
"grammar.js",
|
||||||
|
"queries/*",
|
||||||
|
"src/*",
|
||||||
|
]
|
||||||
|
|
||||||
|
[lib]
|
||||||
|
path = "bindings/rust/lib.rs"
|
||||||
|
|
||||||
|
[dependencies]
|
||||||
|
tree-sitter = "0.20"
|
||||||
|
|
||||||
|
[build-dependencies]
|
||||||
|
cc = "1.0"
|
||||||
@ -0,0 +1,21 @@
|
|||||||
|
The MIT License (MIT)
|
||||||
|
|
||||||
|
Copyright (c) 2020 Serenade Labs, Inc.
|
||||||
|
|
||||||
|
Permission is hereby granted, free of charge, to any person obtaining a copy
|
||||||
|
of this software and associated documentation files (the "Software"), to deal
|
||||||
|
in the Software without restriction, including without limitation the rights
|
||||||
|
to use, copy, modify, merge, publish, distribute, sublicense, and/or sell
|
||||||
|
copies of the Software, and to permit persons to whom the Software is
|
||||||
|
furnished to do so, subject to the following conditions:
|
||||||
|
|
||||||
|
The above copyright notice and this permission notice shall be included in all
|
||||||
|
copies or substantial portions of the Software.
|
||||||
|
|
||||||
|
THE SOFTWARE IS PROVIDED "AS IS", WITHOUT WARRANTY OF ANY KIND, EXPRESS OR
|
||||||
|
IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF MERCHANTABILITY,
|
||||||
|
FITNESS FOR A PARTICULAR PURPOSE AND NONINFRINGEMENT. IN NO EVENT SHALL THE
|
||||||
|
AUTHORS OR COPYRIGHT HOLDERS BE LIABLE FOR ANY CLAIM, DAMAGES OR OTHER
|
||||||
|
LIABILITY, WHETHER IN AN ACTION OF CONTRACT, TORT OR OTHERWISE, ARISING FROM,
|
||||||
|
OUT OF OR IN CONNECTION WITH THE SOFTWARE OR THE USE OR OTHER DEALINGS IN THE
|
||||||
|
SOFTWARE.
|
||||||
@ -0,0 +1,5 @@
|
|||||||
|
# tree-sitter-scss
|
||||||
|
|
||||||
|
SCSS grammar for [tree-sitter](https://github.com/tree-sitter/tree-sitter).
|
||||||
|
|
||||||
|
Based on [tree-sitter-css](https://github.com/tree-sitter/tree-sitter-css).
|
||||||
@ -0,0 +1,19 @@
|
|||||||
|
{
|
||||||
|
"targets": [
|
||||||
|
{
|
||||||
|
"target_name": "tree_sitter_scss_binding",
|
||||||
|
"include_dirs": [
|
||||||
|
"<!(node -e \"require('nan')\")",
|
||||||
|
"src"
|
||||||
|
],
|
||||||
|
"sources": [
|
||||||
|
"src/parser.c",
|
||||||
|
"src/scanner.c",
|
||||||
|
"bindings/node/binding.cc"
|
||||||
|
],
|
||||||
|
"cflags_c": [
|
||||||
|
"-std=c99",
|
||||||
|
]
|
||||||
|
}
|
||||||
|
]
|
||||||
|
}
|
||||||
@ -0,0 +1,28 @@
|
|||||||
|
#include "tree_sitter/parser.h"
|
||||||
|
#include <node.h>
|
||||||
|
#include "nan.h"
|
||||||
|
|
||||||
|
using namespace v8;
|
||||||
|
|
||||||
|
extern "C" TSLanguage * tree_sitter_scss();
|
||||||
|
|
||||||
|
namespace {
|
||||||
|
|
||||||
|
NAN_METHOD(New) {}
|
||||||
|
|
||||||
|
void Init(Local<Object> exports, Local<Object> module) {
|
||||||
|
Local<FunctionTemplate> tpl = Nan::New<FunctionTemplate>(New);
|
||||||
|
tpl->SetClassName(Nan::New("Language").ToLocalChecked());
|
||||||
|
tpl->InstanceTemplate()->SetInternalFieldCount(1);
|
||||||
|
|
||||||
|
Local<Function> constructor = Nan::GetFunction(tpl).ToLocalChecked();
|
||||||
|
Local<Object> instance = constructor->NewInstance(Nan::GetCurrentContext()).ToLocalChecked();
|
||||||
|
Nan::SetInternalFieldPointer(instance, 0, tree_sitter_scss());
|
||||||
|
|
||||||
|
Nan::Set(instance, Nan::New("name").ToLocalChecked(), Nan::New("scss").ToLocalChecked());
|
||||||
|
Nan::Set(module, Nan::New("exports").ToLocalChecked(), instance);
|
||||||
|
}
|
||||||
|
|
||||||
|
NODE_MODULE(tree_sitter_scss_binding, Init)
|
||||||
|
|
||||||
|
} // namespace
|
||||||
@ -0,0 +1,19 @@
|
|||||||
|
try {
|
||||||
|
module.exports = require("../../build/Release/tree_sitter_scss_binding");
|
||||||
|
} catch (error1) {
|
||||||
|
if (error1.code !== 'MODULE_NOT_FOUND') {
|
||||||
|
throw error1;
|
||||||
|
}
|
||||||
|
try {
|
||||||
|
module.exports = require("../../build/Debug/tree_sitter_scss_binding");
|
||||||
|
} catch (error2) {
|
||||||
|
if (error2.code !== 'MODULE_NOT_FOUND') {
|
||||||
|
throw error2;
|
||||||
|
}
|
||||||
|
throw error1
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
try {
|
||||||
|
module.exports.nodeTypeInfo = require("../../src/node-types.json");
|
||||||
|
} catch (_) {}
|
||||||
@ -0,0 +1,16 @@
|
|||||||
|
fn main() {
|
||||||
|
let src_dir = std::path::Path::new("src");
|
||||||
|
let mut c_config = cc::Build::new();
|
||||||
|
c_config.include(&src_dir);
|
||||||
|
c_config
|
||||||
|
.flag_if_supported("-Wno-unused-parameter")
|
||||||
|
.flag_if_supported("-Wno-unused-but-set-variable")
|
||||||
|
.flag_if_supported("-Wno-trigraphs");
|
||||||
|
let parser_path = src_dir.join("parser.c");
|
||||||
|
let scanner_path = src_dir.join("scanner.c");
|
||||||
|
c_config.file(&parser_path);
|
||||||
|
c_config.file(&scanner_path);
|
||||||
|
println!("cargo:rerun-if-changed={}", scanner_path.to_str().unwrap());
|
||||||
|
println!("cargo:rerun-if-changed={}", parser_path.to_str().unwrap());
|
||||||
|
c_config.compile("parser");
|
||||||
|
}
|
||||||
@ -0,0 +1,52 @@
|
|||||||
|
//! This crate provides scss language support for the [tree-sitter][] parsing library.
|
||||||
|
//!
|
||||||
|
//! Typically, you will use the [language][language func] function to add this language to a
|
||||||
|
//! tree-sitter [Parser][], and then use the parser to parse some code:
|
||||||
|
//!
|
||||||
|
//! ```
|
||||||
|
//! let code = "";
|
||||||
|
//! let mut parser = tree_sitter::Parser::new();
|
||||||
|
//! parser.set_language(tree_sitter_scss::language()).expect("Error loading scss grammar");
|
||||||
|
//! let tree = parser.parse(code, None).unwrap();
|
||||||
|
//! ```
|
||||||
|
//!
|
||||||
|
//! [Language]: https://docs.rs/tree-sitter/*/tree_sitter/struct.Language.html
|
||||||
|
//! [language func]: fn.language.html
|
||||||
|
//! [Parser]: https://docs.rs/tree-sitter/*/tree_sitter/struct.Parser.html
|
||||||
|
//! [tree-sitter]: https://tree-sitter.github.io/
|
||||||
|
|
||||||
|
use tree_sitter::Language;
|
||||||
|
|
||||||
|
extern "C" {
|
||||||
|
fn tree_sitter_scss() -> Language;
|
||||||
|
}
|
||||||
|
|
||||||
|
/// Get the tree-sitter [Language][] for this grammar.
|
||||||
|
///
|
||||||
|
/// [Language]: https://docs.rs/tree-sitter/*/tree_sitter/struct.Language.html
|
||||||
|
pub fn language() -> Language {
|
||||||
|
unsafe { tree_sitter_scss() }
|
||||||
|
}
|
||||||
|
|
||||||
|
/// The content of the [`node-types.json`][] file for this grammar.
|
||||||
|
///
|
||||||
|
/// [`node-types.json`]: https://tree-sitter.github.io/tree-sitter/using-parsers#static-node-types
|
||||||
|
pub const NODE_TYPES: &'static str = include_str!("../../src/node-types.json");
|
||||||
|
|
||||||
|
// Uncomment these to include any queries that this grammar contains
|
||||||
|
|
||||||
|
// pub const HIGHLIGHTS_QUERY: &'static str = include_str!("../../queries/highlights.scm");
|
||||||
|
// pub const INJECTIONS_QUERY: &'static str = include_str!("../../queries/injections.scm");
|
||||||
|
// pub const LOCALS_QUERY: &'static str = include_str!("../../queries/locals.scm");
|
||||||
|
// pub const TAGS_QUERY: &'static str = include_str!("../../queries/tags.scm");
|
||||||
|
|
||||||
|
#[cfg(test)]
|
||||||
|
mod tests {
|
||||||
|
#[test]
|
||||||
|
fn test_can_load_grammar() {
|
||||||
|
let mut parser = tree_sitter::Parser::new();
|
||||||
|
parser
|
||||||
|
.set_language(super::language())
|
||||||
|
.expect("Error loading scss language");
|
||||||
|
}
|
||||||
|
}
|
||||||
@ -0,0 +1,379 @@
|
|||||||
|
==========================
|
||||||
|
Function calls
|
||||||
|
==========================
|
||||||
|
|
||||||
|
a {
|
||||||
|
color: rgba(0, 255, 0, 0.5);
|
||||||
|
}
|
||||||
|
|
||||||
|
---
|
||||||
|
|
||||||
|
(stylesheet
|
||||||
|
(rule_set
|
||||||
|
(selectors (tag_name))
|
||||||
|
(block
|
||||||
|
(declaration
|
||||||
|
(property_name)
|
||||||
|
(call_expression (function_name) (arguments
|
||||||
|
(integer_value)
|
||||||
|
(integer_value)
|
||||||
|
(integer_value)
|
||||||
|
(float_value)))))))
|
||||||
|
|
||||||
|
=============================================
|
||||||
|
Calls where each argument has multiple values
|
||||||
|
=============================================
|
||||||
|
|
||||||
|
div {
|
||||||
|
background: repeating-linear-gradient(red, orange 50px);
|
||||||
|
clip-path: polygon(50% 0%, 60% 40%, 100% 50%, 60% 60%, 50% 100%, 40% 60%, 0% 50%, 40% 40%);
|
||||||
|
}
|
||||||
|
|
||||||
|
---
|
||||||
|
|
||||||
|
(stylesheet
|
||||||
|
(rule_set (selectors (tag_name)) (block
|
||||||
|
(declaration
|
||||||
|
(property_name)
|
||||||
|
(call_expression (function_name) (arguments
|
||||||
|
(plain_value)
|
||||||
|
(plain_value)
|
||||||
|
(integer_value (unit)))))
|
||||||
|
(declaration
|
||||||
|
(property_name)
|
||||||
|
(call_expression (function_name) (arguments
|
||||||
|
(integer_value (unit))
|
||||||
|
(integer_value (unit))
|
||||||
|
(integer_value (unit))
|
||||||
|
(integer_value (unit))
|
||||||
|
(integer_value (unit))
|
||||||
|
(integer_value (unit))
|
||||||
|
(integer_value (unit))
|
||||||
|
(integer_value (unit))
|
||||||
|
(integer_value (unit))
|
||||||
|
(integer_value (unit))
|
||||||
|
(integer_value (unit))
|
||||||
|
(integer_value (unit))
|
||||||
|
(integer_value (unit))
|
||||||
|
(integer_value (unit))
|
||||||
|
(integer_value (unit))
|
||||||
|
(integer_value (unit))))))))
|
||||||
|
|
||||||
|
============================
|
||||||
|
Color literals
|
||||||
|
============================
|
||||||
|
|
||||||
|
a {
|
||||||
|
b: #fafd04;
|
||||||
|
c: #fafd0401;
|
||||||
|
}
|
||||||
|
|
||||||
|
---
|
||||||
|
|
||||||
|
(stylesheet
|
||||||
|
(rule_set
|
||||||
|
(selectors (tag_name))
|
||||||
|
(block
|
||||||
|
(declaration (property_name) (color_value))
|
||||||
|
(declaration (property_name) (color_value)))))
|
||||||
|
|
||||||
|
============================
|
||||||
|
Numbers
|
||||||
|
============================
|
||||||
|
|
||||||
|
a {
|
||||||
|
b: 0.5%;
|
||||||
|
c: 5em;
|
||||||
|
margin: 10E3px;
|
||||||
|
margin: -456.8px;
|
||||||
|
margin: -5px;
|
||||||
|
margin: -0.0px;
|
||||||
|
}
|
||||||
|
|
||||||
|
---
|
||||||
|
|
||||||
|
(stylesheet
|
||||||
|
(rule_set (selectors (tag_name)) (block
|
||||||
|
(declaration (property_name) (float_value (unit)))
|
||||||
|
(declaration (property_name) (integer_value (unit)))
|
||||||
|
(declaration (property_name) (float_value (unit)))
|
||||||
|
(declaration (property_name) (float_value (unit)))
|
||||||
|
(declaration (property_name) (integer_value (unit)))
|
||||||
|
(declaration (property_name) (float_value (unit))))))
|
||||||
|
|
||||||
|
============================
|
||||||
|
Binary arithmetic operators
|
||||||
|
============================
|
||||||
|
|
||||||
|
a {
|
||||||
|
width: calc(100% - 80px);
|
||||||
|
aspect-ratio: 1/2;
|
||||||
|
font-size: calc(10px + (56 - 10) * ((100vw - 320px) / (1920 - 320)));
|
||||||
|
}
|
||||||
|
|
||||||
|
---
|
||||||
|
|
||||||
|
(stylesheet
|
||||||
|
(rule_set
|
||||||
|
(selectors (tag_name))
|
||||||
|
(block
|
||||||
|
(declaration
|
||||||
|
(property_name)
|
||||||
|
(call_expression (function_name) (arguments (binary_expression (integer_value (unit)) (integer_value (unit))))))
|
||||||
|
(declaration
|
||||||
|
(property_name)
|
||||||
|
(binary_expression (integer_value) (integer_value)))
|
||||||
|
(declaration
|
||||||
|
(property_name)
|
||||||
|
(call_expression
|
||||||
|
(function_name)
|
||||||
|
(arguments
|
||||||
|
(binary_expression
|
||||||
|
(binary_expression
|
||||||
|
(integer_value (unit))
|
||||||
|
(parenthesized_value (binary_expression (integer_value) (integer_value))))
|
||||||
|
(parenthesized_value
|
||||||
|
(binary_expression
|
||||||
|
(parenthesized_value (binary_expression (integer_value (unit)) (integer_value (unit))))
|
||||||
|
(parenthesized_value (binary_expression (integer_value) (integer_value))))))))))))
|
||||||
|
|
||||||
|
============================
|
||||||
|
Strings
|
||||||
|
============================
|
||||||
|
|
||||||
|
a {
|
||||||
|
b: '';
|
||||||
|
c: '\'hi\'';
|
||||||
|
}
|
||||||
|
|
||||||
|
---
|
||||||
|
|
||||||
|
(stylesheet
|
||||||
|
(rule_set
|
||||||
|
(selectors (tag_name))
|
||||||
|
(block
|
||||||
|
(declaration (property_name) (string_value))
|
||||||
|
(declaration (property_name) (string_value)))))
|
||||||
|
|
||||||
|
============================
|
||||||
|
URLs
|
||||||
|
============================
|
||||||
|
|
||||||
|
a {
|
||||||
|
b: http://something-else?foo=bar;
|
||||||
|
}
|
||||||
|
|
||||||
|
---
|
||||||
|
|
||||||
|
(stylesheet
|
||||||
|
(rule_set
|
||||||
|
(selectors (tag_name))
|
||||||
|
(block
|
||||||
|
(declaration (property_name) (plain_value)))))
|
||||||
|
|
||||||
|
============================
|
||||||
|
Important declarations
|
||||||
|
============================
|
||||||
|
|
||||||
|
a {
|
||||||
|
b: c !important;
|
||||||
|
}
|
||||||
|
|
||||||
|
---
|
||||||
|
|
||||||
|
(stylesheet
|
||||||
|
(rule_set
|
||||||
|
(selectors (tag_name))
|
||||||
|
(block
|
||||||
|
(declaration (property_name) (plain_value) (important)))))
|
||||||
|
|
||||||
|
============================
|
||||||
|
Declarations without trailing semicolons
|
||||||
|
============================
|
||||||
|
|
||||||
|
a {
|
||||||
|
b: c;
|
||||||
|
d: e
|
||||||
|
}
|
||||||
|
|
||||||
|
---
|
||||||
|
|
||||||
|
(stylesheet
|
||||||
|
(rule_set
|
||||||
|
(selectors (tag_name))
|
||||||
|
(block
|
||||||
|
(declaration (property_name) (plain_value))
|
||||||
|
(declaration (property_name) (plain_value)))))
|
||||||
|
|
||||||
|
=======================================
|
||||||
|
Comments right after numbers
|
||||||
|
=======================================
|
||||||
|
|
||||||
|
a {
|
||||||
|
shape-outside: circle(20em/*=*/at 50% 50%);
|
||||||
|
shape-outside: inset(1em, 1em, 1em, 1em);
|
||||||
|
}
|
||||||
|
|
||||||
|
---
|
||||||
|
|
||||||
|
(stylesheet
|
||||||
|
(rule_set
|
||||||
|
(selectors (tag_name))
|
||||||
|
(block
|
||||||
|
(declaration (property_name) (call_expression (function_name) (arguments
|
||||||
|
(integer_value (unit))
|
||||||
|
(comment)
|
||||||
|
(plain_value)
|
||||||
|
(integer_value (unit))
|
||||||
|
(integer_value (unit)))))
|
||||||
|
(declaration (property_name) (call_expression (function_name) (arguments
|
||||||
|
(integer_value (unit))
|
||||||
|
(integer_value (unit))
|
||||||
|
(integer_value (unit))
|
||||||
|
(integer_value (unit))))))))
|
||||||
|
|
||||||
|
=================================
|
||||||
|
Declarations at the top level
|
||||||
|
=================================
|
||||||
|
|
||||||
|
--a-variable: -5px;
|
||||||
|
a-property: calc(5px + var(--a-variable));
|
||||||
|
|
||||||
|
---
|
||||||
|
|
||||||
|
(stylesheet
|
||||||
|
(declaration (property_name) (integer_value (unit)))
|
||||||
|
(declaration (property_name) (call_expression (function_name) (arguments (binary_expression (integer_value (unit)) (call_expression (function_name) (arguments (plain_value))))))))
|
||||||
|
|
||||||
|
=================================
|
||||||
|
Variables
|
||||||
|
=================================
|
||||||
|
|
||||||
|
$font-stack: Helvetica, sans-serif;
|
||||||
|
|
||||||
|
a {
|
||||||
|
$primary-color: red;
|
||||||
|
|
||||||
|
color: $primary-color;
|
||||||
|
font: 100% $font-stack;
|
||||||
|
}
|
||||||
|
|
||||||
|
---
|
||||||
|
|
||||||
|
(stylesheet
|
||||||
|
(declaration (variable_name) (plain_value) (plain_value))
|
||||||
|
(rule_set
|
||||||
|
(selectors (tag_name))
|
||||||
|
(block
|
||||||
|
(declaration (variable_name) (plain_value))
|
||||||
|
(declaration (property_name) (variable_value))
|
||||||
|
(declaration (property_name) (integer_value (unit)) (variable_value)))))
|
||||||
|
|
||||||
|
=================================
|
||||||
|
Mixins with no arguments
|
||||||
|
=================================
|
||||||
|
|
||||||
|
@mixin red {
|
||||||
|
color: red;
|
||||||
|
}
|
||||||
|
|
||||||
|
---
|
||||||
|
|
||||||
|
(stylesheet
|
||||||
|
(mixin_statement (name)
|
||||||
|
(block
|
||||||
|
(declaration (property_name) (plain_value)))))
|
||||||
|
|
||||||
|
=================================
|
||||||
|
Mixins with arguments
|
||||||
|
=================================
|
||||||
|
|
||||||
|
@mixin replace-text($image, $color: red) {
|
||||||
|
text-align: left;
|
||||||
|
}
|
||||||
|
|
||||||
|
---
|
||||||
|
|
||||||
|
(stylesheet
|
||||||
|
(mixin_statement
|
||||||
|
(name)
|
||||||
|
(parameters
|
||||||
|
(parameter (variable_name))
|
||||||
|
(parameter (variable_name) (default_value (plain_value))))
|
||||||
|
(block (declaration (property_name) (plain_value)))))
|
||||||
|
|
||||||
|
=================================
|
||||||
|
Mixins with interpolations and content
|
||||||
|
=================================
|
||||||
|
|
||||||
|
@mixin media($queryString) {
|
||||||
|
@media #{$queryString} {
|
||||||
|
@content;
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
---
|
||||||
|
|
||||||
|
(stylesheet
|
||||||
|
(mixin_statement
|
||||||
|
(name)
|
||||||
|
(parameters (parameter (variable_name)))
|
||||||
|
(block (media_statement (keyword_query) (block (at_rule (at_keyword)))))))
|
||||||
|
|
||||||
|
=================================
|
||||||
|
Mixins with at-root
|
||||||
|
=================================
|
||||||
|
|
||||||
|
@mixin unify-parent($child) {
|
||||||
|
@at-root #{selector.unify(&, $child)} {
|
||||||
|
@content;
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
---
|
||||||
|
|
||||||
|
(stylesheet
|
||||||
|
(mixin_statement
|
||||||
|
(name)
|
||||||
|
(parameters (parameter (variable_name)))
|
||||||
|
(block
|
||||||
|
(at_root_statement (plain_value) (block (at_rule (at_keyword)))))))
|
||||||
|
|
||||||
|
=================================
|
||||||
|
Placeholders
|
||||||
|
=================================
|
||||||
|
|
||||||
|
%bar {
|
||||||
|
width: 100%;
|
||||||
|
}
|
||||||
|
|
||||||
|
---
|
||||||
|
|
||||||
|
(stylesheet
|
||||||
|
(placeholder
|
||||||
|
(name)
|
||||||
|
(block
|
||||||
|
(declaration (property_name) (integer_value (unit))))))
|
||||||
|
|
||||||
|
=============================================
|
||||||
|
Spaces after colons in property declarations
|
||||||
|
=============================================
|
||||||
|
|
||||||
|
div {
|
||||||
|
margin : 0;
|
||||||
|
padding : 0;
|
||||||
|
}
|
||||||
|
|
||||||
|
---
|
||||||
|
|
||||||
|
(stylesheet
|
||||||
|
(rule_set
|
||||||
|
(selectors
|
||||||
|
(tag_name))
|
||||||
|
(block
|
||||||
|
(declaration
|
||||||
|
(property_name)
|
||||||
|
(integer_value))
|
||||||
|
(declaration
|
||||||
|
(property_name)
|
||||||
|
(integer_value)))))
|
||||||
@ -0,0 +1,23 @@
|
|||||||
|
=========================
|
||||||
|
Universal selectors
|
||||||
|
=========================
|
||||||
|
|
||||||
|
@import './styles/reset.scss';
|
||||||
|
@import './styles/main.scss';
|
||||||
|
|
||||||
|
#app {
|
||||||
|
-webkit-font-smoothing: antialiased;
|
||||||
|
}
|
||||||
|
|
||||||
|
.MoreChancesModal {
|
||||||
|
&_Title {
|
||||||
|
@extend .t--heading-tertiary;
|
||||||
|
}
|
||||||
|
&_Spacer {
|
||||||
|
background: red;
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
---
|
||||||
|
|
||||||
|
(stylesheet (import_statement (string_value)) (import_statement (string_value)) (rule_set (selectors (id_selector (id_name))) (block (declaration (property_name) (plain_value)))) (rule_set (selectors (class_selector (class_name))) (block (rule_set (selectors (class_selector (nesting_selector) (class_name))) (block (extend_statement (class_selector (class_name))))) (rule_set (selectors (class_selector (nesting_selector) (class_name))) (block (declaration (property_name) (plain_value)))))))
|
||||||
@ -0,0 +1,224 @@
|
|||||||
|
=========================
|
||||||
|
Universal selectors
|
||||||
|
=========================
|
||||||
|
|
||||||
|
* {}
|
||||||
|
|
||||||
|
---
|
||||||
|
|
||||||
|
(stylesheet
|
||||||
|
(rule_set (selectors (universal_selector)) (block)))
|
||||||
|
|
||||||
|
=========================
|
||||||
|
Type selectors
|
||||||
|
=========================
|
||||||
|
|
||||||
|
div, span {}
|
||||||
|
h1, h2, h3, h4 {}
|
||||||
|
|
||||||
|
---
|
||||||
|
|
||||||
|
(stylesheet
|
||||||
|
(rule_set (selectors (tag_name) (tag_name)) (block))
|
||||||
|
(rule_set (selectors (tag_name) (tag_name) (tag_name) (tag_name)) (block)))
|
||||||
|
|
||||||
|
=========================
|
||||||
|
Class selectors
|
||||||
|
=========================
|
||||||
|
|
||||||
|
.class-a {}
|
||||||
|
div.class-b, .class-c.class-d {}
|
||||||
|
|
||||||
|
---
|
||||||
|
|
||||||
|
(stylesheet
|
||||||
|
(rule_set
|
||||||
|
(selectors (class_selector (class_name)))
|
||||||
|
(block))
|
||||||
|
(rule_set
|
||||||
|
(selectors
|
||||||
|
(class_selector (tag_name) (class_name))
|
||||||
|
(class_selector (class_selector (class_name)) (class_name)))
|
||||||
|
(block)))
|
||||||
|
|
||||||
|
=========================
|
||||||
|
Id selectors
|
||||||
|
=========================
|
||||||
|
|
||||||
|
#some-id, a#another-id {}
|
||||||
|
|
||||||
|
---
|
||||||
|
|
||||||
|
(stylesheet
|
||||||
|
(rule_set
|
||||||
|
(selectors (id_selector (id_name)) (id_selector (tag_name) (id_name)))
|
||||||
|
(block)))
|
||||||
|
|
||||||
|
=========================
|
||||||
|
Attribute selectors
|
||||||
|
=========================
|
||||||
|
|
||||||
|
[a] {}
|
||||||
|
[b=c] {}
|
||||||
|
[d~=e] {}
|
||||||
|
a[b] {}
|
||||||
|
|
||||||
|
---
|
||||||
|
|
||||||
|
(stylesheet
|
||||||
|
(rule_set (selectors (attribute_selector (attribute_name))) (block))
|
||||||
|
(rule_set (selectors (attribute_selector (attribute_name) (plain_value))) (block))
|
||||||
|
(rule_set (selectors (attribute_selector (attribute_name) (plain_value))) (block))
|
||||||
|
(rule_set (selectors (attribute_selector (tag_name) (attribute_name))) (block)))
|
||||||
|
|
||||||
|
=========================
|
||||||
|
Pseudo-class selectors
|
||||||
|
=========================
|
||||||
|
|
||||||
|
a:hover {}
|
||||||
|
:nth-child(2) {}
|
||||||
|
|
||||||
|
---
|
||||||
|
|
||||||
|
(stylesheet
|
||||||
|
(rule_set
|
||||||
|
(selectors (pseudo_class_selector (tag_name) (class_name)))
|
||||||
|
(block))
|
||||||
|
(rule_set
|
||||||
|
(selectors (pseudo_class_selector (class_name) (arguments (integer_value))))
|
||||||
|
(block)))
|
||||||
|
|
||||||
|
=========================
|
||||||
|
Pseudo-element selectors
|
||||||
|
=========================
|
||||||
|
|
||||||
|
a::first-line {}
|
||||||
|
|
||||||
|
---
|
||||||
|
|
||||||
|
(stylesheet
|
||||||
|
(rule_set
|
||||||
|
(selectors (pseudo_element_selector (tag_name) (tag_name)))
|
||||||
|
(block)))
|
||||||
|
|
||||||
|
=========================
|
||||||
|
Child selectors
|
||||||
|
=========================
|
||||||
|
|
||||||
|
a > b {}
|
||||||
|
c > d > e {}
|
||||||
|
|
||||||
|
---
|
||||||
|
|
||||||
|
(stylesheet
|
||||||
|
(rule_set
|
||||||
|
(selectors (child_selector (tag_name) (tag_name)))
|
||||||
|
(block))
|
||||||
|
(rule_set
|
||||||
|
(selectors (child_selector
|
||||||
|
(child_selector (tag_name) (tag_name))
|
||||||
|
(tag_name)))
|
||||||
|
(block)))
|
||||||
|
|
||||||
|
=========================
|
||||||
|
Descendant selectors
|
||||||
|
=========================
|
||||||
|
|
||||||
|
a b {}
|
||||||
|
c d e {}
|
||||||
|
|
||||||
|
---
|
||||||
|
|
||||||
|
(stylesheet
|
||||||
|
(rule_set
|
||||||
|
(selectors (descendant_selector (tag_name) (tag_name)))
|
||||||
|
(block))
|
||||||
|
(rule_set
|
||||||
|
(selectors (descendant_selector
|
||||||
|
(descendant_selector (tag_name) (tag_name))
|
||||||
|
(tag_name)))
|
||||||
|
(block)))
|
||||||
|
|
||||||
|
===========================
|
||||||
|
Nesting selectors
|
||||||
|
===========================
|
||||||
|
|
||||||
|
a {
|
||||||
|
&.b {}
|
||||||
|
& c {}
|
||||||
|
& > d {}
|
||||||
|
&e {}
|
||||||
|
}
|
||||||
|
|
||||||
|
---
|
||||||
|
|
||||||
|
(stylesheet
|
||||||
|
(rule_set
|
||||||
|
(selectors (tag_name))
|
||||||
|
(block
|
||||||
|
(rule_set (selectors (class_selector (nesting_selector) (class_name))) (block))
|
||||||
|
(rule_set (selectors (descendant_selector (nesting_selector) (tag_name))) (block))
|
||||||
|
(rule_set (selectors (child_selector (nesting_selector) (tag_name))) (block))
|
||||||
|
(rule_set (selectors (class_selector (nesting_selector) (class_name))) (block)))))
|
||||||
|
|
||||||
|
===========================
|
||||||
|
Sibling selectors
|
||||||
|
===========================
|
||||||
|
|
||||||
|
a.b ~ c.d {}
|
||||||
|
.e.f + .g.h {}
|
||||||
|
|
||||||
|
---
|
||||||
|
|
||||||
|
(stylesheet
|
||||||
|
(rule_set
|
||||||
|
(selectors (sibling_selector
|
||||||
|
(class_selector (tag_name) (class_name))
|
||||||
|
(class_selector (tag_name) (class_name))))
|
||||||
|
(block))
|
||||||
|
(rule_set
|
||||||
|
(selectors (adjacent_sibling_selector
|
||||||
|
(class_selector (class_selector (class_name)) (class_name))
|
||||||
|
(class_selector (class_selector (class_name)) (class_name))))
|
||||||
|
(block)))
|
||||||
|
|
||||||
|
===========================
|
||||||
|
The :not selector
|
||||||
|
===========================
|
||||||
|
|
||||||
|
a:not(:hover) {}
|
||||||
|
.b:not(c > .d) {}
|
||||||
|
|
||||||
|
---
|
||||||
|
|
||||||
|
(stylesheet
|
||||||
|
(rule_set
|
||||||
|
(selectors (pseudo_class_selector
|
||||||
|
(tag_name)
|
||||||
|
(class_name)
|
||||||
|
(arguments (pseudo_class_selector (class_name)))))
|
||||||
|
(block))
|
||||||
|
(rule_set
|
||||||
|
(selectors (pseudo_class_selector
|
||||||
|
(class_selector (class_name))
|
||||||
|
(class_name)
|
||||||
|
(arguments (child_selector (tag_name) (class_selector (class_name))))))
|
||||||
|
(block)))
|
||||||
|
|
||||||
|
===========================
|
||||||
|
Parent selectors
|
||||||
|
===========================
|
||||||
|
|
||||||
|
html {
|
||||||
|
.foo & {}
|
||||||
|
}
|
||||||
|
|
||||||
|
---
|
||||||
|
|
||||||
|
(stylesheet
|
||||||
|
(rule_set
|
||||||
|
(selectors (tag_name))
|
||||||
|
(block
|
||||||
|
(rule_set
|
||||||
|
(selectors (descendant_selector (class_selector (class_name)) (nesting_selector)))
|
||||||
|
(block)))))
|
||||||
@ -0,0 +1,526 @@
|
|||||||
|
==============================
|
||||||
|
Import statements
|
||||||
|
==============================
|
||||||
|
|
||||||
|
@import url("fineprint.css") print;
|
||||||
|
@import url("bluish.css") speech;
|
||||||
|
@import 'custom.css';
|
||||||
|
@import url("chrome://communicator/skin/");
|
||||||
|
@import "common.css" screen;
|
||||||
|
|
||||||
|
---
|
||||||
|
|
||||||
|
(stylesheet
|
||||||
|
(import_statement (call_expression (function_name) (arguments (string_value))) (keyword_query))
|
||||||
|
(import_statement (call_expression (function_name) (arguments (string_value))) (keyword_query))
|
||||||
|
(import_statement (string_value))
|
||||||
|
(import_statement (call_expression (function_name) (arguments (string_value))))
|
||||||
|
(import_statement (string_value) (keyword_query)))
|
||||||
|
|
||||||
|
==============================
|
||||||
|
Namespace statements
|
||||||
|
==============================
|
||||||
|
|
||||||
|
/* Default namespace */
|
||||||
|
@namespace url(XML-namespace-URL);
|
||||||
|
@namespace "XML-namespace-URL";
|
||||||
|
@namespace url(http://www.w3.org/1999/xhtml);
|
||||||
|
@namespace svg url(http://www.w3.org/2000/svg);
|
||||||
|
|
||||||
|
/* Prefixed namespace */
|
||||||
|
@namespace prefix url(XML-namespace-URL);
|
||||||
|
@namespace prefix "XML-namespace-URL";
|
||||||
|
|
||||||
|
---
|
||||||
|
|
||||||
|
(stylesheet
|
||||||
|
(comment)
|
||||||
|
(namespace_statement (call_expression (function_name) (arguments (plain_value))))
|
||||||
|
(namespace_statement (string_value))
|
||||||
|
(namespace_statement (call_expression (function_name) (arguments (plain_value))))
|
||||||
|
(namespace_statement (namespace_name) (call_expression (function_name) (arguments (plain_value))))
|
||||||
|
(comment)
|
||||||
|
(namespace_statement (namespace_name) (call_expression (function_name) (arguments (plain_value))))
|
||||||
|
(namespace_statement (namespace_name) (string_value)))
|
||||||
|
|
||||||
|
==============================
|
||||||
|
Keyframes statements
|
||||||
|
==============================
|
||||||
|
|
||||||
|
@keyframes important1 {
|
||||||
|
from { margin-top: 50px; }
|
||||||
|
50% { margin-top: 150px !important; } /* ignored */
|
||||||
|
to { margin-top: 100px; }
|
||||||
|
}
|
||||||
|
|
||||||
|
---
|
||||||
|
|
||||||
|
(stylesheet
|
||||||
|
(keyframes_statement (keyframes_name) (keyframe_block_list
|
||||||
|
(keyframe_block (from) (block (declaration (property_name) (integer_value (unit)))))
|
||||||
|
(keyframe_block (integer_value (unit)) (block (declaration (property_name) (integer_value (unit)) (important))))
|
||||||
|
(comment)
|
||||||
|
(keyframe_block (to) (block (declaration (property_name) (integer_value (unit))))))))
|
||||||
|
|
||||||
|
==============================
|
||||||
|
Media statements
|
||||||
|
==============================
|
||||||
|
|
||||||
|
@media screen and (min-width: 30em) and (orientation: landscape) {}
|
||||||
|
@media (min-height: 680px), screen and (orientation: portrait) {}
|
||||||
|
@media not all and (monochrome) {}
|
||||||
|
@media only screen {}
|
||||||
|
|
||||||
|
---
|
||||||
|
|
||||||
|
(stylesheet
|
||||||
|
(media_statement
|
||||||
|
(binary_query
|
||||||
|
(binary_query
|
||||||
|
(keyword_query)
|
||||||
|
(feature_query (feature_name) (integer_value (unit))))
|
||||||
|
(feature_query (feature_name) (plain_value)))
|
||||||
|
(block))
|
||||||
|
(media_statement
|
||||||
|
(feature_query (feature_name) (integer_value (unit)))
|
||||||
|
(binary_query (keyword_query) (feature_query (feature_name) (plain_value)))
|
||||||
|
(block))
|
||||||
|
(media_statement
|
||||||
|
(binary_query (unary_query (keyword_query)) (parenthesized_query (keyword_query)))
|
||||||
|
(block))
|
||||||
|
(media_statement (unary_query (keyword_query)) (block)))
|
||||||
|
|
||||||
|
==============================
|
||||||
|
Supports statements
|
||||||
|
==============================
|
||||||
|
|
||||||
|
@supports (animation-name: test) {
|
||||||
|
div { animation-name: test; }
|
||||||
|
}
|
||||||
|
@supports (transform-style: preserve) or (-moz-transform-style: preserve) {}
|
||||||
|
@supports not ((text-align-last: justify) or (-moz-text-align-last: justify)) {}
|
||||||
|
@supports not selector(:matches(a, b)) {}
|
||||||
|
|
||||||
|
---
|
||||||
|
|
||||||
|
(stylesheet
|
||||||
|
(supports_statement
|
||||||
|
(feature_query (feature_name) (plain_value))
|
||||||
|
(block
|
||||||
|
(rule_set (selectors (tag_name)) (block
|
||||||
|
(declaration (property_name) (plain_value))))))
|
||||||
|
(supports_statement
|
||||||
|
(binary_query
|
||||||
|
(feature_query (feature_name) (plain_value))
|
||||||
|
(feature_query (feature_name) (plain_value)))
|
||||||
|
(block))
|
||||||
|
(supports_statement
|
||||||
|
(unary_query (parenthesized_query (binary_query
|
||||||
|
(feature_query (feature_name) (plain_value))
|
||||||
|
(feature_query (feature_name) (plain_value)))))
|
||||||
|
(block))
|
||||||
|
(supports_statement
|
||||||
|
(unary_query (selector_query (pseudo_class_selector
|
||||||
|
(class_name)
|
||||||
|
(arguments (tag_name) (tag_name)))))
|
||||||
|
(block)))
|
||||||
|
|
||||||
|
==============================
|
||||||
|
Charset statements
|
||||||
|
==============================
|
||||||
|
|
||||||
|
@charset "utf-8";
|
||||||
|
|
||||||
|
---
|
||||||
|
|
||||||
|
(stylesheet
|
||||||
|
(charset_statement (string_value)))
|
||||||
|
|
||||||
|
==============================
|
||||||
|
Other at-statements
|
||||||
|
==============================
|
||||||
|
|
||||||
|
@font-face {
|
||||||
|
font-family: "Open Sans";
|
||||||
|
src: url("/a") format("woff2"), url("/b/c") format("woff");
|
||||||
|
}
|
||||||
|
|
||||||
|
---
|
||||||
|
|
||||||
|
(stylesheet
|
||||||
|
(at_rule
|
||||||
|
(at_keyword)
|
||||||
|
(block
|
||||||
|
(declaration (property_name) (string_value))
|
||||||
|
(declaration (property_name)
|
||||||
|
(call_expression (function_name) (arguments (string_value)))
|
||||||
|
(call_expression (function_name) (arguments (string_value)))
|
||||||
|
(call_expression (function_name) (arguments (string_value)))
|
||||||
|
(call_expression (function_name) (arguments (string_value)))))))
|
||||||
|
|
||||||
|
==============================
|
||||||
|
Single-line comments
|
||||||
|
==============================
|
||||||
|
|
||||||
|
// https://awardwinningfjords.com/2010/04/09/example-scss-sassy-css-file.html
|
||||||
|
|
||||||
|
html {
|
||||||
|
background: url(https://google.com);
|
||||||
|
}
|
||||||
|
|
||||||
|
---
|
||||||
|
|
||||||
|
(stylesheet
|
||||||
|
(single_line_comment)
|
||||||
|
(rule_set
|
||||||
|
(selectors (tag_name))
|
||||||
|
(block
|
||||||
|
(declaration (property_name) (call_expression (function_name) (arguments (plain_value)))))))
|
||||||
|
|
||||||
|
==============================
|
||||||
|
Use statements
|
||||||
|
==============================
|
||||||
|
|
||||||
|
@use 'custom.css';
|
||||||
|
|
||||||
|
.inverse {
|
||||||
|
background-color: base.$primary-color;
|
||||||
|
color: white;
|
||||||
|
}
|
||||||
|
|
||||||
|
---
|
||||||
|
|
||||||
|
(stylesheet
|
||||||
|
(use_statement (string_value))
|
||||||
|
(rule_set
|
||||||
|
(selectors (class_selector (class_name)))
|
||||||
|
(block
|
||||||
|
(declaration (property_name) (variable_value))
|
||||||
|
(declaration (property_name) (plain_value)))))
|
||||||
|
|
||||||
|
==============================
|
||||||
|
Forward statements
|
||||||
|
==============================
|
||||||
|
|
||||||
|
@forward 'custom.css';
|
||||||
|
|
||||||
|
---
|
||||||
|
|
||||||
|
(stylesheet
|
||||||
|
(forward_statement (string_value)))
|
||||||
|
|
||||||
|
==============================
|
||||||
|
Include statements
|
||||||
|
==============================
|
||||||
|
|
||||||
|
.foo {
|
||||||
|
@include bar;
|
||||||
|
@include transform(50px, $float: left);
|
||||||
|
}
|
||||||
|
|
||||||
|
---
|
||||||
|
|
||||||
|
(stylesheet
|
||||||
|
(rule_set
|
||||||
|
(selectors (class_selector (class_name)))
|
||||||
|
(block
|
||||||
|
(include_statement (identifier))
|
||||||
|
(include_statement (identifier)
|
||||||
|
(arguments
|
||||||
|
(argument (argument_value (integer_value (unit))))
|
||||||
|
(argument (argument_name) (argument_value (plain_value))))))))
|
||||||
|
|
||||||
|
==============================
|
||||||
|
Extend statements
|
||||||
|
==============================
|
||||||
|
|
||||||
|
.foo {
|
||||||
|
@extend red;
|
||||||
|
.bar {
|
||||||
|
@extend blue;
|
||||||
|
@extend .green;
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
---
|
||||||
|
|
||||||
|
(stylesheet
|
||||||
|
(rule_set
|
||||||
|
(selectors (class_selector (class_name)))
|
||||||
|
(block
|
||||||
|
(extend_statement (plain_value))
|
||||||
|
(rule_set
|
||||||
|
(selectors (class_selector (class_name)))
|
||||||
|
(block (extend_statement (plain_value))
|
||||||
|
(extend_statement (class_selector (class_name))))))))
|
||||||
|
|
||||||
|
==============================
|
||||||
|
Apply statements
|
||||||
|
==============================
|
||||||
|
|
||||||
|
@apply fill-red-50 border-black col-span-1;
|
||||||
|
|
||||||
|
---
|
||||||
|
|
||||||
|
(stylesheet
|
||||||
|
(apply_statement (plain_value) (plain_value) (plain_value)))
|
||||||
|
|
||||||
|
=================================
|
||||||
|
Operators
|
||||||
|
=================================
|
||||||
|
|
||||||
|
article[role="main"] {
|
||||||
|
width: 600px / 960px * 100%;
|
||||||
|
}
|
||||||
|
|
||||||
|
---
|
||||||
|
|
||||||
|
(stylesheet
|
||||||
|
(rule_set
|
||||||
|
(selectors (attribute_selector (tag_name) (attribute_name) (string_value)))
|
||||||
|
(block
|
||||||
|
(declaration (property_name)
|
||||||
|
(binary_expression
|
||||||
|
(binary_expression (integer_value (unit)) (integer_value (unit))) (integer_value (unit)))))))
|
||||||
|
|
||||||
|
=================================
|
||||||
|
Interpolation
|
||||||
|
=================================
|
||||||
|
|
||||||
|
.icon-#{$name} {
|
||||||
|
position: absolute;
|
||||||
|
#{$top-or-bottom}: 0;
|
||||||
|
}
|
||||||
|
|
||||||
|
---
|
||||||
|
|
||||||
|
(stylesheet
|
||||||
|
(rule_set
|
||||||
|
(selectors (class_selector (class_name)))
|
||||||
|
(block
|
||||||
|
(declaration (property_name) (plain_value))
|
||||||
|
(declaration (property_name) (integer_value)))))
|
||||||
|
|
||||||
|
=================================
|
||||||
|
If statements
|
||||||
|
=================================
|
||||||
|
|
||||||
|
@mixin avatar($size, $circle: false) {
|
||||||
|
width: $size;
|
||||||
|
height: $size;
|
||||||
|
|
||||||
|
@if $circle {
|
||||||
|
border-radius: $size / 2;
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
---
|
||||||
|
|
||||||
|
(stylesheet
|
||||||
|
(mixin_statement
|
||||||
|
(name)
|
||||||
|
(parameters
|
||||||
|
(parameter (variable_name))
|
||||||
|
(parameter (variable_name) (default_value (plain_value))))
|
||||||
|
(block
|
||||||
|
(declaration (property_name) (variable_value))
|
||||||
|
(declaration (property_name) (variable_value))
|
||||||
|
(if_statement
|
||||||
|
(if_clause
|
||||||
|
(condition (variable_value))
|
||||||
|
(block
|
||||||
|
(declaration (property_name) (binary_expression (variable_value) (integer_value)))))))))
|
||||||
|
|
||||||
|
=================================
|
||||||
|
Else statements
|
||||||
|
=================================
|
||||||
|
|
||||||
|
@mixin theme-colors($light-theme: true) {
|
||||||
|
@if $light-theme {
|
||||||
|
color: $light-text;
|
||||||
|
} @else {
|
||||||
|
color: $dark-text;
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
---
|
||||||
|
|
||||||
|
(stylesheet
|
||||||
|
(mixin_statement
|
||||||
|
(name)
|
||||||
|
(parameters
|
||||||
|
(parameter (variable_name) (default_value (plain_value))))
|
||||||
|
(block
|
||||||
|
(if_statement
|
||||||
|
(if_clause
|
||||||
|
(condition (variable_value))
|
||||||
|
(block (declaration (property_name) (variable_value))))
|
||||||
|
(else_clause
|
||||||
|
(block (declaration (property_name) (variable_value))))))))
|
||||||
|
|
||||||
|
=================================
|
||||||
|
Else if statements
|
||||||
|
=================================
|
||||||
|
|
||||||
|
@mixin triangle($direction) {
|
||||||
|
@if $direction == up {
|
||||||
|
border-bottom-color: $color;
|
||||||
|
} @else if $direction == right {
|
||||||
|
border-left-color: $color;
|
||||||
|
} @else if $direction == down {
|
||||||
|
border-top-color: $color;
|
||||||
|
} @else {
|
||||||
|
border-right-color: $color;
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
---
|
||||||
|
|
||||||
|
(stylesheet
|
||||||
|
(mixin_statement
|
||||||
|
(name)
|
||||||
|
(parameters
|
||||||
|
(parameter (variable_name)))
|
||||||
|
(block
|
||||||
|
(if_statement
|
||||||
|
(if_clause
|
||||||
|
(condition (binary_expression (variable_value) (plain_value)))
|
||||||
|
(block (declaration (property_name) (variable_value))))
|
||||||
|
(else_if_clause
|
||||||
|
(condition (binary_expression (variable_value) (plain_value)))
|
||||||
|
(block (declaration (property_name) (variable_value))))
|
||||||
|
(else_if_clause
|
||||||
|
(condition (binary_expression (variable_value) (plain_value)))
|
||||||
|
(block (declaration (property_name) (variable_value))))
|
||||||
|
(else_clause
|
||||||
|
(block (declaration (property_name) (variable_value))))))))
|
||||||
|
|
||||||
|
=================================
|
||||||
|
Each statements
|
||||||
|
=================================
|
||||||
|
|
||||||
|
@each $size in $sizes {
|
||||||
|
.icon-#{$size} {
|
||||||
|
font-size: $size;
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
---
|
||||||
|
|
||||||
|
(stylesheet
|
||||||
|
(each_statement
|
||||||
|
(value)
|
||||||
|
(variable_value)
|
||||||
|
(block
|
||||||
|
(rule_set
|
||||||
|
(selectors (class_selector (class_name)))
|
||||||
|
(block (declaration (property_name) (variable_value)))))))
|
||||||
|
|
||||||
|
=================================
|
||||||
|
For statements
|
||||||
|
=================================
|
||||||
|
|
||||||
|
@for $i from 1 through 3 {
|
||||||
|
background-color: lighten($base-color, $i * 5%);
|
||||||
|
}
|
||||||
|
|
||||||
|
---
|
||||||
|
|
||||||
|
(stylesheet
|
||||||
|
(for_statement
|
||||||
|
(variable)
|
||||||
|
(from (integer_value))
|
||||||
|
(through (integer_value))
|
||||||
|
(block
|
||||||
|
(declaration
|
||||||
|
(property_name)
|
||||||
|
(call_expression
|
||||||
|
(function_name)
|
||||||
|
(arguments (variable_value)
|
||||||
|
(binary_expression (variable_value) (integer_value (unit)))))))))
|
||||||
|
|
||||||
|
=================================
|
||||||
|
While statements
|
||||||
|
=================================
|
||||||
|
|
||||||
|
@while $i < 3 {
|
||||||
|
background-color: lighten($base-color, $i * 5%);
|
||||||
|
$i: $i + 1;
|
||||||
|
}
|
||||||
|
|
||||||
|
---
|
||||||
|
|
||||||
|
(stylesheet
|
||||||
|
(while_statement
|
||||||
|
(binary_expression (variable_value) (integer_value))
|
||||||
|
(block
|
||||||
|
(declaration
|
||||||
|
(property_name)
|
||||||
|
(call_expression
|
||||||
|
(function_name)
|
||||||
|
(arguments (variable_value) (binary_expression (variable_value) (integer_value (unit))))))
|
||||||
|
(declaration (variable_name) (binary_expression (variable_value) (integer_value))))))
|
||||||
|
|
||||||
|
=================================
|
||||||
|
Functions
|
||||||
|
=================================
|
||||||
|
|
||||||
|
@function pow($base, $exponent) {
|
||||||
|
$result: 1;
|
||||||
|
@for $_ from 1 through $exponent {
|
||||||
|
$result: $result * $base;
|
||||||
|
}
|
||||||
|
@return $result;
|
||||||
|
}
|
||||||
|
|
||||||
|
.sidebar {
|
||||||
|
float: left;
|
||||||
|
margin-left: pow(4, 3) * 1px;
|
||||||
|
}
|
||||||
|
|
||||||
|
---
|
||||||
|
|
||||||
|
(stylesheet
|
||||||
|
(function_statement
|
||||||
|
(name)
|
||||||
|
(parameters
|
||||||
|
(parameter (variable_name))
|
||||||
|
(parameter (variable_name)))
|
||||||
|
(block
|
||||||
|
(declaration (variable_name) (integer_value))
|
||||||
|
(for_statement
|
||||||
|
(variable)
|
||||||
|
(from (integer_value))
|
||||||
|
(through (variable_value))
|
||||||
|
(block
|
||||||
|
(declaration (variable_name) (binary_expression (variable_value) (variable_value)))))
|
||||||
|
(return_statement (variable_value))))
|
||||||
|
(rule_set
|
||||||
|
(selectors (class_selector (class_name)))
|
||||||
|
(block
|
||||||
|
(declaration (property_name) (plain_value))
|
||||||
|
(declaration
|
||||||
|
(property_name)
|
||||||
|
(binary_expression
|
||||||
|
(call_expression (function_name) (arguments (integer_value) (integer_value)))
|
||||||
|
(integer_value (unit)))))))
|
||||||
|
|
||||||
|
=================================
|
||||||
|
Logging statements
|
||||||
|
=================================
|
||||||
|
|
||||||
|
@mixin foo {
|
||||||
|
@debug "debug";
|
||||||
|
@warn "warn";
|
||||||
|
@error "error";
|
||||||
|
}
|
||||||
|
|
||||||
|
---
|
||||||
|
|
||||||
|
(stylesheet
|
||||||
|
(mixin_statement
|
||||||
|
(name)
|
||||||
|
(block
|
||||||
|
(debug_statement (string_value))
|
||||||
|
(warn_statement (string_value))
|
||||||
|
(error_statement (string_value)))))
|
||||||
@ -0,0 +1,15 @@
|
|||||||
|
============================
|
||||||
|
Rule sets
|
||||||
|
============================
|
||||||
|
|
||||||
|
#some-id {
|
||||||
|
some-property: 5px;
|
||||||
|
}
|
||||||
|
|
||||||
|
---
|
||||||
|
|
||||||
|
(stylesheet
|
||||||
|
(rule_set
|
||||||
|
(selectors (id_selector (id_name)))
|
||||||
|
(block
|
||||||
|
(declaration (property_name) (integer_value (unit))))))
|
||||||
File diff suppressed because it is too large
Load Diff
@ -0,0 +1,283 @@
|
|||||||
|
// from https://awardwinningfjords.com/2010/04/09/example-scss-sassy-css-file.html
|
||||||
|
|
||||||
|
@import "compass";
|
||||||
|
@import "blueprint";
|
||||||
|
@import "blueprint/fancy_type";
|
||||||
|
|
||||||
|
$blueprint-grid-columns: 5;
|
||||||
|
$blueprint-grid-width: 150px;
|
||||||
|
$blueprint-grid-margin: 20px;
|
||||||
|
|
||||||
|
$blueprint-font-family: Helvetica Neue, Arial, Helvetica, sans-serif;
|
||||||
|
$blueprint-fixed-font-family:'andale mono', 'lucida console', monospace;
|
||||||
|
$blueprint-font-size: 12px;
|
||||||
|
|
||||||
|
$text-color: #555555;
|
||||||
|
$light-text-color: #a0a0a0;
|
||||||
|
$quote-text-color: #f27a00;
|
||||||
|
$disclosure-text-color: #ed7c06;
|
||||||
|
|
||||||
|
$thick-border: 8px solid black;
|
||||||
|
$dotted-border: 1px dotted #999999;
|
||||||
|
|
||||||
|
$header-background-color: #f07c05;
|
||||||
|
$paging-background-color: black;
|
||||||
|
$unfocused-background-color: #f1f0ec;
|
||||||
|
$quote-background-color: #f1f0ec;
|
||||||
|
|
||||||
|
$story-title-color: #f07c05;
|
||||||
|
|
||||||
|
@include global-reset;
|
||||||
|
@include blueprint-typography;
|
||||||
|
|
||||||
|
body {
|
||||||
|
background: $unfocused-background-color image_url("white-bg.jpg") repeat-y 50% 0;
|
||||||
|
color: $text-color;
|
||||||
|
}
|
||||||
|
|
||||||
|
.content_wrapper {
|
||||||
|
@include container;
|
||||||
|
width: 910px;
|
||||||
|
}
|
||||||
|
|
||||||
|
#header {
|
||||||
|
height: 72px;
|
||||||
|
background: $header-background-color;
|
||||||
|
@include clearfix;
|
||||||
|
|
||||||
|
h1 {
|
||||||
|
color: white;
|
||||||
|
@include float-left;
|
||||||
|
a {
|
||||||
|
@include replace-text("logo.jpg");
|
||||||
|
width: 116px;
|
||||||
|
height: 72px;
|
||||||
|
display: block;
|
||||||
|
text-decoration: none;
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
ul {
|
||||||
|
@include horizontal-list;
|
||||||
|
padding: 0 0 0 25px;
|
||||||
|
li {
|
||||||
|
@include incr(18px);
|
||||||
|
padding: 0 20px 0 0;
|
||||||
|
text-transform: uppercase;
|
||||||
|
a {
|
||||||
|
color: #febf0f;
|
||||||
|
text-decoration: none;
|
||||||
|
width: 100px;
|
||||||
|
height: 72px;
|
||||||
|
display: block;
|
||||||
|
}
|
||||||
|
&#header-threads a {
|
||||||
|
@include replace-text("header-threads-text.jpg");
|
||||||
|
}
|
||||||
|
&#header-timeline a {
|
||||||
|
@include replace-text("header-timeline-text.jpg");
|
||||||
|
}
|
||||||
|
}
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
#paging {
|
||||||
|
background: $paging-background-color;
|
||||||
|
height: 33px;
|
||||||
|
padding: 15px 0 0 0;
|
||||||
|
|
||||||
|
h6 {
|
||||||
|
@include float-left;
|
||||||
|
color: #908f8b;
|
||||||
|
padding-right: 20px;
|
||||||
|
text-transform: uppercase;
|
||||||
|
a {
|
||||||
|
color: #f07b07;
|
||||||
|
text-decoration: none;
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
ul {
|
||||||
|
@include horizontal-list;
|
||||||
|
li {
|
||||||
|
padding: 3px 4px;
|
||||||
|
a {
|
||||||
|
color: #4c4c4c;
|
||||||
|
@include replace-text("thread-paging-inactive-bullet.jpg");
|
||||||
|
width: 10px;
|
||||||
|
height: 10px;
|
||||||
|
display: block;
|
||||||
|
}
|
||||||
|
&.active a {
|
||||||
|
color: #f17d06;
|
||||||
|
background-image: image_@import "compass";
|
||||||
|
}
|
||||||
|
}
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
#content {
|
||||||
|
position: relative;
|
||||||
|
#previous {
|
||||||
|
position: absolute;
|
||||||
|
top: 0;
|
||||||
|
left: 0;
|
||||||
|
text-align: right;
|
||||||
|
}
|
||||||
|
#next {
|
||||||
|
position: absolute;
|
||||||
|
top: 0;
|
||||||
|
right: 0;
|
||||||
|
text-align: left;
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
#thread {
|
||||||
|
@include container;
|
||||||
|
width: 910px;
|
||||||
|
top: 0px;
|
||||||
|
left: 0px;
|
||||||
|
|
||||||
|
@include transition-property(left);
|
||||||
|
@include transition-duration(0.5s);
|
||||||
|
@include transition-timing-function(ease-in-out);
|
||||||
|
|
||||||
|
@for $i from 0 through 30 {
|
||||||
|
&.position#{$i} {
|
||||||
|
left: ($i * -910px);
|
||||||
|
}
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
.js {
|
||||||
|
#content {
|
||||||
|
overflow: hidden;
|
||||||
|
width: 100%;
|
||||||
|
}
|
||||||
|
|
||||||
|
#thread {
|
||||||
|
padding: 0;
|
||||||
|
width: 5000px;
|
||||||
|
position: absolute;
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
.story {
|
||||||
|
@include float-left;
|
||||||
|
width: 810px;
|
||||||
|
padding: 0 50px;
|
||||||
|
|
||||||
|
h4.date {
|
||||||
|
@include float-right;
|
||||||
|
@include span(1);
|
||||||
|
background: $unfocused-background-color;
|
||||||
|
padding: 10px 20px;
|
||||||
|
@include border-radius(3px);
|
||||||
|
}
|
||||||
|
|
||||||
|
h1 {
|
||||||
|
padding: 40px 0 20px 0;
|
||||||
|
border-bottom: $thick-border;
|
||||||
|
color: $story-title-color;
|
||||||
|
@include incr(30px);
|
||||||
|
}
|
||||||
|
|
||||||
|
.artifacts {
|
||||||
|
@include column(3);
|
||||||
|
|
||||||
|
.row {
|
||||||
|
@include clearfix;
|
||||||
|
border-bottom: $dotted-border;
|
||||||
|
margin-bottom: $blueprint-grid-margin;
|
||||||
|
}
|
||||||
|
|
||||||
|
.artifact {
|
||||||
|
color: $light-text-color;
|
||||||
|
img {
|
||||||
|
margin-bottom: 0.5em;
|
||||||
|
}
|
||||||
|
a {
|
||||||
|
font-weight: bold;
|
||||||
|
text-decoration: none;
|
||||||
|
color: #0a83e0;
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
.threecol { @include column(3); }
|
||||||
|
.twocol { @include column(2); }
|
||||||
|
.onecol { @include column(1); }
|
||||||
|
.last { @include last; }
|
||||||
|
}
|
||||||
|
|
||||||
|
.information {
|
||||||
|
@include column(1.6, true);
|
||||||
|
border-bottom: $dotted-border;
|
||||||
|
margin-left: 40px;
|
||||||
|
|
||||||
|
h2 {
|
||||||
|
@include incr(20px, $blueprint-font-size, 35px);
|
||||||
|
}
|
||||||
|
|
||||||
|
.textblock p {
|
||||||
|
@include incr(13px, $blueprint-font-size, 26px);
|
||||||
|
}
|
||||||
|
|
||||||
|
.quote {
|
||||||
|
color: $quote-text-color;
|
||||||
|
blockquote {
|
||||||
|
@include incr(18px, $blueprint-font-size, 30px);
|
||||||
|
color: $quote-text-color;
|
||||||
|
margin: 0;
|
||||||
|
padding: 12px 18px;
|
||||||
|
background: $quote-background-color;
|
||||||
|
@include border-radius(5px);
|
||||||
|
}
|
||||||
|
cite {
|
||||||
|
display: block;
|
||||||
|
padding: 0.5em 18px 1.5em 18px;
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
.disclosure {
|
||||||
|
border-top: $dotted-border;
|
||||||
|
h5 {
|
||||||
|
padding: 10px 0;
|
||||||
|
margin: 0;
|
||||||
|
color: $disclosure-text-color;
|
||||||
|
}
|
||||||
|
p {
|
||||||
|
color: #a8a8a8;
|
||||||
|
}
|
||||||
|
}
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
#footer {
|
||||||
|
@include container;
|
||||||
|
background: white;
|
||||||
|
width: 810px;
|
||||||
|
padding: $blueprint-grid-margin 0;
|
||||||
|
|
||||||
|
.inner {
|
||||||
|
border-top: $thick-border;
|
||||||
|
padding: 30px 0;
|
||||||
|
}
|
||||||
|
|
||||||
|
p {
|
||||||
|
@include float-right;
|
||||||
|
@include incr(10px);
|
||||||
|
color: #b3b3b3;
|
||||||
|
}
|
||||||
|
|
||||||
|
ul {
|
||||||
|
@include horizontal-list;
|
||||||
|
|
||||||
|
li {
|
||||||
|
padding: 0 30px 0 0;
|
||||||
|
a {
|
||||||
|
text-decoration: none;
|
||||||
|
color: #ef7a06;
|
||||||
|
}
|
||||||
|
}
|
||||||
|
}
|
||||||
|
}
|
||||||
@ -0,0 +1,57 @@
|
|||||||
|
// from https://scotch.io/tutorials/getting-started-with-sass
|
||||||
|
|
||||||
|
// ----
|
||||||
|
// Sass (v3.4.4)
|
||||||
|
// Compass (v1.0.1)
|
||||||
|
// ----
|
||||||
|
|
||||||
|
@mixin renderGridStyles($settings) {
|
||||||
|
.container {
|
||||||
|
padding-right: map-get($settings, "margin");
|
||||||
|
padding-left: map-get($settings, "margin");
|
||||||
|
margin-right: auto;
|
||||||
|
margin-left: auto;
|
||||||
|
max-width: map-get($settings, "maxWidth");
|
||||||
|
}
|
||||||
|
|
||||||
|
.row {
|
||||||
|
margin-right: map-get($settings, "margin") * -1;
|
||||||
|
margin-left: map-get($settings, "margin") * -1;
|
||||||
|
}
|
||||||
|
|
||||||
|
$breakpoints: map-get($settings, "breakpoints");
|
||||||
|
|
||||||
|
@each $key, $breakpoint in $breakpoints {
|
||||||
|
@include media($breakpoint) {
|
||||||
|
@include renderGrid($key, $settings);
|
||||||
|
}
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
@mixin renderGrid($key, $settings) {
|
||||||
|
$i: 1;
|
||||||
|
|
||||||
|
@while $i <= map-get($settings, "columns") {
|
||||||
|
.col-#{$key}-#{$i} {
|
||||||
|
float: left;
|
||||||
|
width: 100% * $i / map-get($settings, "columns");
|
||||||
|
}
|
||||||
|
|
||||||
|
$i: $i + 1;
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
@mixin media($queryString) {
|
||||||
|
@media #{$queryString} {
|
||||||
|
@content;
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
@include renderGridStyles($settings);
|
||||||
|
|
||||||
|
p {
|
||||||
|
padding: 20px;
|
||||||
|
color: white;
|
||||||
|
background: #9b59b6;
|
||||||
|
margin: 20px;
|
||||||
|
}
|
||||||
@ -0,0 +1,398 @@
|
|||||||
|
module.exports = grammar({
|
||||||
|
name: "scss",
|
||||||
|
|
||||||
|
extras: ($) => [/\s/, $.comment, $.single_line_comment],
|
||||||
|
|
||||||
|
externals: ($) => [$._descendant_operator],
|
||||||
|
|
||||||
|
conflicts: ($) => [[$._selector, $.declaration]],
|
||||||
|
|
||||||
|
inline: ($) => [$._top_level_item, $._block_item],
|
||||||
|
|
||||||
|
rules: {
|
||||||
|
stylesheet: ($) => repeat($._top_level_item),
|
||||||
|
|
||||||
|
_top_level_item: ($) =>
|
||||||
|
choice(
|
||||||
|
$.declaration,
|
||||||
|
$.rule_set,
|
||||||
|
$.import_statement,
|
||||||
|
$.media_statement,
|
||||||
|
$.charset_statement,
|
||||||
|
$.namespace_statement,
|
||||||
|
$.keyframes_statement,
|
||||||
|
$.supports_statement,
|
||||||
|
$.use_statement,
|
||||||
|
$.forward_statement,
|
||||||
|
$.apply_statement,
|
||||||
|
$.mixin_statement,
|
||||||
|
$.include_statement,
|
||||||
|
$.if_statement,
|
||||||
|
$.each_statement,
|
||||||
|
$.for_statement,
|
||||||
|
$.while_statement,
|
||||||
|
$.function_statement,
|
||||||
|
$.error_statement,
|
||||||
|
$.warn_statement,
|
||||||
|
$.debug_statement,
|
||||||
|
$.at_rule,
|
||||||
|
$.placeholder
|
||||||
|
),
|
||||||
|
|
||||||
|
// Statements
|
||||||
|
|
||||||
|
import_statement: ($) => seq("@import", $._value, sep(",", $._query), ";"),
|
||||||
|
|
||||||
|
media_statement: ($) => seq("@media", sep1(",", $._query), $.block),
|
||||||
|
|
||||||
|
charset_statement: ($) => seq("@charset", $._value, ";"),
|
||||||
|
|
||||||
|
namespace_statement: ($) =>
|
||||||
|
seq(
|
||||||
|
"@namespace",
|
||||||
|
optional(alias($.identifier, $.namespace_name)),
|
||||||
|
choice($.string_value, $.call_expression),
|
||||||
|
";"
|
||||||
|
),
|
||||||
|
|
||||||
|
keyframes_statement: ($) =>
|
||||||
|
seq(
|
||||||
|
choice("@keyframes", alias(/@[-a-z]+keyframes/, $.at_keyword)),
|
||||||
|
alias($.identifier, $.keyframes_name),
|
||||||
|
$.keyframe_block_list
|
||||||
|
),
|
||||||
|
|
||||||
|
keyframe_block_list: ($) => seq("{", repeat($.keyframe_block), "}"),
|
||||||
|
|
||||||
|
keyframe_block: ($) => seq(choice($.from, $.to, $.integer_value), $.block),
|
||||||
|
|
||||||
|
from: ($) => "from",
|
||||||
|
to: ($) => "to",
|
||||||
|
|
||||||
|
supports_statement: ($) => seq("@supports", $._query, $.block),
|
||||||
|
|
||||||
|
at_rule: ($) => seq($.at_keyword, sep(",", $._query), choice(";", $.block)),
|
||||||
|
|
||||||
|
use_statement: ($) => seq("@use", $._value, ";"),
|
||||||
|
|
||||||
|
forward_statement: ($) => seq("@forward", $._value, ";"),
|
||||||
|
|
||||||
|
apply_statement: ($) => seq("@apply", repeat($._value), ";"),
|
||||||
|
|
||||||
|
parameters: ($) => seq("(", sep1(",", $.parameter), ")"),
|
||||||
|
|
||||||
|
parameter: ($) =>
|
||||||
|
seq(
|
||||||
|
alias($.variable_identifier, $.variable_name),
|
||||||
|
optional(seq(":", alias($._value, $.default_value)))
|
||||||
|
),
|
||||||
|
|
||||||
|
mixin_statement: ($) =>
|
||||||
|
seq("@mixin", alias($.identifier, $.name), optional($.parameters), $.block),
|
||||||
|
|
||||||
|
include_statement: ($) =>
|
||||||
|
seq(
|
||||||
|
"@include",
|
||||||
|
$.identifier,
|
||||||
|
optional(alias($.include_arguments, $.arguments)),
|
||||||
|
choice($.block, ";")
|
||||||
|
),
|
||||||
|
|
||||||
|
include_arguments: ($) =>
|
||||||
|
seq(
|
||||||
|
token.immediate("("),
|
||||||
|
sep1(",", alias($.include_argument, $.argument)),
|
||||||
|
token.immediate(")")
|
||||||
|
),
|
||||||
|
|
||||||
|
include_argument: ($) =>
|
||||||
|
seq(
|
||||||
|
optional(seq(alias($.variable_identifier, $.argument_name), ":")),
|
||||||
|
alias($._value, $.argument_value)
|
||||||
|
),
|
||||||
|
|
||||||
|
placeholder: ($) => seq("%", alias($.identifier, $.name), $.block),
|
||||||
|
|
||||||
|
extend_statement: ($) => seq("@extend", choice($._value, $.class_selector), ";"),
|
||||||
|
|
||||||
|
if_statement: ($) => seq($.if_clause, repeat($.else_if_clause), optional($.else_clause)),
|
||||||
|
|
||||||
|
if_clause: ($) => seq("@if", alias($._value, $.condition), $.block),
|
||||||
|
|
||||||
|
else_if_clause: ($) => seq("@else", "if", alias($._value, $.condition), $.block),
|
||||||
|
|
||||||
|
else_clause: ($) => seq("@else", $.block),
|
||||||
|
|
||||||
|
each_statement: ($) =>
|
||||||
|
seq(
|
||||||
|
"@each",
|
||||||
|
optional(seq(alias($.variable_identifier, $.key), ",")),
|
||||||
|
alias($.variable_identifier, $.value),
|
||||||
|
"in",
|
||||||
|
$._value,
|
||||||
|
$.block
|
||||||
|
),
|
||||||
|
|
||||||
|
for_statement: ($) =>
|
||||||
|
seq(
|
||||||
|
"@for",
|
||||||
|
alias($.variable_identifier, $.variable),
|
||||||
|
"from",
|
||||||
|
alias($._value, $.from),
|
||||||
|
"through",
|
||||||
|
alias($._value, $.through),
|
||||||
|
$.block
|
||||||
|
),
|
||||||
|
|
||||||
|
while_statement: ($) => seq("@while", $._value, $.block),
|
||||||
|
|
||||||
|
function_statement: ($) =>
|
||||||
|
seq("@function", alias($.identifier, $.name), optional($.parameters), $.block),
|
||||||
|
|
||||||
|
return_statement: ($) => seq("@return", $._value, ";"),
|
||||||
|
|
||||||
|
at_root_statement: ($) => seq("@at-root", $._value, $.block),
|
||||||
|
|
||||||
|
error_statement: ($) => seq("@error", $._value, ";"),
|
||||||
|
|
||||||
|
warn_statement: ($) => seq("@warn", $._value, ";"),
|
||||||
|
|
||||||
|
debug_statement: ($) => seq("@debug", $._value, ";"),
|
||||||
|
|
||||||
|
// Rule sets
|
||||||
|
|
||||||
|
rule_set: ($) => seq($.selectors, $.block),
|
||||||
|
|
||||||
|
selectors: ($) => sep1(",", $._selector),
|
||||||
|
|
||||||
|
block: ($) =>
|
||||||
|
seq("{", repeat($._block_item), optional(alias($.last_declaration, $.declaration)), "}"),
|
||||||
|
|
||||||
|
_block_item: ($) =>
|
||||||
|
choice(
|
||||||
|
$.declaration,
|
||||||
|
$.rule_set,
|
||||||
|
$.import_statement,
|
||||||
|
$.media_statement,
|
||||||
|
$.charset_statement,
|
||||||
|
$.namespace_statement,
|
||||||
|
$.keyframes_statement,
|
||||||
|
$.supports_statement,
|
||||||
|
$.mixin_statement,
|
||||||
|
$.include_statement,
|
||||||
|
$.extend_statement,
|
||||||
|
$.if_statement,
|
||||||
|
$.each_statement,
|
||||||
|
$.for_statement,
|
||||||
|
$.while_statement,
|
||||||
|
$.function_statement,
|
||||||
|
$.return_statement,
|
||||||
|
$.at_root_statement,
|
||||||
|
$.error_statement,
|
||||||
|
$.warn_statement,
|
||||||
|
$.debug_statement,
|
||||||
|
$.at_rule
|
||||||
|
),
|
||||||
|
|
||||||
|
// Selectors
|
||||||
|
|
||||||
|
_selector: ($) =>
|
||||||
|
choice(
|
||||||
|
$.universal_selector,
|
||||||
|
alias($.identifier, $.tag_name),
|
||||||
|
$.class_selector,
|
||||||
|
$.nesting_selector,
|
||||||
|
$.pseudo_class_selector,
|
||||||
|
$.pseudo_element_selector,
|
||||||
|
$.id_selector,
|
||||||
|
$.attribute_selector,
|
||||||
|
$.string_value,
|
||||||
|
$.child_selector,
|
||||||
|
$.descendant_selector,
|
||||||
|
$.sibling_selector,
|
||||||
|
$.adjacent_sibling_selector
|
||||||
|
),
|
||||||
|
|
||||||
|
nesting_selector: ($) => "&",
|
||||||
|
|
||||||
|
universal_selector: ($) => "*",
|
||||||
|
|
||||||
|
class_selector: ($) =>
|
||||||
|
prec(1, seq(optional($._selector), choice(".", $.nesting_selector), alias($.identifier, $.class_name))),
|
||||||
|
|
||||||
|
pseudo_class_selector: ($) =>
|
||||||
|
seq(
|
||||||
|
optional($._selector),
|
||||||
|
":",
|
||||||
|
alias($.identifier, $.class_name),
|
||||||
|
optional(alias($.pseudo_class_arguments, $.arguments))
|
||||||
|
),
|
||||||
|
|
||||||
|
pseudo_element_selector: ($) =>
|
||||||
|
seq(optional($._selector), "::", alias($.identifier, $.tag_name)),
|
||||||
|
|
||||||
|
id_selector: ($) => seq(optional($._selector), "#", alias($.identifier, $.id_name)),
|
||||||
|
|
||||||
|
attribute_selector: ($) =>
|
||||||
|
seq(
|
||||||
|
optional($._selector),
|
||||||
|
"[",
|
||||||
|
alias($.identifier, $.attribute_name),
|
||||||
|
optional(seq(choice("=", "~=", "^=", "|=", "*=", "$="), $._value)),
|
||||||
|
"]"
|
||||||
|
),
|
||||||
|
|
||||||
|
child_selector: ($) => prec.left(seq($._selector, ">", $._selector)),
|
||||||
|
|
||||||
|
descendant_selector: ($) => prec.left(seq($._selector, $._descendant_operator, $._selector)),
|
||||||
|
|
||||||
|
sibling_selector: ($) => prec.left(seq($._selector, "~", $._selector)),
|
||||||
|
|
||||||
|
adjacent_sibling_selector: ($) => prec.left(seq($._selector, "+", $._selector)),
|
||||||
|
|
||||||
|
pseudo_class_arguments: ($) =>
|
||||||
|
seq(token.immediate("("), sep(",", choice($._selector, repeat1($._value))), ")"),
|
||||||
|
|
||||||
|
// Declarations
|
||||||
|
|
||||||
|
declaration: ($) =>
|
||||||
|
seq(
|
||||||
|
choice(alias($.variable_identifier, $.variable_name), alias($.identifier, $.property_name)),
|
||||||
|
":",
|
||||||
|
$._value,
|
||||||
|
repeat(seq(optional(","), $._value)),
|
||||||
|
optional($.important),
|
||||||
|
";"
|
||||||
|
),
|
||||||
|
|
||||||
|
last_declaration: ($) =>
|
||||||
|
prec(
|
||||||
|
1,
|
||||||
|
seq(
|
||||||
|
alias($.identifier, $.property_name),
|
||||||
|
":",
|
||||||
|
$._value,
|
||||||
|
repeat(seq(optional(","), $._value)),
|
||||||
|
optional($.important)
|
||||||
|
)
|
||||||
|
),
|
||||||
|
|
||||||
|
important: ($) => "!important",
|
||||||
|
|
||||||
|
// Media queries
|
||||||
|
|
||||||
|
_query: ($) =>
|
||||||
|
choice(
|
||||||
|
alias($.identifier, $.keyword_query),
|
||||||
|
$.feature_query,
|
||||||
|
$.binary_query,
|
||||||
|
$.unary_query,
|
||||||
|
$.selector_query,
|
||||||
|
$.parenthesized_query
|
||||||
|
),
|
||||||
|
|
||||||
|
feature_query: ($) =>
|
||||||
|
seq("(", alias($.identifier, $.feature_name), ":", repeat1($._value), ")"),
|
||||||
|
|
||||||
|
parenthesized_query: ($) => seq("(", $._query, ")"),
|
||||||
|
|
||||||
|
binary_query: ($) => prec.left(seq($._query, choice("and", "or"), $._query)),
|
||||||
|
|
||||||
|
unary_query: ($) => prec(1, seq(choice("not", "only"), $._query)),
|
||||||
|
|
||||||
|
selector_query: ($) => seq("selector", "(", $._selector, ")"),
|
||||||
|
|
||||||
|
// Property Values
|
||||||
|
|
||||||
|
_value: ($) =>
|
||||||
|
prec(
|
||||||
|
-1,
|
||||||
|
choice(
|
||||||
|
alias($.identifier, $.plain_value),
|
||||||
|
alias($.variable_identifier, $.variable_value),
|
||||||
|
$.plain_value,
|
||||||
|
$.color_value,
|
||||||
|
$.integer_value,
|
||||||
|
$.float_value,
|
||||||
|
$.string_value,
|
||||||
|
$.binary_expression,
|
||||||
|
$.parenthesized_value,
|
||||||
|
$.call_expression
|
||||||
|
)
|
||||||
|
),
|
||||||
|
|
||||||
|
parenthesized_value: ($) => seq("(", $._value, ")"),
|
||||||
|
|
||||||
|
color_value: ($) => seq("#", token.immediate(/[0-9a-fA-F]{3,8}/)),
|
||||||
|
|
||||||
|
string_value: ($) =>
|
||||||
|
token(choice(seq("'", /([^'\n]|\\(.|\n))*/, "'"), seq('"', /([^"\n]|\\(.|\n))*/, '"'))),
|
||||||
|
|
||||||
|
integer_value: ($) => seq(token(seq(optional(choice("+", "-")), /\d+/)), optional($.unit)),
|
||||||
|
|
||||||
|
float_value: ($) =>
|
||||||
|
seq(
|
||||||
|
token(
|
||||||
|
seq(
|
||||||
|
optional(choice("+", "-")),
|
||||||
|
/\d*/,
|
||||||
|
choice(
|
||||||
|
seq(".", /\d+/),
|
||||||
|
seq(/[eE]/, optional("-"), /\d+/),
|
||||||
|
seq(".", /\d+/, /[eE]/, optional("-"), /\d+/)
|
||||||
|
)
|
||||||
|
)
|
||||||
|
),
|
||||||
|
optional($.unit)
|
||||||
|
),
|
||||||
|
|
||||||
|
unit: ($) => token.immediate(/[a-zA-Z%]+/),
|
||||||
|
|
||||||
|
call_expression: ($) => seq(alias($.identifier, $.function_name), $.arguments),
|
||||||
|
|
||||||
|
binary_expression: ($) =>
|
||||||
|
prec.left(
|
||||||
|
seq($._value, choice("+", "-", "*", "/", "==", "<", ">", "!=", "<=", ">="), $._value)
|
||||||
|
),
|
||||||
|
|
||||||
|
arguments: ($) => seq(token.immediate("("), sep(choice(",", ";"), repeat1($._value)), ")"),
|
||||||
|
|
||||||
|
identifier: ($) =>
|
||||||
|
/((#\{[a-zA-Z0-9-_,&\$\.\(\) ]*\})|(--|-?[a-zA-Z_]))([a-zA-Z0-9-_]|(#\{[a-zA-Z0-9-_,&\$\.\(\) ]*\}))*/,
|
||||||
|
|
||||||
|
variable_identifier: ($) => /([a-zA-Z_]+\.)?\$[a-zA-Z-_][a-zA-Z0-9-_]*/,
|
||||||
|
|
||||||
|
at_keyword: ($) => /@[a-zA-Z-_]+/,
|
||||||
|
|
||||||
|
comment: ($) => token(seq("/*", /[^*]*\*+([^/*][^*]*\*+)*/, "/")),
|
||||||
|
|
||||||
|
single_line_comment: ($) => token(seq("//", /.*/)),
|
||||||
|
|
||||||
|
plain_value: ($) =>
|
||||||
|
token(
|
||||||
|
seq(
|
||||||
|
repeat(
|
||||||
|
choice(
|
||||||
|
/[-_]/,
|
||||||
|
/\/[^\*\s,;!{}()\[\]]/ // Slash not followed by a '*' (which would be a comment)
|
||||||
|
)
|
||||||
|
),
|
||||||
|
/[a-zA-Z]/,
|
||||||
|
repeat(
|
||||||
|
choice(
|
||||||
|
/[^/\s,;!{}()\[\]]/, // Not a slash, not a delimiter character
|
||||||
|
/\/[^\*\s,;!{}()\[\]]/ // Slash not followed by a '*' (which would be a comment)
|
||||||
|
)
|
||||||
|
)
|
||||||
|
)
|
||||||
|
),
|
||||||
|
},
|
||||||
|
});
|
||||||
|
|
||||||
|
function sep(separator, rule) {
|
||||||
|
return optional(sep1(separator, rule));
|
||||||
|
}
|
||||||
|
|
||||||
|
function sep1(separator, rule) {
|
||||||
|
return seq(rule, repeat(seq(separator, rule)));
|
||||||
|
}
|
||||||
@ -0,0 +1,13 @@
|
|||||||
|
try {
|
||||||
|
module.exports = require("./build/Release/tree_sitter_scss_binding");
|
||||||
|
} catch (error) {
|
||||||
|
try {
|
||||||
|
module.exports = require("./build/Debug/tree_sitter_scss_binding");
|
||||||
|
} catch (_) {
|
||||||
|
throw error
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
try {
|
||||||
|
module.exports.nodeTypeInfo = require("./src/node-types.json");
|
||||||
|
} catch (_) {}
|
||||||
@ -0,0 +1,33 @@
|
|||||||
|
{
|
||||||
|
"name": "tree-sitter-scss",
|
||||||
|
"version": "0.0.1",
|
||||||
|
"description": "SCSS grammar for tree-sitter",
|
||||||
|
"main": "bindings/node",
|
||||||
|
"keywords": [
|
||||||
|
"parser",
|
||||||
|
"lexer"
|
||||||
|
],
|
||||||
|
"author": "Serenade Labs, Inc.",
|
||||||
|
"license": "MIT",
|
||||||
|
"dependencies": {
|
||||||
|
"nan": "^2.11.1"
|
||||||
|
},
|
||||||
|
"devDependencies": {
|
||||||
|
"tree-sitter-cli": "^0.19.4"
|
||||||
|
},
|
||||||
|
"scripts": {
|
||||||
|
"build": "tree-sitter generate && node-gyp build",
|
||||||
|
"build-test": "tree-sitter generate && node-gyp build && tree-sitter test",
|
||||||
|
"test": "tree-sitter test && tree-sitter parse examples/*.scss --quiet --time",
|
||||||
|
"test-windows": "tree-sitter test"
|
||||||
|
},
|
||||||
|
"tree-sitter": [
|
||||||
|
{
|
||||||
|
"scope": "source.scss",
|
||||||
|
"file-types": [
|
||||||
|
"scss"
|
||||||
|
],
|
||||||
|
"injection-regex": "^scss$"
|
||||||
|
}
|
||||||
|
]
|
||||||
|
}
|
||||||
@ -0,0 +1,63 @@
|
|||||||
|
(comment) @comment
|
||||||
|
|
||||||
|
(tag_name) @tag
|
||||||
|
(nesting_selector) @tag
|
||||||
|
(universal_selector) @tag
|
||||||
|
|
||||||
|
"~" @operator
|
||||||
|
">" @operator
|
||||||
|
"+" @operator
|
||||||
|
"-" @operator
|
||||||
|
"*" @operator
|
||||||
|
"/" @operator
|
||||||
|
"=" @operator
|
||||||
|
"^=" @operator
|
||||||
|
"|=" @operator
|
||||||
|
"~=" @operator
|
||||||
|
"$=" @operator
|
||||||
|
"*=" @operator
|
||||||
|
|
||||||
|
"and" @operator
|
||||||
|
"or" @operator
|
||||||
|
"not" @operator
|
||||||
|
"only" @operator
|
||||||
|
|
||||||
|
(attribute_selector (plain_value) @string)
|
||||||
|
(pseudo_element_selector (tag_name) @attribute)
|
||||||
|
(pseudo_class_selector (class_name) @attribute)
|
||||||
|
|
||||||
|
(class_name) @property
|
||||||
|
(id_name) @property
|
||||||
|
(namespace_name) @property
|
||||||
|
(property_name) @property
|
||||||
|
(feature_name) @property
|
||||||
|
|
||||||
|
(attribute_name) @attribute
|
||||||
|
|
||||||
|
(function_name) @function
|
||||||
|
|
||||||
|
((property_name) @variable
|
||||||
|
(match? @variable "^--"))
|
||||||
|
((plain_value) @variable
|
||||||
|
(match? @variable "^--"))
|
||||||
|
|
||||||
|
"@media" @keyword
|
||||||
|
"@import" @keyword
|
||||||
|
"@charset" @keyword
|
||||||
|
"@namespace" @keyword
|
||||||
|
"@supports" @keyword
|
||||||
|
"@keyframes" @keyword
|
||||||
|
(at_keyword) @keyword
|
||||||
|
(to) @keyword
|
||||||
|
(from) @keyword
|
||||||
|
(important) @keyword
|
||||||
|
|
||||||
|
(string_value) @string
|
||||||
|
(color_value) @string.special
|
||||||
|
|
||||||
|
(integer_value) @number
|
||||||
|
(float_value) @number
|
||||||
|
(unit) @type
|
||||||
|
|
||||||
|
"#" @punctuation.delimiter
|
||||||
|
"," @punctuation.delimiter
|
||||||
@ -0,0 +1,28 @@
|
|||||||
|
#include "tree_sitter/parser.h"
|
||||||
|
#include <node.h>
|
||||||
|
#include "nan.h"
|
||||||
|
|
||||||
|
using namespace v8;
|
||||||
|
|
||||||
|
extern "C" TSLanguage * tree_sitter_scss();
|
||||||
|
|
||||||
|
namespace {
|
||||||
|
|
||||||
|
NAN_METHOD(New) {}
|
||||||
|
|
||||||
|
void Init(Local<Object> exports, Local<Object> module) {
|
||||||
|
Local<FunctionTemplate> tpl = Nan::New<FunctionTemplate>(New);
|
||||||
|
tpl->SetClassName(Nan::New("Language").ToLocalChecked());
|
||||||
|
tpl->InstanceTemplate()->SetInternalFieldCount(1);
|
||||||
|
|
||||||
|
Local<Function> constructor = Nan::GetFunction(tpl).ToLocalChecked();
|
||||||
|
Local<Object> instance = constructor->NewInstance(Nan::GetCurrentContext()).ToLocalChecked();
|
||||||
|
Nan::SetInternalFieldPointer(instance, 0, tree_sitter_scss());
|
||||||
|
|
||||||
|
Nan::Set(instance, Nan::New("name").ToLocalChecked(), Nan::New("scss").ToLocalChecked());
|
||||||
|
Nan::Set(module, Nan::New("exports").ToLocalChecked(), instance);
|
||||||
|
}
|
||||||
|
|
||||||
|
NODE_MODULE(tree_sitter_scss_binding, Init)
|
||||||
|
|
||||||
|
} // namespace
|
||||||
File diff suppressed because it is too large
Load Diff
File diff suppressed because it is too large
Load Diff
File diff suppressed because it is too large
Load Diff
@ -0,0 +1,53 @@
|
|||||||
|
#include <tree_sitter/parser.h>
|
||||||
|
#include <wctype.h>
|
||||||
|
|
||||||
|
enum TokenType {
|
||||||
|
DESCENDANT_OP,
|
||||||
|
};
|
||||||
|
|
||||||
|
void *tree_sitter_scss_external_scanner_create() { return NULL; }
|
||||||
|
void tree_sitter_scss_external_scanner_destroy(void *p) {}
|
||||||
|
void tree_sitter_scss_external_scanner_reset(void *p) {}
|
||||||
|
unsigned tree_sitter_scss_external_scanner_serialize(void *p, char *buffer) { return 0; }
|
||||||
|
void tree_sitter_scss_external_scanner_deserialize(void *p, const char *b, unsigned n) {}
|
||||||
|
|
||||||
|
bool tree_sitter_scss_external_scanner_scan(void *payload, TSLexer *lexer, const bool *valid_symbols) {
|
||||||
|
if (iswspace(lexer->lookahead) && valid_symbols[DESCENDANT_OP]) {
|
||||||
|
lexer->result_symbol = DESCENDANT_OP;
|
||||||
|
|
||||||
|
lexer->advance(lexer, true);
|
||||||
|
while (iswspace(lexer->lookahead)) {
|
||||||
|
lexer->advance(lexer, true);
|
||||||
|
}
|
||||||
|
lexer->mark_end(lexer);
|
||||||
|
|
||||||
|
if (
|
||||||
|
lexer->lookahead == '#' ||
|
||||||
|
lexer->lookahead == '.' ||
|
||||||
|
lexer->lookahead == '[' ||
|
||||||
|
lexer->lookahead == '-' ||
|
||||||
|
lexer->lookahead == '&' ||
|
||||||
|
iswalnum(lexer->lookahead)
|
||||||
|
) {
|
||||||
|
return true;
|
||||||
|
}
|
||||||
|
|
||||||
|
if (lexer->lookahead == ':') {
|
||||||
|
lexer->advance(lexer, false);
|
||||||
|
if (iswspace(lexer->lookahead)) return false;
|
||||||
|
for (;;) {
|
||||||
|
if (
|
||||||
|
lexer->lookahead == ';' ||
|
||||||
|
lexer->lookahead == '}' ||
|
||||||
|
lexer->eof(lexer)
|
||||||
|
) return false;
|
||||||
|
if (lexer->lookahead == '{') {
|
||||||
|
return true;
|
||||||
|
}
|
||||||
|
lexer->advance(lexer, false);
|
||||||
|
}
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
return false;
|
||||||
|
}
|
||||||
@ -0,0 +1,223 @@
|
|||||||
|
#ifndef TREE_SITTER_PARSER_H_
|
||||||
|
#define TREE_SITTER_PARSER_H_
|
||||||
|
|
||||||
|
#ifdef __cplusplus
|
||||||
|
extern "C" {
|
||||||
|
#endif
|
||||||
|
|
||||||
|
#include <stdbool.h>
|
||||||
|
#include <stdint.h>
|
||||||
|
#include <stdlib.h>
|
||||||
|
|
||||||
|
#define ts_builtin_sym_error ((TSSymbol)-1)
|
||||||
|
#define ts_builtin_sym_end 0
|
||||||
|
#define TREE_SITTER_SERIALIZATION_BUFFER_SIZE 1024
|
||||||
|
|
||||||
|
typedef uint16_t TSStateId;
|
||||||
|
|
||||||
|
#ifndef TREE_SITTER_API_H_
|
||||||
|
typedef uint16_t TSSymbol;
|
||||||
|
typedef uint16_t TSFieldId;
|
||||||
|
typedef struct TSLanguage TSLanguage;
|
||||||
|
#endif
|
||||||
|
|
||||||
|
typedef struct {
|
||||||
|
TSFieldId field_id;
|
||||||
|
uint8_t child_index;
|
||||||
|
bool inherited;
|
||||||
|
} TSFieldMapEntry;
|
||||||
|
|
||||||
|
typedef struct {
|
||||||
|
uint16_t index;
|
||||||
|
uint16_t length;
|
||||||
|
} TSFieldMapSlice;
|
||||||
|
|
||||||
|
typedef struct {
|
||||||
|
bool visible;
|
||||||
|
bool named;
|
||||||
|
bool supertype;
|
||||||
|
} TSSymbolMetadata;
|
||||||
|
|
||||||
|
typedef struct TSLexer TSLexer;
|
||||||
|
|
||||||
|
struct TSLexer {
|
||||||
|
int32_t lookahead;
|
||||||
|
TSSymbol result_symbol;
|
||||||
|
void (*advance)(TSLexer *, bool);
|
||||||
|
void (*mark_end)(TSLexer *);
|
||||||
|
uint32_t (*get_column)(TSLexer *);
|
||||||
|
bool (*is_at_included_range_start)(const TSLexer *);
|
||||||
|
bool (*eof)(const TSLexer *);
|
||||||
|
};
|
||||||
|
|
||||||
|
typedef enum {
|
||||||
|
TSParseActionTypeShift,
|
||||||
|
TSParseActionTypeReduce,
|
||||||
|
TSParseActionTypeAccept,
|
||||||
|
TSParseActionTypeRecover,
|
||||||
|
} TSParseActionType;
|
||||||
|
|
||||||
|
typedef union {
|
||||||
|
struct {
|
||||||
|
uint8_t type;
|
||||||
|
TSStateId state;
|
||||||
|
bool extra;
|
||||||
|
bool repetition;
|
||||||
|
} shift;
|
||||||
|
struct {
|
||||||
|
uint8_t type;
|
||||||
|
uint8_t child_count;
|
||||||
|
TSSymbol symbol;
|
||||||
|
int16_t dynamic_precedence;
|
||||||
|
uint16_t production_id;
|
||||||
|
} reduce;
|
||||||
|
uint8_t type;
|
||||||
|
} TSParseAction;
|
||||||
|
|
||||||
|
typedef struct {
|
||||||
|
uint16_t lex_state;
|
||||||
|
uint16_t external_lex_state;
|
||||||
|
} TSLexMode;
|
||||||
|
|
||||||
|
typedef union {
|
||||||
|
TSParseAction action;
|
||||||
|
struct {
|
||||||
|
uint8_t count;
|
||||||
|
bool reusable;
|
||||||
|
} entry;
|
||||||
|
} TSParseActionEntry;
|
||||||
|
|
||||||
|
struct TSLanguage {
|
||||||
|
uint32_t version;
|
||||||
|
uint32_t symbol_count;
|
||||||
|
uint32_t alias_count;
|
||||||
|
uint32_t token_count;
|
||||||
|
uint32_t external_token_count;
|
||||||
|
uint32_t state_count;
|
||||||
|
uint32_t large_state_count;
|
||||||
|
uint32_t production_id_count;
|
||||||
|
uint32_t field_count;
|
||||||
|
uint16_t max_alias_sequence_length;
|
||||||
|
const uint16_t *parse_table;
|
||||||
|
const uint16_t *small_parse_table;
|
||||||
|
const uint32_t *small_parse_table_map;
|
||||||
|
const TSParseActionEntry *parse_actions;
|
||||||
|
const char **symbol_names;
|
||||||
|
const char **field_names;
|
||||||
|
const TSFieldMapSlice *field_map_slices;
|
||||||
|
const TSFieldMapEntry *field_map_entries;
|
||||||
|
const TSSymbolMetadata *symbol_metadata;
|
||||||
|
const TSSymbol *public_symbol_map;
|
||||||
|
const uint16_t *alias_map;
|
||||||
|
const TSSymbol *alias_sequences;
|
||||||
|
const TSLexMode *lex_modes;
|
||||||
|
bool (*lex_fn)(TSLexer *, TSStateId);
|
||||||
|
bool (*keyword_lex_fn)(TSLexer *, TSStateId);
|
||||||
|
TSSymbol keyword_capture_token;
|
||||||
|
struct {
|
||||||
|
const bool *states;
|
||||||
|
const TSSymbol *symbol_map;
|
||||||
|
void *(*create)(void);
|
||||||
|
void (*destroy)(void *);
|
||||||
|
bool (*scan)(void *, TSLexer *, const bool *symbol_whitelist);
|
||||||
|
unsigned (*serialize)(void *, char *);
|
||||||
|
void (*deserialize)(void *, const char *, unsigned);
|
||||||
|
} external_scanner;
|
||||||
|
};
|
||||||
|
|
||||||
|
/*
|
||||||
|
* Lexer Macros
|
||||||
|
*/
|
||||||
|
|
||||||
|
#define START_LEXER() \
|
||||||
|
bool result = false; \
|
||||||
|
bool skip = false; \
|
||||||
|
bool eof = false; \
|
||||||
|
int32_t lookahead; \
|
||||||
|
goto start; \
|
||||||
|
next_state: \
|
||||||
|
lexer->advance(lexer, skip); \
|
||||||
|
start: \
|
||||||
|
skip = false; \
|
||||||
|
lookahead = lexer->lookahead;
|
||||||
|
|
||||||
|
#define ADVANCE(state_value) \
|
||||||
|
{ \
|
||||||
|
state = state_value; \
|
||||||
|
goto next_state; \
|
||||||
|
}
|
||||||
|
|
||||||
|
#define SKIP(state_value) \
|
||||||
|
{ \
|
||||||
|
skip = true; \
|
||||||
|
state = state_value; \
|
||||||
|
goto next_state; \
|
||||||
|
}
|
||||||
|
|
||||||
|
#define ACCEPT_TOKEN(symbol_value) \
|
||||||
|
result = true; \
|
||||||
|
lexer->result_symbol = symbol_value; \
|
||||||
|
lexer->mark_end(lexer);
|
||||||
|
|
||||||
|
#define END_STATE() return result;
|
||||||
|
|
||||||
|
/*
|
||||||
|
* Parse Table Macros
|
||||||
|
*/
|
||||||
|
|
||||||
|
#define SMALL_STATE(id) id - LARGE_STATE_COUNT
|
||||||
|
|
||||||
|
#define STATE(id) id
|
||||||
|
|
||||||
|
#define ACTIONS(id) id
|
||||||
|
|
||||||
|
#define SHIFT(state_value) \
|
||||||
|
{{ \
|
||||||
|
.shift = { \
|
||||||
|
.type = TSParseActionTypeShift, \
|
||||||
|
.state = state_value \
|
||||||
|
} \
|
||||||
|
}}
|
||||||
|
|
||||||
|
#define SHIFT_REPEAT(state_value) \
|
||||||
|
{{ \
|
||||||
|
.shift = { \
|
||||||
|
.type = TSParseActionTypeShift, \
|
||||||
|
.state = state_value, \
|
||||||
|
.repetition = true \
|
||||||
|
} \
|
||||||
|
}}
|
||||||
|
|
||||||
|
#define SHIFT_EXTRA() \
|
||||||
|
{{ \
|
||||||
|
.shift = { \
|
||||||
|
.type = TSParseActionTypeShift, \
|
||||||
|
.extra = true \
|
||||||
|
} \
|
||||||
|
}}
|
||||||
|
|
||||||
|
#define REDUCE(symbol_val, child_count_val, ...) \
|
||||||
|
{{ \
|
||||||
|
.reduce = { \
|
||||||
|
.type = TSParseActionTypeReduce, \
|
||||||
|
.symbol = symbol_val, \
|
||||||
|
.child_count = child_count_val, \
|
||||||
|
__VA_ARGS__ \
|
||||||
|
}, \
|
||||||
|
}}
|
||||||
|
|
||||||
|
#define RECOVER() \
|
||||||
|
{{ \
|
||||||
|
.type = TSParseActionTypeRecover \
|
||||||
|
}}
|
||||||
|
|
||||||
|
#define ACCEPT_INPUT() \
|
||||||
|
{{ \
|
||||||
|
.type = TSParseActionTypeAccept \
|
||||||
|
}}
|
||||||
|
|
||||||
|
#ifdef __cplusplus
|
||||||
|
}
|
||||||
|
#endif
|
||||||
|
|
||||||
|
#endif // TREE_SITTER_PARSER_H_
|
||||||
@ -0,0 +1,13 @@
|
|||||||
|
# THIS IS AN AUTOGENERATED FILE. DO NOT EDIT THIS FILE DIRECTLY.
|
||||||
|
# yarn lockfile v1
|
||||||
|
|
||||||
|
|
||||||
|
"nan@^2.11.1":
|
||||||
|
"integrity" "sha512-isWHgVjnFjh2x2yuJ/tj3JbwoHu3UC2dX5G/88Cm24yB6YopVgxvBObDY7n5xW6ExmFhJpSEQqFPvq9zaXc8Jw=="
|
||||||
|
"resolved" "https://registry.npmjs.org/nan/-/nan-2.14.1.tgz"
|
||||||
|
"version" "2.14.1"
|
||||||
|
|
||||||
|
"tree-sitter-cli@^0.19.4":
|
||||||
|
"integrity" "sha512-p2kxjuoQeauXBu5eE+j7c5BMCRXmc17EiAswnnWn3ieUlHXBkA0Z7vRnaCSElDR34MhZnSgqgzuuzQk0cDqCjw=="
|
||||||
|
"resolved" "https://registry.npmjs.org/tree-sitter-cli/-/tree-sitter-cli-0.19.4.tgz"
|
||||||
|
"version" "0.19.4"
|
||||||
Loading…
Reference in New Issue