From bf239233da290c30b05b9c2b93867aade43c1574 Mon Sep 17 00:00:00 2001 From: deathaxe Date: Sun, 18 Aug 2024 11:04:58 +0200 Subject: [PATCH 1/4] Syntax: Add support for WAST/WIT fenced code blocks --- .../Code Block Syntaxes.sublime-completions | 14 ++++++ syntaxes/Markdown.sublime-syntax | 46 +++++++++++++++++++ 2 files changed, 60 insertions(+) diff --git a/syntaxes/Code Block Syntaxes.sublime-completions b/syntaxes/Code Block Syntaxes.sublime-completions index a5439ff7..6c78dd32 100644 --- a/syntaxes/Code Block Syntaxes.sublime-completions +++ b/syntaxes/Code Block Syntaxes.sublime-completions @@ -664,6 +664,20 @@ "details": "Specifies SQL code highlighting" }, + // WASM + { + "trigger": "wast", + "annotation": "WAST", + "kind": ["markup", "s", "Syntax"], + "details": "Specifies WebAssembly Text code highlighting" + }, + { + "trigger": "wit", + "annotation": "WIT", + "kind": ["markup", "s", "Syntax"], + "details": "Specifies WabAssembly Interface Type code highlighting" + }, + // XML { "trigger": "atom", diff --git a/syntaxes/Markdown.sublime-syntax b/syntaxes/Markdown.sublime-syntax index f64cb4ac..8ccd0c41 100644 --- a/syntaxes/Markdown.sublime-syntax +++ b/syntaxes/Markdown.sublime-syntax @@ -1182,6 +1182,8 @@ contexts: - include: fenced-twee - include: fenced-twig - include: fenced-verilog + - include: fenced-wast + - include: fenced-wit - include: fenced-xonsh fenced-actionscript: @@ -2858,6 +2860,50 @@ contexts: 1: punctuation.definition.raw.code-fence.end.markdown 2: meta.fold.code-fence.end.markdown + fenced-wast: + - match: |- + (?x) + {{fenced_code_block_start}} + (?i:\s*(wast)) + {{fenced_code_block_trailing_infostring_characters}} + captures: + 0: meta.code-fence.definition.begin.wast.markdown-gfm + 2: punctuation.definition.raw.code-fence.begin.markdown + 5: constant.other.language-name.markdown + 6: comment.line.infostring.markdown + 7: meta.fold.code-fence.begin.markdown + embed: scope:source.wast + embed_scope: + markup.raw.code-fence.wast.markdown-gfm + source.wast + escape: '{{fenced_code_block_escape}}' + escape_captures: + 0: meta.code-fence.definition.end.wast.markdown-gfm + 1: punctuation.definition.raw.code-fence.end.markdown + 2: meta.fold.code-fence.end.markdown + + fenced-wit: + - match: |- + (?x) + {{fenced_code_block_start}} + (?i:\s*(wit)) + {{fenced_code_block_trailing_infostring_characters}} + captures: + 0: meta.code-fence.definition.begin.wit.markdown-gfm + 2: punctuation.definition.raw.code-fence.begin.markdown + 5: constant.other.language-name.markdown + 6: comment.line.infostring.markdown + 7: meta.fold.code-fence.begin.markdown + embed: scope:source.wit + embed_scope: + markup.raw.code-fence.wit.markdown-gfm + source.wit + escape: '{{fenced_code_block_escape}}' + escape_captures: + 0: meta.code-fence.definition.end.wit.markdown-gfm + 1: punctuation.definition.raw.code-fence.end.markdown + 2: meta.fold.code-fence.end.markdown + fenced-xonsh: - match: |- (?x) From a6b3195c0152766c34fd86d5152abcf74a8ffea9 Mon Sep 17 00:00:00 2001 From: deathaxe Date: Tue, 22 Oct 2024 20:07:24 +0200 Subject: [PATCH 2/4] Syntax: More lazy syntax tests Avoid compatibility issues with core packages. --- tests/syntax_test_markdown.md | 6 +++--- 1 file changed, 3 insertions(+), 3 deletions(-) diff --git a/tests/syntax_test_markdown.md b/tests/syntax_test_markdown.md index 4619ae89..bd786fcc 100644 --- a/tests/syntax_test_markdown.md +++ b/tests/syntax_test_markdown.md @@ -2043,9 +2043,9 @@ unclosed_paren = ( | ^ meta.code-fence.definition.begin meta.fold.code-fence.begin - merkup function foo () { -| <- markup.raw.code-fence.shell.markdown-gfm meta.function.shell keyword.declaration.function.shell +| <- markup.raw.code-fence.shell.markdown-gfm meta.function keyword.declaration.function.shell } -| <- markup.raw.code-fence.shell.markdown-gfm meta.function.shell punctuation.section +| <- markup.raw.code-fence.shell.markdown-gfm meta.function punctuation.section $ ls ~ | <- markup.raw.code-fence.shell.markdown-gfm source.shell.interactive comment.other.shell @@ -2394,7 +2394,7 @@ okay