From 38e2bdfa8521a7886efa4cef96e1b5eaf3f709bc Mon Sep 17 00:00:00 2001 From: Christopher Dwyer-Perkins Date: Thu, 14 Nov 2024 10:23:37 -0400 Subject: [PATCH] Potental fix for numeric literal colorization --- src/grammar/brightscript.tmLanguage.spec.ts | 67 +++++++++++++++++++++ syntaxes/brightscript.tmLanguage.json | 14 ++++- 2 files changed, 79 insertions(+), 2 deletions(-) diff --git a/src/grammar/brightscript.tmLanguage.spec.ts b/src/grammar/brightscript.tmLanguage.spec.ts index 99a369be..a9507d66 100644 --- a/src/grammar/brightscript.tmLanguage.spec.ts +++ b/src/grammar/brightscript.tmLanguage.spec.ts @@ -6,6 +6,73 @@ import { standardizePath as s } from 'brighterscript'; const brightscriptTmlanguagePath = s`${__dirname}/../../syntaxes/brightscript.tmLanguage.json`; describe('brightscript.tmlanguage.json', () => { + it('colors numerics correctly', async () => { + await testGrammar(` + var = 1 + ' ^ constant.numeric.brs + '^^^ entity.name.variable.local.brs + `); + + await testGrammar(` + var = 1.1 + ' ^ constant.numeric.brs + ' ^ constant.numeric.brs + '^^^ entity.name.variable.local.brs + `); + + await testGrammar(` + var = .1 + ' ^ constant.numeric.brs + '^^^ entity.name.variable.local.brs + `); + + await testGrammar(` + var = 0x2 + ' ^^^ constant.numeric.brs + '^^^ entity.name.variable.local.brs + `); + + await testGrammar(` + var = 1.8e+308 + ' ^^^^^^^^ constant.numeric.brs + '^^^ entity.name.variable.local.brs + `); + + await testGrammar(` + var = 0x2 + ' ^^^ constant.numeric.brs + '^^^ entity.name.variable.local.brs + `); + + await testGrammar(` + var = 0% + ' ^ source.brs + ' ^ constant.numeric.brs + '^^^ entity.name.variable.local.brs + `); + + await testGrammar(` + var = 0! + ' ^ source.brs + ' ^ constant.numeric.brs + '^^^ entity.name.variable.local.brs + `); + + await testGrammar(` + var = 0# + ' ^ source.brs + ' ^ constant.numeric.brs + '^^^ entity.name.variable.local.brs + `); + + await testGrammar(` + var = 0& + ' ^ source.brs + ' ^ constant.numeric.brs + '^^^ entity.name.variable.local.brs + `); + }); + it('colors m, m.top, m.global, and super correctly', async () => { await testGrammar(` super.doSomething() diff --git a/syntaxes/brightscript.tmLanguage.json b/syntaxes/brightscript.tmLanguage.json index 2c63db55..e7ac5009 100644 --- a/syntaxes/brightscript.tmLanguage.json +++ b/syntaxes/brightscript.tmLanguage.json @@ -82,6 +82,9 @@ { "include": "#function_call" }, + { + "include": "#numeric_literal" + }, { "include": "#object_properties" }, @@ -581,8 +584,7 @@ ] }, { - "match": "\\b((0(x|X)[0-9a-fA-F]*)|(([0-9]+\\.?[0-9]*)|(\\.[0-9]+))((e|E)(\\+|-)?[0-9]+)?)(L|l|UL|ul|u|U|F|f)?\\b", - "name": "constant.numeric.brs" + "include": "#numeric_literal" }, { "patterns": [ @@ -606,6 +608,14 @@ } ] }, + "numeric_literal": { + "patterns": [ + { + "match": "\\b((0(x|X)[0-9a-fA-F]*)|(([0-9]+\\.?[0-9]*)|(\\.[0-9]+))((e|E)(\\+|-)?[0-9]+)?)(L|l|UL|ul|u|U|F|f)?\\b", + "name": "constant.numeric.brs" + } + ] + }, "comment": { "patterns": [ {