Skip to content
New issue

Have a question about this project? Sign up for a free GitHub account to open an issue and contact its maintainers and the community.

By clicking “Sign up for GitHub”, you agree to our terms of service and privacy statement. We’ll occasionally send you account related emails.

Already on GitHub? Sign in to your account

vscode-cue: Sublime Text / TextMate / Sourcegraph syntax highlighting support #3427

Open
emidoots opened this issue Aug 2, 2021 · 2 comments

Comments

@emidoots
Copy link

emidoots commented Aug 2, 2021

I thought cue-lang/vscode-cue#12 was all we would need to get the grammar in syntaxes/cue.tmLanugage working for Sublime Text/TextMate/Sourcegraph, but unfortunately not: I've ran into another instance where the grammar here is not valid.

There are several instances where the grammar specifies a patterns array, without the begin and end keys:

invalid instances

https://github.com/cue-sh/vscode-cue/blob/4dff3d1e9ea19953de460950255885806100b7f2/internal/cmd/gen-syntax/defs.go#L57-L63

https://github.com/cue-sh/vscode-cue/blob/4dff3d1e9ea19953de460950255885806100b7f2/internal/cmd/gen-syntax/defs.go#L90-L102

https://github.com/cue-sh/vscode-cue/blob/4dff3d1e9ea19953de460950255885806100b7f2/internal/cmd/gen-syntax/defs.go#L132-L137

https://github.com/cue-sh/vscode-cue/blob/4dff3d1e9ea19953de460950255885806100b7f2/internal/cmd/gen-syntax/defs.go#L178-L203

https://github.com/cue-sh/vscode-cue/blob/4dff3d1e9ea19953de460950255885806100b7f2/internal/cmd/gen-syntax/defs.go#L204-L209

https://github.com/cue-sh/vscode-cue/blob/4dff3d1e9ea19953de460950255885806100b7f2/internal/cmd/gen-syntax/defs.go#L225-L235

https://github.com/cue-sh/vscode-cue/blob/4dff3d1e9ea19953de460950255885806100b7f2/internal/cmd/gen-syntax/defs.go#L236-L243

https://github.com/cue-sh/vscode-cue/blob/4dff3d1e9ea19953de460950255885806100b7f2/internal/cmd/gen-syntax/defs.go#L244-L259

https://github.com/cue-sh/vscode-cue/blob/4dff3d1e9ea19953de460950255885806100b7f2/internal/cmd/gen-syntax/defs.go#L264-L313

https://github.com/cue-sh/vscode-cue/blob/4dff3d1e9ea19953de460950255885806100b7f2/internal/cmd/gen-syntax/defs.go#L314-L322

https://github.com/cue-sh/vscode-cue/blob/4dff3d1e9ea19953de460950255885806100b7f2/internal/cmd/gen-syntax/defs.go#L339-L350

https://github.com/cue-sh/vscode-cue/blob/4dff3d1e9ea19953de460950255885806100b7f2/internal/cmd/gen-syntax/defs.go#L367-L372

https://github.com/cue-sh/vscode-cue/blob/4dff3d1e9ea19953de460950255885806100b7f2/internal/cmd/gen-syntax/defs.go#L373-L388

https://github.com/cue-sh/vscode-cue/blob/4dff3d1e9ea19953de460950255885806100b7f2/internal/cmd/gen-syntax/defs.go#L389-L412

https://github.com/cue-sh/vscode-cue/blob/4dff3d1e9ea19953de460950255885806100b7f2/internal/cmd/gen-syntax/defs.go#L473-L475

I noticed this because Sublime Text 4 fails to validate the grammar prior to conversion to a .sublime-syntax file, this is relatively easy to test but I won't enumerate the steps here unless you're interested.

Both the TextMate website and Sublime website are fairly clear:

  • The root patterns array may contain rules
  • A rule may contain a nested patterns array, only if it is a begin..end element.

From https://docs.sublimetext.io/reference/syntaxdefs_legacy.html#patterns-array

image

From https://macromates.com/manual/en/language_grammars#rule_keys

image

Unfortunately, it seems VS Code has differed here in their tmLanguage implementation and allowed a more lax interpretation - so the grammar here works in VS Code, but not elsewhere.

Sublime is capable of doing a best-effort translation, but it will drop highlighting for all of the mentioned definitions above (which is most of the grammar.) As for what to replace these patterns-only definitions with.. that's a bit trickier.

@myitcv
Copy link
Member

myitcv commented Aug 3, 2021

If only we had a schema to validate these grammars! ❤️

FWIW, this constraint could be described using a CUE schema with the help of a couple of upcoming proposals (#943 and #575)

As for the fix, perhaps we do this as part of #3425

cc @betawaffle for thoughts on any of this.

@betawaffle
Copy link

This was done intentionally in the original code I wrote (if I recall correctly) to avoid duplication where possible.

The fix for this bug is to take every instance of these and replace them with their contents. For example, everywhere #attribute_element is included, you'd instead include #attribute_label, #attribute_nested, and #attribute_string. You'd have to do that recursively obviously, since (for example) #attribute_string has that problem too.

The best way in my mind would be to implement it as a post-processing step, since duplicating all of that by hand sounds really painful, and would make it harder to maintain in the future.

I you implement the whole thing in CUE, there might be a simpler way to do the above, but I'm not certain.

emidoots referenced this issue in sourcegraph/sourcegraph-public-snapshot Aug 30, 2021
Although we did add the upstream Cue syntax highlighting grammar, it turned out to not be valid and so this feature does not work.

Tracking issue here: https://github.com/cue-sh/vscode-cue/issues/16
@myitcv myitcv changed the title Sublime Text / TextMate / Sourcegraph syntax highlighting support vscode-cue: Sublime Text / TextMate / Sourcegraph syntax highlighting support Sep 2, 2024
@myitcv myitcv transferred this issue from cue-lang/vscode-cue Sep 2, 2024
Sign up for free to join this conversation on GitHub. Already have an account? Sign in to comment
Labels
None yet
Projects
None yet
Development

No branches or pull requests

3 participants