From 16a2650cc2f803c2c177eb5cc1002a74ad4397f4 Mon Sep 17 00:00:00 2001 From: Thomas Smith Date: Sat, 23 Sep 2023 15:07:43 -0400 Subject: [PATCH] [TypeScript] Support placeholder in LSP type output (#3846) --- JavaScript/TypeScript.sublime-syntax | 5 +++++ JavaScript/tests/syntax_test_typescript.ts | 9 +++++++++ 2 files changed, 14 insertions(+) diff --git a/JavaScript/TypeScript.sublime-syntax b/JavaScript/TypeScript.sublime-syntax index 0767815b3e..510c70f2ed 100644 --- a/JavaScript/TypeScript.sublime-syntax +++ b/JavaScript/TypeScript.sublime-syntax @@ -854,6 +854,11 @@ contexts: - ts-type-expression-begin ts-type-expression-begin: + # Placeholder in LSP output. This should never occur in actual TypeScript code. + - match: '\.\.\. \d+ more \.\.\.' + scope: comment.other.ts + pop: true + - match: keyof{{identifier_break}} scope: keyword.operator.type.js - match: typeof{{identifier_break}} diff --git a/JavaScript/tests/syntax_test_typescript.ts b/JavaScript/tests/syntax_test_typescript.ts index 3b380ddf9e..ee7bd6fd62 100644 --- a/JavaScript/tests/syntax_test_typescript.ts +++ b/JavaScript/tests/syntax_test_typescript.ts @@ -1390,3 +1390,12 @@ type T = V; // ^^^ storage.modifier.variance // ^ variable.parameter.generic // ^ punctuation.definition.generic.end + +type T = Foo | ... 100 more ... | Bar; +//^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^ meta.type-alias +// ^^^ support.class +// ^ keyword.operator.type.union +// ^^^^^^^^^^^^^^^^ comment.other.ts +// ^ keyword.operator.type.union +// ^^^ support.class +// ^ punctuation.terminator.statement.empty