mirror of https://github.com/helix-editor/helix
Merge branch 'helix-editor:master' into master
commit
a6e25fb6f9
|
@ -151,9 +151,9 @@ checksum = "df8670b8c7b9dae1793364eafadf7239c40d669904660c5960d74cfd80b46a53"
|
||||||
|
|
||||||
[[package]]
|
[[package]]
|
||||||
name = "cc"
|
name = "cc"
|
||||||
version = "1.2.20"
|
version = "1.2.21"
|
||||||
source = "registry+https://github.com/rust-lang/crates.io-index"
|
source = "registry+https://github.com/rust-lang/crates.io-index"
|
||||||
checksum = "04da6a0d40b948dfc4fa8f5bbf402b0fc1a64a28dbf7d12ffd683550f2c1b63a"
|
checksum = "8691782945451c1c383942c4874dbe63814f61cb57ef773cda2972682b7bb3c0"
|
||||||
dependencies = [
|
dependencies = [
|
||||||
"shlex",
|
"shlex",
|
||||||
]
|
]
|
||||||
|
@ -177,9 +177,9 @@ dependencies = [
|
||||||
|
|
||||||
[[package]]
|
[[package]]
|
||||||
name = "chrono"
|
name = "chrono"
|
||||||
version = "0.4.40"
|
version = "0.4.41"
|
||||||
source = "registry+https://github.com/rust-lang/crates.io-index"
|
source = "registry+https://github.com/rust-lang/crates.io-index"
|
||||||
checksum = "1a7964611d71df112cb1730f2ee67324fcf4d0fc6606acbbe9bfe06df124637c"
|
checksum = "c469d952047f47f91b68d1cba3f10d63c11d73e4636f24f08daf0278abf01c4d"
|
||||||
dependencies = [
|
dependencies = [
|
||||||
"android-tzdata",
|
"android-tzdata",
|
||||||
"iana-time-zone",
|
"iana-time-zone",
|
||||||
|
@ -913,7 +913,7 @@ dependencies = [
|
||||||
"itoa",
|
"itoa",
|
||||||
"libc",
|
"libc",
|
||||||
"memmap2",
|
"memmap2",
|
||||||
"rustix 1.0.5",
|
"rustix 1.0.7",
|
||||||
"smallvec",
|
"smallvec",
|
||||||
"thiserror 2.0.12",
|
"thiserror 2.0.12",
|
||||||
]
|
]
|
||||||
|
@ -1530,7 +1530,7 @@ dependencies = [
|
||||||
"regex-automata",
|
"regex-automata",
|
||||||
"regex-cursor",
|
"regex-cursor",
|
||||||
"ropey",
|
"ropey",
|
||||||
"rustix 1.0.5",
|
"rustix 1.0.7",
|
||||||
"tempfile",
|
"tempfile",
|
||||||
"unicode-segmentation",
|
"unicode-segmentation",
|
||||||
"which",
|
"which",
|
||||||
|
@ -1637,7 +1637,7 @@ dependencies = [
|
||||||
"log",
|
"log",
|
||||||
"once_cell",
|
"once_cell",
|
||||||
"parking_lot",
|
"parking_lot",
|
||||||
"rustix 1.0.5",
|
"rustix 1.0.7",
|
||||||
"serde",
|
"serde",
|
||||||
"serde_json",
|
"serde_json",
|
||||||
"slotmap",
|
"slotmap",
|
||||||
|
@ -2374,9 +2374,9 @@ dependencies = [
|
||||||
|
|
||||||
[[package]]
|
[[package]]
|
||||||
name = "rustix"
|
name = "rustix"
|
||||||
version = "1.0.5"
|
version = "1.0.7"
|
||||||
source = "registry+https://github.com/rust-lang/crates.io-index"
|
source = "registry+https://github.com/rust-lang/crates.io-index"
|
||||||
checksum = "d97817398dd4bb2e6da002002db259209759911da105da92bec29ccb12cf58bf"
|
checksum = "c71e83d6afe7ff64890ec6b71d6a69bb8a610ab78ce364b3352876bb4c801266"
|
||||||
dependencies = [
|
dependencies = [
|
||||||
"bitflags",
|
"bitflags",
|
||||||
"errno",
|
"errno",
|
||||||
|
@ -2622,7 +2622,7 @@ dependencies = [
|
||||||
"fastrand",
|
"fastrand",
|
||||||
"getrandom 0.3.1",
|
"getrandom 0.3.1",
|
||||||
"once_cell",
|
"once_cell",
|
||||||
"rustix 1.0.5",
|
"rustix 1.0.7",
|
||||||
"windows-sys 0.59.0",
|
"windows-sys 0.59.0",
|
||||||
]
|
]
|
||||||
|
|
||||||
|
@ -2995,7 +2995,7 @@ checksum = "24d643ce3fd3e5b54854602a080f34fb10ab75e0b813ee32d00ca2b44fa74762"
|
||||||
dependencies = [
|
dependencies = [
|
||||||
"either",
|
"either",
|
||||||
"env_home",
|
"env_home",
|
||||||
"rustix 1.0.5",
|
"rustix 1.0.7",
|
||||||
"winsafe",
|
"winsafe",
|
||||||
]
|
]
|
||||||
|
|
||||||
|
|
|
@ -47,6 +47,8 @@ The following variables are supported:
|
||||||
| `cursor_column` | The column number of the primary cursor in the currently focused document, starting at 1. This is counted as the number of grapheme clusters from the start of the line rather than bytes or codepoints. |
|
| `cursor_column` | The column number of the primary cursor in the currently focused document, starting at 1. This is counted as the number of grapheme clusters from the start of the line rather than bytes or codepoints. |
|
||||||
| `buffer_name` | The relative path of the currently focused document. `[scratch]` is expanded instead for scratch buffers. |
|
| `buffer_name` | The relative path of the currently focused document. `[scratch]` is expanded instead for scratch buffers. |
|
||||||
| `line_ending` | A string containing the line ending of the currently focused document. For example on Unix systems this is usually a line-feed character (`\n`) but on Windows systems this may be a carriage-return plus a line-feed (`\r\n`). The line ending kind of the currently focused document can be inspected with the `:line-ending` command. |
|
| `line_ending` | A string containing the line ending of the currently focused document. For example on Unix systems this is usually a line-feed character (`\n`) but on Windows systems this may be a carriage-return plus a line-feed (`\r\n`). The line ending kind of the currently focused document can be inspected with the `:line-ending` command. |
|
||||||
|
| `language` | A string containing the language name of the currently focused document.|
|
||||||
|
| `selection` | A string containing the contents of the primary selection of the currently focused document. |
|
||||||
|
|
||||||
Aside from editor variables, the following expansions may be used:
|
Aside from editor variables, the following expansions may be used:
|
||||||
|
|
||||||
|
|
|
@ -46,6 +46,7 @@
|
||||||
| dot | ✓ | | | `dot-language-server` |
|
| dot | ✓ | | | `dot-language-server` |
|
||||||
| dtd | ✓ | | | |
|
| dtd | ✓ | | | |
|
||||||
| dune | ✓ | | | |
|
| dune | ✓ | | | |
|
||||||
|
| dunstrc | ✓ | | | |
|
||||||
| earthfile | ✓ | ✓ | ✓ | `earthlyls` |
|
| earthfile | ✓ | ✓ | ✓ | `earthlyls` |
|
||||||
| edoc | ✓ | | | |
|
| edoc | ✓ | | | |
|
||||||
| eex | ✓ | | | |
|
| eex | ✓ | | | |
|
||||||
|
@ -180,6 +181,7 @@
|
||||||
| prolog | ✓ | | ✓ | `swipl` |
|
| prolog | ✓ | | ✓ | `swipl` |
|
||||||
| protobuf | ✓ | ✓ | ✓ | `buf`, `pb`, `protols` |
|
| protobuf | ✓ | ✓ | ✓ | `buf`, `pb`, `protols` |
|
||||||
| prql | ✓ | | | |
|
| prql | ✓ | | | |
|
||||||
|
| pug | ✓ | | | |
|
||||||
| purescript | ✓ | ✓ | | `purescript-language-server` |
|
| purescript | ✓ | ✓ | | `purescript-language-server` |
|
||||||
| python | ✓ | ✓ | ✓ | `ruff`, `jedi-language-server`, `pylsp` |
|
| python | ✓ | ✓ | ✓ | `ruff`, `jedi-language-server`, `pylsp` |
|
||||||
| qml | ✓ | | ✓ | `qmlls` |
|
| qml | ✓ | | ✓ | `qmlls` |
|
||||||
|
@ -200,6 +202,7 @@
|
||||||
| scala | ✓ | ✓ | ✓ | `metals` |
|
| scala | ✓ | ✓ | ✓ | `metals` |
|
||||||
| scheme | ✓ | | ✓ | |
|
| scheme | ✓ | | ✓ | |
|
||||||
| scss | ✓ | | | `vscode-css-language-server` |
|
| scss | ✓ | | | `vscode-css-language-server` |
|
||||||
|
| slang | ✓ | ✓ | ✓ | `slangd` |
|
||||||
| slint | ✓ | ✓ | ✓ | `slint-lsp` |
|
| slint | ✓ | ✓ | ✓ | `slint-lsp` |
|
||||||
| smali | ✓ | | ✓ | |
|
| smali | ✓ | | ✓ | |
|
||||||
| smithy | ✓ | | | `cs` |
|
| smithy | ✓ | | | `cs` |
|
||||||
|
|
|
@ -153,6 +153,8 @@
|
||||||
| `goto_last_change` | Goto last change | normal: `` ]G ``, select: `` ]G `` |
|
| `goto_last_change` | Goto last change | normal: `` ]G ``, select: `` ]G `` |
|
||||||
| `goto_line_start` | Goto line start | normal: `` gh ``, `` <home> ``, select: `` gh ``, insert: `` <home> `` |
|
| `goto_line_start` | Goto line start | normal: `` gh ``, `` <home> ``, select: `` gh ``, insert: `` <home> `` |
|
||||||
| `goto_line_end` | Goto line end | normal: `` gl ``, `` <end> ``, select: `` gl `` |
|
| `goto_line_end` | Goto line end | normal: `` gl ``, `` <end> ``, select: `` gl `` |
|
||||||
|
| `goto_column` | Goto column | normal: `` g\| `` |
|
||||||
|
| `extend_to_column` | Extend to column | select: `` g\| `` |
|
||||||
| `goto_next_buffer` | Goto next buffer | normal: `` gn ``, select: `` gn `` |
|
| `goto_next_buffer` | Goto next buffer | normal: `` gn ``, select: `` gn `` |
|
||||||
| `goto_previous_buffer` | Goto previous buffer | normal: `` gp ``, select: `` gp `` |
|
| `goto_previous_buffer` | Goto previous buffer | normal: `` gp ``, select: `` gp `` |
|
||||||
| `goto_line_end_newline` | Goto newline at line end | insert: `` <end> `` |
|
| `goto_line_end_newline` | Goto newline at line end | insert: `` <end> `` |
|
||||||
|
|
|
@ -23,6 +23,7 @@ The following [captures][tree-sitter-captures] are recognized:
|
||||||
| `test.inside` |
|
| `test.inside` |
|
||||||
| `test.around` |
|
| `test.around` |
|
||||||
| `parameter.inside` |
|
| `parameter.inside` |
|
||||||
|
| `parameter.around` |
|
||||||
| `comment.inside` |
|
| `comment.inside` |
|
||||||
| `comment.around` |
|
| `comment.around` |
|
||||||
| `entry.inside` |
|
| `entry.inside` |
|
||||||
|
|
|
@ -213,6 +213,7 @@ Jumps to various locations.
|
||||||
| Key | Description | Command |
|
| Key | Description | Command |
|
||||||
| ----- | ----------- | ------- |
|
| ----- | ----------- | ------- |
|
||||||
| `g` | Go to line number `<n>` else start of file | `goto_file_start` |
|
| `g` | Go to line number `<n>` else start of file | `goto_file_start` |
|
||||||
|
| <code>|</code> | Go to column number `<n>` else start of line | `goto_column` |
|
||||||
| `e` | Go to the end of the file | `goto_last_line` |
|
| `e` | Go to the end of the file | `goto_last_line` |
|
||||||
| `f` | Go to files in the selections | `goto_file` |
|
| `f` | Go to files in the selections | `goto_file` |
|
||||||
| `h` | Go to the start of the line | `goto_line_start` |
|
| `h` | Go to the start of the line | `goto_line_start` |
|
||||||
|
|
|
@ -451,7 +451,6 @@ fn build_tree_sitter_library(
|
||||||
command
|
command
|
||||||
.args(["/nologo", "/LD", "/I"])
|
.args(["/nologo", "/LD", "/I"])
|
||||||
.arg(header_path)
|
.arg(header_path)
|
||||||
.arg("/Od")
|
|
||||||
.arg("/utf-8")
|
.arg("/utf-8")
|
||||||
.arg("/std:c11");
|
.arg("/std:c11");
|
||||||
if let Some(scanner_path) = scanner_path.as_ref() {
|
if let Some(scanner_path) = scanner_path.as_ref() {
|
||||||
|
@ -469,7 +468,6 @@ fn build_tree_sitter_library(
|
||||||
cpp_command
|
cpp_command
|
||||||
.args(["/nologo", "/LD", "/I"])
|
.args(["/nologo", "/LD", "/I"])
|
||||||
.arg(header_path)
|
.arg(header_path)
|
||||||
.arg("/Od")
|
|
||||||
.arg("/utf-8")
|
.arg("/utf-8")
|
||||||
.arg("/std:c++14")
|
.arg("/std:c++14")
|
||||||
.arg(format!("/Fo{}", object_file.display()))
|
.arg(format!("/Fo{}", object_file.display()))
|
||||||
|
|
|
@ -451,6 +451,8 @@ impl MappableCommand {
|
||||||
goto_last_change, "Goto last change",
|
goto_last_change, "Goto last change",
|
||||||
goto_line_start, "Goto line start",
|
goto_line_start, "Goto line start",
|
||||||
goto_line_end, "Goto line end",
|
goto_line_end, "Goto line end",
|
||||||
|
goto_column, "Goto column",
|
||||||
|
extend_to_column, "Extend to column",
|
||||||
goto_next_buffer, "Goto next buffer",
|
goto_next_buffer, "Goto next buffer",
|
||||||
goto_previous_buffer, "Goto previous buffer",
|
goto_previous_buffer, "Goto previous buffer",
|
||||||
goto_line_end_newline, "Goto newline at line end",
|
goto_line_end_newline, "Goto newline at line end",
|
||||||
|
@ -3839,6 +3841,28 @@ fn goto_last_line_impl(cx: &mut Context, movement: Movement) {
|
||||||
doc.set_selection(view.id, selection);
|
doc.set_selection(view.id, selection);
|
||||||
}
|
}
|
||||||
|
|
||||||
|
fn goto_column(cx: &mut Context) {
|
||||||
|
goto_column_impl(cx, Movement::Move);
|
||||||
|
}
|
||||||
|
|
||||||
|
fn extend_to_column(cx: &mut Context) {
|
||||||
|
goto_column_impl(cx, Movement::Extend);
|
||||||
|
}
|
||||||
|
|
||||||
|
fn goto_column_impl(cx: &mut Context, movement: Movement) {
|
||||||
|
let count = cx.count();
|
||||||
|
let (view, doc) = current!(cx.editor);
|
||||||
|
let text = doc.text().slice(..);
|
||||||
|
let selection = doc.selection(view.id).clone().transform(|range| {
|
||||||
|
let line = range.cursor_line(text);
|
||||||
|
let line_start = text.line_to_char(line);
|
||||||
|
let line_end = line_end_char_index(&text, line);
|
||||||
|
let pos = graphemes::nth_next_grapheme_boundary(text, line_start, count - 1).min(line_end);
|
||||||
|
range.put_cursor(text, pos, movement == Movement::Extend)
|
||||||
|
});
|
||||||
|
doc.set_selection(view.id, selection);
|
||||||
|
}
|
||||||
|
|
||||||
fn goto_last_accessed_file(cx: &mut Context) {
|
fn goto_last_accessed_file(cx: &mut Context) {
|
||||||
let view = view_mut!(cx.editor);
|
let view = view_mut!(cx.editor);
|
||||||
if let Some(alt) = view.docs_access_history.pop() {
|
if let Some(alt) = view.docs_access_history.pop() {
|
||||||
|
|
|
@ -38,6 +38,7 @@ pub fn default() -> HashMap<Mode, KeyTrie> {
|
||||||
"G" => goto_line,
|
"G" => goto_line,
|
||||||
"g" => { "Goto"
|
"g" => { "Goto"
|
||||||
"g" => goto_file_start,
|
"g" => goto_file_start,
|
||||||
|
"|" => goto_column,
|
||||||
"e" => goto_last_line,
|
"e" => goto_last_line,
|
||||||
"f" => goto_file,
|
"f" => goto_file,
|
||||||
"h" => goto_line_start,
|
"h" => goto_line_start,
|
||||||
|
@ -368,6 +369,7 @@ pub fn default() -> HashMap<Mode, KeyTrie> {
|
||||||
"v" => normal_mode,
|
"v" => normal_mode,
|
||||||
"g" => { "Goto"
|
"g" => { "Goto"
|
||||||
"g" => extend_to_file_start,
|
"g" => extend_to_file_start,
|
||||||
|
"|" => extend_to_column,
|
||||||
"e" => extend_to_last_line,
|
"e" => extend_to_last_line,
|
||||||
"k" => extend_line_up,
|
"k" => extend_line_up,
|
||||||
"j" => extend_line_down,
|
"j" => extend_line_down,
|
||||||
|
|
|
@ -33,6 +33,10 @@ pub enum Variable {
|
||||||
BufferName,
|
BufferName,
|
||||||
/// A string containing the line-ending of the currently focused document.
|
/// A string containing the line-ending of the currently focused document.
|
||||||
LineEnding,
|
LineEnding,
|
||||||
|
// The name of current buffers language as set in `languages.toml`
|
||||||
|
Language,
|
||||||
|
// Primary selection
|
||||||
|
Selection,
|
||||||
}
|
}
|
||||||
|
|
||||||
impl Variable {
|
impl Variable {
|
||||||
|
@ -41,6 +45,8 @@ impl Variable {
|
||||||
Self::CursorColumn,
|
Self::CursorColumn,
|
||||||
Self::BufferName,
|
Self::BufferName,
|
||||||
Self::LineEnding,
|
Self::LineEnding,
|
||||||
|
Self::Language,
|
||||||
|
Self::Selection,
|
||||||
];
|
];
|
||||||
|
|
||||||
pub const fn as_str(&self) -> &'static str {
|
pub const fn as_str(&self) -> &'static str {
|
||||||
|
@ -49,6 +55,8 @@ impl Variable {
|
||||||
Self::CursorColumn => "cursor_column",
|
Self::CursorColumn => "cursor_column",
|
||||||
Self::BufferName => "buffer_name",
|
Self::BufferName => "buffer_name",
|
||||||
Self::LineEnding => "line_ending",
|
Self::LineEnding => "line_ending",
|
||||||
|
Self::Language => "language",
|
||||||
|
Self::Selection => "selection",
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@ -58,6 +66,8 @@ impl Variable {
|
||||||
"cursor_column" => Some(Self::CursorColumn),
|
"cursor_column" => Some(Self::CursorColumn),
|
||||||
"buffer_name" => Some(Self::BufferName),
|
"buffer_name" => Some(Self::BufferName),
|
||||||
"line_ending" => Some(Self::LineEnding),
|
"line_ending" => Some(Self::LineEnding),
|
||||||
|
"language" => Some(Self::Language),
|
||||||
|
"selection" => Some(Self::Selection),
|
||||||
_ => None,
|
_ => None,
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
@ -215,5 +225,12 @@ fn expand_variable(editor: &Editor, variable: Variable) -> Result<Cow<'static, s
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
Variable::LineEnding => Ok(Cow::Borrowed(doc.line_ending.as_str())),
|
Variable::LineEnding => Ok(Cow::Borrowed(doc.line_ending.as_str())),
|
||||||
|
Variable::Language => Ok(match doc.language_name() {
|
||||||
|
Some(lang) => Cow::Owned(lang.to_owned()),
|
||||||
|
None => Cow::Borrowed("text"),
|
||||||
|
}),
|
||||||
|
Variable::Selection => Ok(Cow::Owned(
|
||||||
|
doc.selection(view.id).primary().fragment(text).to_string(),
|
||||||
|
)),
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
|
@ -104,6 +104,7 @@ robotframework_ls = { command = "robotframework_ls" }
|
||||||
ruff = { command = "ruff", args = ["server"] }
|
ruff = { command = "ruff", args = ["server"] }
|
||||||
ruby-lsp = { command = "ruby-lsp" }
|
ruby-lsp = { command = "ruby-lsp" }
|
||||||
serve-d = { command = "serve-d" }
|
serve-d = { command = "serve-d" }
|
||||||
|
slangd = { command = "slangd" }
|
||||||
slint-lsp = { command = "slint-lsp", args = [] }
|
slint-lsp = { command = "slint-lsp", args = [] }
|
||||||
solargraph = { command = "solargraph", args = ["stdio"] }
|
solargraph = { command = "solargraph", args = ["stdio"] }
|
||||||
solc = { command = "solc", args = ["--lsp"] }
|
solc = { command = "solc", args = ["--lsp"] }
|
||||||
|
@ -1899,7 +1900,7 @@ source = { git = "https://github.com/mtoohey31/tree-sitter-gitattributes", rev =
|
||||||
[[language]]
|
[[language]]
|
||||||
name = "git-ignore"
|
name = "git-ignore"
|
||||||
scope = "source.gitignore"
|
scope = "source.gitignore"
|
||||||
file-types = [{ glob = ".gitignore_global" }, { glob = "git/ignore" }, { glob = ".ignore" }, { glob = "CODEOWNERS" }, { glob = ".config/helix/ignore" }, { glob = ".helix/ignore" }, { glob = ".*ignore" }]
|
file-types = [{ glob = ".gitignore_global" }, { glob = "git/ignore" }, { glob = ".ignore" }, { glob = "CODEOWNERS" }, { glob = ".config/helix/ignore" }, { glob = ".helix/ignore" }, { glob = ".*ignore" }, { glob = ".git-blame-ignore-revs" }]
|
||||||
injection-regex = "git-ignore"
|
injection-regex = "git-ignore"
|
||||||
comment-token = "#"
|
comment-token = "#"
|
||||||
grammar = "gitignore"
|
grammar = "gitignore"
|
||||||
|
@ -2577,6 +2578,20 @@ formatter = { command = "cue", args = ["fmt", "-"] }
|
||||||
name = "cue"
|
name = "cue"
|
||||||
source = { git = "https://github.com/eonpatapon/tree-sitter-cue", rev = "8a5f273bfa281c66354da562f2307c2d394b6c81" }
|
source = { git = "https://github.com/eonpatapon/tree-sitter-cue", rev = "8a5f273bfa281c66354da562f2307c2d394b6c81" }
|
||||||
|
|
||||||
|
[[language]]
|
||||||
|
name = "slang"
|
||||||
|
scope = "source.lang"
|
||||||
|
injection-regex = "slang"
|
||||||
|
file-types = ["slang"]
|
||||||
|
comment-token = "//"
|
||||||
|
block-comment-tokens = { start = "/*", end = "*/" }
|
||||||
|
language-servers = [ "slangd" ]
|
||||||
|
indent = { tab-width = 4, unit = " " }
|
||||||
|
|
||||||
|
[[grammar]]
|
||||||
|
name = "slang"
|
||||||
|
source = { git = "https://github.com/tree-sitter-grammars/tree-sitter-slang", rev = "327b1b821c255867a4fb724c8eee48887e3d014b" }
|
||||||
|
|
||||||
[[language]]
|
[[language]]
|
||||||
name = "slint"
|
name = "slint"
|
||||||
scope = "source.slint"
|
scope = "source.slint"
|
||||||
|
@ -4313,3 +4328,24 @@ comment-tokens = "#"
|
||||||
[[grammar]]
|
[[grammar]]
|
||||||
name = "debian"
|
name = "debian"
|
||||||
source = { git = "https://gitlab.com/MggMuggins/tree-sitter-debian", rev = "9b3f4b78c45aab8a2f25a5f9e7bbc00995bc3dde" }
|
source = { git = "https://gitlab.com/MggMuggins/tree-sitter-debian", rev = "9b3f4b78c45aab8a2f25a5f9e7bbc00995bc3dde" }
|
||||||
|
|
||||||
|
[[language]]
|
||||||
|
name = "pug"
|
||||||
|
scope = "source.pug"
|
||||||
|
file-types = ["pug"]
|
||||||
|
comment-tokens = ["//", "//-"]
|
||||||
|
indent = { tab-width = 2, unit = " " }
|
||||||
|
|
||||||
|
[[grammar]]
|
||||||
|
name = "pug"
|
||||||
|
source = { git = "https://github.com/zealot128/tree-sitter-pug", rev = "13e9195370172c86a8b88184cc358b23b677cc46" }
|
||||||
|
|
||||||
|
[[language]]
|
||||||
|
name = "dunstrc"
|
||||||
|
scope = "source.dunstrc"
|
||||||
|
comment-tokens = ["#", ";"]
|
||||||
|
file-types = [ { glob = "dunst/dunstrc" } ]
|
||||||
|
|
||||||
|
[[grammar]]
|
||||||
|
name = "dunstrc"
|
||||||
|
source = { git = "https://github.com/rotmh/tree-sitter-dunstrc", rev = "9cb9d5cc51cf5e2a47bb2a0e2f2e519ff11c1431" }
|
||||||
|
|
|
@ -0,0 +1,14 @@
|
||||||
|
(assign
|
||||||
|
(key) @attribute)
|
||||||
|
|
||||||
|
(comment) @comment.line
|
||||||
|
|
||||||
|
[
|
||||||
|
"["
|
||||||
|
"]"
|
||||||
|
] @punctuation.bracket
|
||||||
|
|
||||||
|
"=" @operator
|
||||||
|
|
||||||
|
(section
|
||||||
|
(name) @namespace)
|
|
@ -1,5 +1,5 @@
|
||||||
; Comments
|
; Comments
|
||||||
(tripledot) @comment.discard
|
(tripledot) @comment.unused
|
||||||
|
|
||||||
[(comment) (line_comment) (shebang)] @comment
|
[(comment) (line_comment) (shebang)] @comment
|
||||||
|
|
||||||
|
@ -114,10 +114,6 @@
|
||||||
] @comment.block.documentation)
|
] @comment.block.documentation)
|
||||||
(#any-of? @keyword "doc" "moduledoc"))
|
(#any-of? @keyword "doc" "moduledoc"))
|
||||||
|
|
||||||
; Ignored variables
|
|
||||||
((variable) @comment.discard
|
|
||||||
(#match? @comment.discard "^_"))
|
|
||||||
|
|
||||||
; Macros
|
; Macros
|
||||||
(macro
|
(macro
|
||||||
"?"+ @keyword.directive
|
"?"+ @keyword.directive
|
||||||
|
@ -163,3 +159,7 @@
|
||||||
|
|
||||||
(record field: (atom) @variable.other.member)
|
(record field: (atom) @variable.other.member)
|
||||||
(record name: (atom) @type)
|
(record name: (atom) @type)
|
||||||
|
|
||||||
|
; Ignored variables
|
||||||
|
((variable) @comment.unused
|
||||||
|
(#match? @comment.unused "^_"))
|
||||||
|
|
|
@ -0,0 +1,97 @@
|
||||||
|
(comment) @comment
|
||||||
|
|
||||||
|
(
|
||||||
|
doctype
|
||||||
|
(("doctype") @keyword.storage.type)
|
||||||
|
((doctype_name) @type.enum.variant)
|
||||||
|
)
|
||||||
|
|
||||||
|
(tag_name) @constant
|
||||||
|
|
||||||
|
; Attributes
|
||||||
|
(id) @attribute
|
||||||
|
(class) @attribute
|
||||||
|
(attribute_name) @attribute
|
||||||
|
|
||||||
|
(quoted_attribute_value) @string
|
||||||
|
|
||||||
|
; Controls
|
||||||
|
(
|
||||||
|
conditional
|
||||||
|
((keyword) @keyword.control.conditional)
|
||||||
|
)
|
||||||
|
(
|
||||||
|
case
|
||||||
|
((keyword) @keyword.control)
|
||||||
|
(
|
||||||
|
when
|
||||||
|
((keyword) @keyword.control)
|
||||||
|
)
|
||||||
|
)
|
||||||
|
(
|
||||||
|
each
|
||||||
|
((keyword) @keyword.control.repeat)
|
||||||
|
)
|
||||||
|
(
|
||||||
|
else
|
||||||
|
((keyword) @keyword.control.conditional)
|
||||||
|
)
|
||||||
|
(
|
||||||
|
while
|
||||||
|
((keyword) @keyword.control.repeat)
|
||||||
|
)
|
||||||
|
|
||||||
|
; Mixins
|
||||||
|
(
|
||||||
|
mixin_definition
|
||||||
|
((keyword) @keyword.function)
|
||||||
|
((mixin_name) @function.method)
|
||||||
|
)
|
||||||
|
(
|
||||||
|
mixin_use
|
||||||
|
(("+") @operator)
|
||||||
|
((mixin_name) @function.method)
|
||||||
|
)
|
||||||
|
|
||||||
|
; Includes
|
||||||
|
(
|
||||||
|
include
|
||||||
|
((keyword) @keyword.directive)
|
||||||
|
((filename) @string.special.path)
|
||||||
|
)
|
||||||
|
|
||||||
|
; Inheritance
|
||||||
|
(
|
||||||
|
extends
|
||||||
|
((keyword) @keyword.directive)
|
||||||
|
((filename) @string.special.path)
|
||||||
|
)
|
||||||
|
(
|
||||||
|
block_definition
|
||||||
|
((keyword) @keyword.directive)
|
||||||
|
((block_name) @function.method)
|
||||||
|
)
|
||||||
|
(
|
||||||
|
block_append
|
||||||
|
((keyword) @keyword.directive)
|
||||||
|
((block_name) @function.method)
|
||||||
|
)
|
||||||
|
(
|
||||||
|
block_prepend
|
||||||
|
((keyword) @keyword.directive)
|
||||||
|
((block_name) @function.method)
|
||||||
|
)
|
||||||
|
|
||||||
|
; Filters
|
||||||
|
(
|
||||||
|
filter
|
||||||
|
(":" @function.macro)
|
||||||
|
((filter_name) @function.macro)
|
||||||
|
((content) @special)
|
||||||
|
)
|
||||||
|
|
||||||
|
; Inline JavaScript
|
||||||
|
(
|
||||||
|
unbuffered_code
|
||||||
|
(("-") @special)
|
||||||
|
)
|
|
@ -0,0 +1,3 @@
|
||||||
|
((javascript) @injection.content
|
||||||
|
(#set! injection.language "javascript")
|
||||||
|
)
|
|
@ -0,0 +1,371 @@
|
||||||
|
; inherits: c
|
||||||
|
|
||||||
|
; cpp
|
||||||
|
((identifier) @variable.other.member
|
||||||
|
(#match? @variable.other.member "^m_.*$"))
|
||||||
|
|
||||||
|
(parameter_declaration
|
||||||
|
declarator: (reference_declarator) @variable.parameter)
|
||||||
|
|
||||||
|
; function(Foo ...foo)
|
||||||
|
(variadic_parameter_declaration
|
||||||
|
declarator: (variadic_declarator
|
||||||
|
(_) @variable.parameter))
|
||||||
|
|
||||||
|
; int foo = 0
|
||||||
|
(optional_parameter_declaration
|
||||||
|
declarator: (_) @variable.parameter)
|
||||||
|
|
||||||
|
(field_declaration
|
||||||
|
(field_identifier) @variable.other.member)
|
||||||
|
|
||||||
|
(field_initializer
|
||||||
|
(field_identifier) @variable.other.member)
|
||||||
|
|
||||||
|
(function_declarator
|
||||||
|
declarator: (field_identifier) @function.method)
|
||||||
|
|
||||||
|
(concept_definition
|
||||||
|
name: (identifier) @type)
|
||||||
|
|
||||||
|
(alias_declaration
|
||||||
|
name: (type_identifier) @type)
|
||||||
|
|
||||||
|
(namespace_identifier) @namespace
|
||||||
|
|
||||||
|
((namespace_identifier) @type
|
||||||
|
(#match? @type "^[%u]"))
|
||||||
|
|
||||||
|
(case_statement
|
||||||
|
value: (qualified_identifier
|
||||||
|
(identifier) @constant))
|
||||||
|
|
||||||
|
(using_declaration
|
||||||
|
.
|
||||||
|
"using"
|
||||||
|
.
|
||||||
|
"namespace"
|
||||||
|
.
|
||||||
|
[
|
||||||
|
(qualified_identifier)
|
||||||
|
(identifier)
|
||||||
|
] @namespace)
|
||||||
|
|
||||||
|
(destructor_name
|
||||||
|
(identifier) @function.method)
|
||||||
|
|
||||||
|
; functions
|
||||||
|
(function_declarator
|
||||||
|
(qualified_identifier
|
||||||
|
(identifier) @function))
|
||||||
|
|
||||||
|
(function_declarator
|
||||||
|
(qualified_identifier
|
||||||
|
(qualified_identifier
|
||||||
|
(identifier) @function)))
|
||||||
|
|
||||||
|
(function_declarator
|
||||||
|
(qualified_identifier
|
||||||
|
(qualified_identifier
|
||||||
|
(qualified_identifier
|
||||||
|
(identifier) @function))))
|
||||||
|
|
||||||
|
(function_declarator
|
||||||
|
(template_function
|
||||||
|
(identifier) @function))
|
||||||
|
|
||||||
|
(operator_name) @function
|
||||||
|
|
||||||
|
"operator" @function
|
||||||
|
|
||||||
|
"static_assert" @function.builtin
|
||||||
|
|
||||||
|
|
||||||
|
(call_expression
|
||||||
|
(qualified_identifier
|
||||||
|
(identifier) @function))
|
||||||
|
|
||||||
|
|
||||||
|
(call_expression
|
||||||
|
(qualified_identifier
|
||||||
|
(qualified_identifier
|
||||||
|
(identifier) @function)))
|
||||||
|
|
||||||
|
(call_expression
|
||||||
|
(qualified_identifier
|
||||||
|
(qualified_identifier
|
||||||
|
(qualified_identifier
|
||||||
|
(identifier) @function))))
|
||||||
|
|
||||||
|
(call_expression
|
||||||
|
(template_function
|
||||||
|
(identifier) @function))
|
||||||
|
|
||||||
|
(call_expression
|
||||||
|
(qualified_identifier
|
||||||
|
(template_function
|
||||||
|
(identifier) @function)))
|
||||||
|
|
||||||
|
(call_expression
|
||||||
|
(qualified_identifier
|
||||||
|
(qualified_identifier
|
||||||
|
(template_function
|
||||||
|
(identifier) @function))))
|
||||||
|
|
||||||
|
(call_expression
|
||||||
|
(qualified_identifier
|
||||||
|
(qualified_identifier
|
||||||
|
(qualified_identifier
|
||||||
|
(template_function
|
||||||
|
(identifier) @function)))))
|
||||||
|
|
||||||
|
; methods
|
||||||
|
(function_declarator
|
||||||
|
(template_method
|
||||||
|
(field_identifier) @function.method))
|
||||||
|
|
||||||
|
(call_expression
|
||||||
|
(field_expression
|
||||||
|
(field_identifier) @function.method))
|
||||||
|
|
||||||
|
; constructors
|
||||||
|
((function_declarator
|
||||||
|
(qualified_identifier
|
||||||
|
(identifier) @constructor))
|
||||||
|
(#match? @constructor "^%u"))
|
||||||
|
|
||||||
|
((call_expression
|
||||||
|
function: (identifier) @constructor)
|
||||||
|
(#match? @constructor "^%u"))
|
||||||
|
|
||||||
|
((call_expression
|
||||||
|
function: (qualified_identifier
|
||||||
|
name: (identifier) @constructor))
|
||||||
|
(#match? @constructor "^%u"))
|
||||||
|
|
||||||
|
((call_expression
|
||||||
|
function: (field_expression
|
||||||
|
field: (field_identifier) @constructor))
|
||||||
|
(#match? @constructor "^%u"))
|
||||||
|
|
||||||
|
; constructing a type in an initializer list: Constructor (): **SuperType (1)**
|
||||||
|
((field_initializer
|
||||||
|
(field_identifier) @constructor
|
||||||
|
(argument_list))
|
||||||
|
(#match? @constructor "^%u"))
|
||||||
|
|
||||||
|
; Constants
|
||||||
|
(this) @variable.builtin
|
||||||
|
|
||||||
|
(null
|
||||||
|
"nullptr" @constant.builtin)
|
||||||
|
|
||||||
|
(true) @constant.builtin.boolean
|
||||||
|
|
||||||
|
(false) @constant.builtin.boolean
|
||||||
|
|
||||||
|
; Literals
|
||||||
|
(raw_string_literal) @string
|
||||||
|
|
||||||
|
; Keywords
|
||||||
|
[
|
||||||
|
"try"
|
||||||
|
"catch"
|
||||||
|
"noexcept"
|
||||||
|
"throw"
|
||||||
|
] @keyword.control.exception
|
||||||
|
|
||||||
|
[
|
||||||
|
"decltype"
|
||||||
|
"explicit"
|
||||||
|
"friend"
|
||||||
|
"override"
|
||||||
|
"using"
|
||||||
|
"requires"
|
||||||
|
"constexpr"
|
||||||
|
] @keyword
|
||||||
|
|
||||||
|
[
|
||||||
|
"class"
|
||||||
|
"namespace"
|
||||||
|
"template"
|
||||||
|
"typename"
|
||||||
|
"concept"
|
||||||
|
] @keyword.storage.type
|
||||||
|
|
||||||
|
[
|
||||||
|
"co_await"
|
||||||
|
"co_yield"
|
||||||
|
"co_return"
|
||||||
|
] @keyword
|
||||||
|
|
||||||
|
[
|
||||||
|
"public"
|
||||||
|
"private"
|
||||||
|
"protected"
|
||||||
|
"final"
|
||||||
|
"virtual"
|
||||||
|
] @keyword.storage.modifier
|
||||||
|
|
||||||
|
[
|
||||||
|
"new"
|
||||||
|
"delete"
|
||||||
|
"xor"
|
||||||
|
"bitand"
|
||||||
|
"bitor"
|
||||||
|
"compl"
|
||||||
|
"not"
|
||||||
|
"xor_eq"
|
||||||
|
"and_eq"
|
||||||
|
"or_eq"
|
||||||
|
"not_eq"
|
||||||
|
"and"
|
||||||
|
"or"
|
||||||
|
] @keyword.operator
|
||||||
|
|
||||||
|
"<=>" @operator
|
||||||
|
|
||||||
|
"::" @punctuation.delimiter
|
||||||
|
|
||||||
|
(template_argument_list
|
||||||
|
[
|
||||||
|
"<"
|
||||||
|
">"
|
||||||
|
] @punctuation.bracket)
|
||||||
|
|
||||||
|
(template_parameter_list
|
||||||
|
[
|
||||||
|
"<"
|
||||||
|
">"
|
||||||
|
] @punctuation.bracket)
|
||||||
|
|
||||||
|
(literal_suffix) @operator
|
||||||
|
|
||||||
|
; hlsl
|
||||||
|
[
|
||||||
|
"in"
|
||||||
|
"out"
|
||||||
|
"inout"
|
||||||
|
"uniform"
|
||||||
|
"shared"
|
||||||
|
"groupshared"
|
||||||
|
"discard"
|
||||||
|
"cbuffer"
|
||||||
|
"row_major"
|
||||||
|
"column_major"
|
||||||
|
"globallycoherent"
|
||||||
|
"centroid"
|
||||||
|
"noperspective"
|
||||||
|
"nointerpolation"
|
||||||
|
"sample"
|
||||||
|
"linear"
|
||||||
|
"snorm"
|
||||||
|
"unorm"
|
||||||
|
"point"
|
||||||
|
"line"
|
||||||
|
"triangleadj"
|
||||||
|
"lineadj"
|
||||||
|
"triangle"
|
||||||
|
] @keyword
|
||||||
|
|
||||||
|
((identifier) @variable.builtin
|
||||||
|
(#match? @variable.builtin "^SV_"))
|
||||||
|
; ((identifier) @variable)
|
||||||
|
|
||||||
|
(hlsl_attribute) @attribute
|
||||||
|
|
||||||
|
(hlsl_attribute
|
||||||
|
[
|
||||||
|
"["
|
||||||
|
"]"
|
||||||
|
] @attribute)
|
||||||
|
|
||||||
|
"This" @type.builtin
|
||||||
|
|
||||||
|
[
|
||||||
|
"interface"
|
||||||
|
"extension"
|
||||||
|
"property"
|
||||||
|
"associatedtype"
|
||||||
|
"where"
|
||||||
|
"var"
|
||||||
|
"let"
|
||||||
|
] @keyword
|
||||||
|
|
||||||
|
"__init" @constructor
|
||||||
|
|
||||||
|
[
|
||||||
|
"__subscript"
|
||||||
|
"get"
|
||||||
|
"set"
|
||||||
|
] @function.builtin
|
||||||
|
|
||||||
|
(call_expression) @function
|
||||||
|
|
||||||
|
(call_expression (identifier)) @function
|
||||||
|
|
||||||
|
((call_expression
|
||||||
|
function: (identifier) @function.builtin)
|
||||||
|
(#any-of? @function.builtin
|
||||||
|
"frac" "abs" "acos" "acosh" "asin" "asinh" "atan" "atanh" "cos" "cosh" "exp" "exp2" "floor" "log" "log10" "log2" "round" "rsqrt" "sin" "sincos" "sinh" "sqrt" "tan" "tanh" "trunc"
|
||||||
|
"AllMemoryBarrier" "AllMemoryBarrierWithGroupSync" "DeviceMemoryBarrier" "DeviceMemoryBarrierWithGroupSync" "GroupMemoryBarrier" "GroupMemoryBarrierWithGroupSync"
|
||||||
|
"abort" "clip" "errorf" "printf"
|
||||||
|
"all" "any" "countbits" "faceforward" "firstbithigh" "firstbitlow" "isfinite" "isinf" "isnan" "max" "min" "noise" "pow" "reversebits" "sign"
|
||||||
|
"asdouble" "asfloat" "asint" "asuint" "D3DCOLORtoUBYTE4" "f16tof32" "f32tof16"
|
||||||
|
"ceil" "clamp" "degrees" "fma" "fmod" "frac" "frexp" "ldexp" "lerp" "mad" "modf" "radiants" "saturate" "smoothstep" "step"
|
||||||
|
"cross" "determinant" "distance" "dot" "dst" "length" "lit" "msad4" "mul" "normalize" "rcp" "reflect" "refract" "transpose"
|
||||||
|
"ddx" "ddx_coarse" "ddx_fine" "ddy" "ddy_coarse" "ddy_fine" "fwidth"
|
||||||
|
"EvaluateAttributeAtCentroid" "EvaluateAttributeAtSample" "EvaluateAttributeSnapped"
|
||||||
|
"GetRenderTargetSampleCount" "GetRenderTargetSamplePosition"
|
||||||
|
"InterlockedAdd" "InterlockedAnd" "InterlockedCompareExchange" "InterlockedCompareStore" "InterlockedExchange" "InterlockedMax" "InterlockedMin" "InterlockedOr" "InterlockedXor"
|
||||||
|
"InterlockedCompareStoreFloatBitwise" "InterlockedCompareExchangeFloatBitwise"
|
||||||
|
"Process2DQuadTessFactorsAvg" "Process2DQuadTessFactorsMax" "Process2DQuadTessFactorsMin" "ProcessIsolineTessFactors"
|
||||||
|
"ProcessQuadTessFactorsAvg" "ProcessQuadTessFactorsMax" "ProcessQuadTessFactorsMin" "ProcessTriTessFactorsAvg" "ProcessTriTessFactorsMax" "ProcessTriTessFactorsMin"
|
||||||
|
"tex1D" "tex1Dbias" "tex1Dgrad" "tex1Dlod" "tex1Dproj"
|
||||||
|
"tex2D" "tex2Dbias" "tex2Dgrad" "tex2Dlod" "tex2Dproj"
|
||||||
|
"tex3D" "tex3Dbias" "tex3Dgrad" "tex3Dlod" "tex3Dproj"
|
||||||
|
"texCUBE" "texCUBEbias" "texCUBEgrad" "texCUBElod" "texCUBEproj"
|
||||||
|
"WaveIsFirstLane" "WaveGetLaneCount" "WaveGetLaneIndex"
|
||||||
|
"IsHelperLane"
|
||||||
|
"WaveActiveAnyTrue" "WaveActiveAllTrue" "WaveActiveBallot"
|
||||||
|
"WaveReadLaneFirst" "WaveReadLaneAt"
|
||||||
|
"WaveActiveAllEqual" "WaveActiveAllEqualBool" "WaveActiveCountBits"
|
||||||
|
"WaveActiveSum" "WaveActiveProduct" "WaveActiveBitAnd" "WaveActiveBitOr" "WaveActiveBitXor" "WaveActiveMin" "WaveActiveMax"
|
||||||
|
"WavePrefixCountBits" "WavePrefixProduct" "WavePrefixSum"
|
||||||
|
"QuadReadAcrossX" "QuadReadAcrossY" "QuadReadAcrossDiagonal" "QuadReadLaneAt"
|
||||||
|
"QuadAny" "QuadAll"
|
||||||
|
"WaveMatch" "WaveMultiPrefixSum" "WaveMultiPrefixProduct" "WaveMultiPrefixCountBits" "WaveMultiPrefixAnd" "WaveMultiPrefixOr" "WaveMultiPrefixXor"
|
||||||
|
"NonUniformResourceIndex"
|
||||||
|
"DispatchMesh" "SetMeshOutputCounts"
|
||||||
|
"dot4add_u8packed" "dot4add_i8packed" "dot2add"
|
||||||
|
"RestartStrip"
|
||||||
|
"CalculateLevelOfDetail" "CalculateLevelOfDetailUnclamped" "Gather" "GetDimensions" "GetSamplePosition" "Load" "Sample" "SampleBias" "SampleCmp" "SampleCmpLevelZero" "SampleGrad" "SampleLevel" "GatherRaw" "SampleCmpLevel"
|
||||||
|
"SampleCmpBias" "SampleCmpGrad"
|
||||||
|
"WriteSamplerFeedback" "WriteSamplerFeedbackBias" "WriteSamplerFeedbackGrad" "WriteSamplerFeedbackLevel"
|
||||||
|
"Append" "Consume" "DecrementCounter" "IncrementCounter"
|
||||||
|
"Load2" "Load3" "Load4" "Store" "Store2" "Store3" "Store4"
|
||||||
|
"GatherRed" "GatherGreen" "GatherBlue" "GatherAlpha" "GatherCmp" "GatherCmpRed" "GatherCmpGreen" "GatherCmpBlue" "GatherCmpAlpha"
|
||||||
|
))
|
||||||
|
|
||||||
|
(interface_requirements
|
||||||
|
(identifier) @type)
|
||||||
|
|
||||||
|
(binary_expression
|
||||||
|
[
|
||||||
|
"is"
|
||||||
|
"as"
|
||||||
|
]
|
||||||
|
right: (identifier) @type)
|
||||||
|
|
||||||
|
[
|
||||||
|
"as"
|
||||||
|
"is"
|
||||||
|
] @keyword.operator
|
||||||
|
|
||||||
|
[
|
||||||
|
"__exported"
|
||||||
|
"import"
|
||||||
|
] @keyword.control.import
|
||||||
|
|
||||||
|
(property_declaration
|
||||||
|
(identifier) @variable.other.member)
|
|
@ -0,0 +1,6 @@
|
||||||
|
; inherits: hlsl
|
||||||
|
|
||||||
|
[
|
||||||
|
(interface_specifier)
|
||||||
|
(extension_specifier)
|
||||||
|
] @indent
|
|
@ -0,0 +1,5 @@
|
||||||
|
((preproc_arg) @injection.content
|
||||||
|
(#set! injection.language "slang"))
|
||||||
|
|
||||||
|
((comment) @injection.content
|
||||||
|
(#set! injection.language "comment"))
|
|
@ -0,0 +1,30 @@
|
||||||
|
(function_definition
|
||||||
|
body: (_) @function.inside) @function.around
|
||||||
|
|
||||||
|
(struct_specifier
|
||||||
|
body: (_) @class.inside) @class.around
|
||||||
|
|
||||||
|
(interface_specifier
|
||||||
|
body: (_) @class.inside) @class.around
|
||||||
|
|
||||||
|
(enum_specifier
|
||||||
|
body: (_) @class.inside) @class.around
|
||||||
|
|
||||||
|
(union_specifier
|
||||||
|
body: (_) @class.inside) @class.around
|
||||||
|
|
||||||
|
(parameter_list
|
||||||
|
((_) @parameter.inside . ","? @parameter.around) @parameter.around)
|
||||||
|
|
||||||
|
(argument_list
|
||||||
|
((_) @parameter.inside . ","? @parameter.around) @parameter.around)
|
||||||
|
|
||||||
|
(comment) @comment.inside
|
||||||
|
|
||||||
|
(comment)+ @comment.around
|
||||||
|
|
||||||
|
(enumerator
|
||||||
|
(_) @entry.inside) @entry.around
|
||||||
|
|
||||||
|
(initializer_list
|
||||||
|
(_) @entry.around)
|
|
@ -106,6 +106,7 @@
|
||||||
"+"
|
"+"
|
||||||
"/"
|
"/"
|
||||||
"*"
|
"*"
|
||||||
|
"**"
|
||||||
"^"
|
"^"
|
||||||
"&"
|
"&"
|
||||||
"|"
|
"|"
|
||||||
|
@ -118,8 +119,6 @@
|
||||||
"'{"
|
"'{"
|
||||||
"<="
|
"<="
|
||||||
"@"
|
"@"
|
||||||
"or"
|
|
||||||
"and"
|
|
||||||
"=="
|
"=="
|
||||||
"!="
|
"!="
|
||||||
"==="
|
"==="
|
||||||
|
@ -131,8 +130,15 @@
|
||||||
"%"
|
"%"
|
||||||
">>"
|
">>"
|
||||||
"<<"
|
"<<"
|
||||||
|
">>>"
|
||||||
|
"<<<"
|
||||||
"|="
|
"|="
|
||||||
(inc_or_dec_operator)
|
(inc_or_dec_operator)
|
||||||
|
"?"
|
||||||
|
] @operator
|
||||||
|
[
|
||||||
|
"or"
|
||||||
|
"and"
|
||||||
] @keyword.operator
|
] @keyword.operator
|
||||||
|
|
||||||
(cast
|
(cast
|
||||||
|
|
Loading…
Reference in New Issue