From 782ea940507461d694ded23bcfddd718b240d442 Mon Sep 17 00:00:00 2001 From: Alex Ross Date: Mon, 13 Mar 2023 17:40:43 +0100 Subject: [PATCH] Update shellscript grammar (#176978) --- extensions/shellscript/cgmanifest.json | 4 +- .../syntaxes/shell-unix-bash.tmLanguage.json | 70 ++++++++++++++----- .../test/colorize-results/test-173216_sh.json | 6 +- .../test/colorize-results/test-173336_sh.json | 18 ++--- .../test/colorize-results/test_sh.json | 44 ++++++------ 5 files changed, 90 insertions(+), 52 deletions(-) diff --git a/extensions/shellscript/cgmanifest.json b/extensions/shellscript/cgmanifest.json index f3743babadc..45091516a46 100644 --- a/extensions/shellscript/cgmanifest.json +++ b/extensions/shellscript/cgmanifest.json @@ -6,11 +6,11 @@ "git": { "name": "jeff-hykin/better-shell-syntax", "repositoryUrl": "https://github.com/jeff-hykin/better-shell-syntax", - "commitHash": "02e55c164ef9a5b1754ba1caa184b966e7a69a44" + "commitHash": "adcc0fdac84e96e03a2cfb48a0f6f854a1da9053" } }, "license": "MIT", - "version": "1.4.4" + "version": "1.4.5" } ], "version": 1 diff --git a/extensions/shellscript/syntaxes/shell-unix-bash.tmLanguage.json b/extensions/shellscript/syntaxes/shell-unix-bash.tmLanguage.json index a44418fb9f9..93ef7323aa3 100644 --- a/extensions/shellscript/syntaxes/shell-unix-bash.tmLanguage.json +++ b/extensions/shellscript/syntaxes/shell-unix-bash.tmLanguage.json @@ -4,7 +4,7 @@ "If you want to provide a fix or improvement, please create a pull request against the original repository.", "Once accepted there, we are happy to receive an update request." ], - "version": "https://github.com/jeff-hykin/better-shell-syntax/commit/02e55c164ef9a5b1754ba1caa184b966e7a69a44", + "version": "https://github.com/jeff-hykin/better-shell-syntax/commit/adcc0fdac84e96e03a2cfb48a0f6f854a1da9053", "name": "Shell Script", "scopeName": "source.shell", "patterns": [ @@ -2116,17 +2116,6 @@ } } }, - { - "match": "(\\$)(\\{[0-9]+\\}(?!\\w))", - "captures": { - "1": { - "name": "punctuation.definition.variable.shell variable.parameter.positional.shell" - }, - "2": { - "name": "variable.parameter.positional.shell" - } - } - }, { "match": "(\\$)([-*#?$!0_](?!\\w))", "captures": { @@ -2139,19 +2128,68 @@ } }, { - "begin": "(\\$)(\\{)", + "begin": "(\\$)(\\{)[ \\t]*+(?=\\d)", "end": "\\}", "beginCaptures": { "1": { - "name": "punctuation.definition.variable.shell punctuation.section.bracket.curly.variable.begin.shell" + "name": "punctuation.definition.variable.shell variable.parameter.positional.shell" }, "2": { - "name": "punctuation.section.bracket.curly.variable.begin.shell" + "name": "punctuation.section.bracket.curly.variable.begin.shell punctuation.definition.variable.shell variable.parameter.positional.shell" } }, "endCaptures": { "0": { - "name": "punctuation.section.bracket.curly.variable.end.shell" + "name": "punctuation.section.bracket.curly.variable.end.shell punctuation.definition.variable.shell variable.parameter.positional.shell" + } + }, + "contentName": "meta.parameter-expansion", + "patterns": [ + { + "match": "!|:[-=?]?|\\*|@|##|#|%%|%|\\/", + "name": "keyword.operator.expansion.shell" + }, + { + "match": "(\\[)[^\\]]+(\\])", + "captures": { + "1": { + "name": "punctuation.section.array.shell" + }, + "2": { + "name": "punctuation.section.array.shell" + } + } + }, + { + "match": "[0-9]+", + "name": "variable.parameter.positional.shell" + }, + { + "match": "(?