From aba2914a31615ecd153cd23be035e6cdfa967a42 Mon Sep 17 00:00:00 2001 From: Max Brunsfeld Date: Mon, 6 Mar 2023 15:38:12 -0800 Subject: [PATCH 1/4] Fix constant highlighting in JS, TypeScript Previously, SCREAMING_SNAKE_CASE identifiers were highlighted as types due to a mistake in the order of patterns in the highlight queries. --- crates/zed/src/languages/javascript/highlights.scm | 14 ++++---------- crates/zed/src/languages/typescript/highlights.scm | 13 +++++-------- 2 files changed, 9 insertions(+), 18 deletions(-) diff --git a/crates/zed/src/languages/javascript/highlights.scm b/crates/zed/src/languages/javascript/highlights.scm index 9dc3af4eae..36ab21ca1e 100644 --- a/crates/zed/src/languages/javascript/highlights.scm +++ b/crates/zed/src/languages/javascript/highlights.scm @@ -43,8 +43,10 @@ ; Special identifiers -((identifier) @constructor - (#match? @constructor "^[A-Z]")) +((identifier) @type + (#match? @type "^[A-Z]")) +(type_identifier) @type +(predefined_type) @type.builtin ([ (identifier) @@ -192,14 +194,6 @@ "${" @punctuation.special "}" @punctuation.special) @embedded -; Types - -(type_identifier) @type -(predefined_type) @type.builtin - -((identifier) @type - (#match? @type "^[A-Z]")) - (type_arguments "<" @punctuation.bracket ">" @punctuation.bracket) diff --git a/crates/zed/src/languages/typescript/highlights.scm b/crates/zed/src/languages/typescript/highlights.scm index 4b744c3a80..bf086ea156 100644 --- a/crates/zed/src/languages/typescript/highlights.scm +++ b/crates/zed/src/languages/typescript/highlights.scm @@ -46,6 +46,11 @@ ((identifier) @constructor (#match? @constructor "^[A-Z]")) +((identifier) @type + (#match? @type "^[A-Z]")) +(type_identifier) @type +(predefined_type) @type.builtin + ([ (identifier) (shorthand_property_identifier) @@ -193,14 +198,6 @@ "${" @punctuation.special "}" @punctuation.special) @embedded -; Types - -(type_identifier) @type -(predefined_type) @type.builtin - -((identifier) @type - (#match? @type "^[A-Z]")) - (type_arguments "<" @punctuation.bracket ">" @punctuation.bracket) From 0867162c879d8f555c772e88b257bc245f6f878e Mon Sep 17 00:00:00 2001 From: Max Brunsfeld Date: Mon, 6 Mar 2023 15:54:14 -0800 Subject: [PATCH 2/4] Fix lua highlight query * Fix regex predicate on constants. * Remove 'function.call' highlight name. In other languages, we differentiate calls from definitions with the 'function.definition' highlight name. We actually don't use this in any themes though. --- crates/zed/src/languages/lua/highlights.scm | 16 +++++++++++----- 1 file changed, 11 insertions(+), 5 deletions(-) diff --git a/crates/zed/src/languages/lua/highlights.scm b/crates/zed/src/languages/lua/highlights.scm index 96389c79b4..f061bbf8f9 100644 --- a/crates/zed/src/languages/lua/highlights.scm +++ b/crates/zed/src/languages/lua/highlights.scm @@ -137,7 +137,7 @@ ;; Constants ((identifier) @constant - (#lua-match? @constant "^[A-Z][A-Z_0-9]*$")) + (#match? @constant "^[A-Z][A-Z_0-9]*$")) (vararg_expression) @constant @@ -164,11 +164,17 @@ (parameters (identifier) @parameter) -(function_call name: (identifier) @function.call) -(function_declaration name: (identifier) @function) +(function_call + name: [ + (identifier) @function + (dot_index_expression field: (identifier) @function) + ]) -(function_call name: (dot_index_expression field: (identifier) @function.call)) -(function_declaration name: (dot_index_expression field: (identifier) @function)) +(function_declaration + name: [ + (identifier) @function.definition + (dot_index_expression field: (identifier) @function.definition) + ]) (method_index_expression method: (identifier) @method) From 515724821e17f9c5c58e91f2b2e62801b7110383 Mon Sep 17 00:00:00 2001 From: Max Brunsfeld Date: Mon, 6 Mar 2023 15:56:20 -0800 Subject: [PATCH 3/4] Make racket highlight query more consistent with other langs --- crates/zed/src/languages/racket/highlights.scm | 2 +- 1 file changed, 1 insertion(+), 1 deletion(-) diff --git a/crates/zed/src/languages/racket/highlights.scm b/crates/zed/src/languages/racket/highlights.scm index 42b85774c9..2c0caf8935 100644 --- a/crates/zed/src/languages/racket/highlights.scm +++ b/crates/zed/src/languages/racket/highlights.scm @@ -19,7 +19,7 @@ (quote . (symbol)) @constant (extension) @keyword -(lang_name) @variable.builtin +(lang_name) @variable.special ((symbol) @operator (#match? @operator "^(\\+|-|\\*|/|=|>|<|>=|<=)$")) From c832e4406eedf0ffa32a482319692a068f563ce3 Mon Sep 17 00:00:00 2001 From: Max Brunsfeld Date: Mon, 6 Mar 2023 15:57:04 -0800 Subject: [PATCH 4/4] Remove more colors from default syntax theme These default colors weren't consistent with the rest of the syntax theme. --- styles/src/themes/common/syntax.ts | 59 ++++++------------------------ styles/src/themes/one-dark.ts | 1 + 2 files changed, 12 insertions(+), 48 deletions(-) diff --git a/styles/src/themes/common/syntax.ts b/styles/src/themes/common/syntax.ts index 7295a5432e..dcfd93628e 100644 --- a/styles/src/themes/common/syntax.ts +++ b/styles/src/themes/common/syntax.ts @@ -47,11 +47,11 @@ export interface Syntax { "string.special": SyntaxHighlightStyle // elixir: atom, quoted_atom, keyword, quoted_keyword // ruby: simple_symbol, delimited_symbol... - "string.special.symbol": SyntaxHighlightStyle + "string.special.symbol"?: SyntaxHighlightStyle // elixir, python, yaml...: escape_sequence - "string.escape": SyntaxHighlightStyle + "string.escape"?: SyntaxHighlightStyle // Regular expressions - "string.regex": SyntaxHighlightStyle + "string.regex"?: SyntaxHighlightStyle // == Types ====== / // We allow Function here because all JS objects literals have this property @@ -59,16 +59,14 @@ export interface Syntax { variant: SyntaxHighlightStyle type: SyntaxHighlightStyle // js: predefined_type - "type.builtin": SyntaxHighlightStyle + "type.builtin"?: SyntaxHighlightStyle // == Values variable: SyntaxHighlightStyle - // racket: lang_name - "variable.builtin": SyntaxHighlightStyle // this, ... // css: -- (var(--foo)) // lua: self - "variable.special": SyntaxHighlightStyle + "variable.special"?: SyntaxHighlightStyle // c: statement_identifier, label: SyntaxHighlightStyle // css: tag_name, nesting_selector, universal_selector... @@ -90,24 +88,22 @@ export interface Syntax { boolean: SyntaxHighlightStyle // elixir: __MODULE__, __DIR__, __ENV__, etc // go: nil, iota - "constant.builtin": SyntaxHighlightStyle + "constant.builtin"?: SyntaxHighlightStyle // == Functions ====== / function: SyntaxHighlightStyle // lua: assert, error, loadfile, tostring, unpack... - "function.builtin": SyntaxHighlightStyle - // lua: function_call - "function.call": SyntaxHighlightStyle + "function.builtin"?: SyntaxHighlightStyle // go: call_expression, method_declaration // js: call_expression, method_definition, pair (key, arrow function) // rust: function_item name: (identifier) - "function.definition": SyntaxHighlightStyle + "function.definition"?: SyntaxHighlightStyle // rust: macro_definition name: (identifier) - "function.special.definition": SyntaxHighlightStyle - "function.method": SyntaxHighlightStyle + "function.special.definition"?: SyntaxHighlightStyle + "function.method"?: SyntaxHighlightStyle // ruby: identifier/"defined?" // Nate note: I don't fully understand this one. - "function.method.builtin": SyntaxHighlightStyle + "function.method.builtin"?: SyntaxHighlightStyle // == Unsorted ====== / // lua: hash_bang_line @@ -117,9 +113,6 @@ export interface Syntax { embedded: SyntaxHighlightStyle } -// HACK: "constructor" as a key in the syntax interface returns an error when a theme tries to use it. -// For now hack around it by omiting constructor as a valid key for overrides. -// export type ThemeSyntax = Partial> export type ThemeSyntax = Partial const defaultSyntaxHighlightStyle: Omit = { @@ -238,18 +231,9 @@ function buildDefaultSyntax(colorScheme: ColorScheme): Syntax { type: { color: color.type, }, - "type.builtin": { - color: color.type, - }, variable: { color: color.primary, }, - "variable.builtin": { - color: colorScheme.ramps.blue(0.5).hex(), - }, - "variable.special": { - color: colorScheme.ramps.blue(0.7).hex(), - }, label: { color: colorScheme.ramps.blue(0.5).hex(), }, @@ -280,30 +264,9 @@ function buildDefaultSyntax(colorScheme: ColorScheme): Syntax { boolean: { color: color.boolean, }, - "constant.builtin": { - color: color.constant, - }, function: { color: color.function, }, - "function.builtin": { - color: color.function, - }, - "function.call": { - color: color.function, - }, - "function.definition": { - color: color.function, - }, - "function.special.definition": { - color: color.function, - }, - "function.method": { - color: color.function, - }, - "function.method.builtin": { - color: color.function, - }, preproc: { color: color.primary, }, diff --git a/styles/src/themes/one-dark.ts b/styles/src/themes/one-dark.ts index 2803cab572..419e4065fe 100644 --- a/styles/src/themes/one-dark.ts +++ b/styles/src/themes/one-dark.ts @@ -51,6 +51,7 @@ const syntax: ThemeSyntax = { linkText: { color: color.blue, italic: false }, linkUri: { color: color.teal }, number: { color: color.orange }, + constant: { color: color.yellow }, operator: { color: color.teal }, primary: { color: color.white }, property: { color: color.red },