[英]VSCode extension: embed standard language in mine
我需要在我的语言扩展中嵌入标准语言(例如JavaScript
)。 这意味着,我想看到自动完成,语法higlighting等作为file.js
。 我可以这样做吗(如何)?
感谢您提供任何示例!
您可以在嵌入式语言指南中使用附加语法syntaxes/abc.tmLanguage.json
继续abc-lang
示例:
{
"scopeName": "source.abc",
"patterns": [ { "include": "#expression" } ],
"repository": {
"expression": {
"patterns": [
{ "include": "#letter" },
{ "include": "#paren-expression" },
{ "include": "#code" }
]
},
"letter": {
"match": "a|b|c",
"name": "keyword.letter"
},
"paren-expression": {
"begin": "\\(",
"end": "\\)",
"beginCaptures": {
"0": { "name": "punctuation.paren.open" }
},
"endCaptures": {
"0": { "name": "punctuation.paren.close" }
},
"name": "expression.group",
"patterns": [ { "include": "#expression" } ]
},
"code": {
"begin": "```js",
"end": "```",
"beginCaptures": {
"0": { "name": "punctuation.code.open" }
},
"endCaptures": {
"0": { "name": "punctuation.code.close" }
},
"name": "meta.embedded.block.javascript",
"patterns": [ { "include": "source.js" } ]
}
}
}
语法高亮很容易,只需包含要嵌入的语言的顶级范围。 例如, Html 使用"include": "source.js"
在脚本块内添加 js 语法高亮。
智能感知要困难得多。 再次,看看vscode 的 HTML 扩展做了什么。 它基本上将 html 文件拆分为虚拟文档(一个用于脚本块,一个用于样式块,一个用于 html),然后为这些语言中的每一种嵌入所需的语言库以提供 IntelliSense。 Vetur 扩展也做了类似的事情。 在这两种情况下,扩展都拥有顶级文档(html 或 vue),然后根据发出 IntelliSense 请求的位置委托给正确的嵌入式语言
声明:本站的技术帖子网页,遵循CC BY-SA 4.0协议,如果您需要转载,请注明本站网址或者原文地址。任何问题请咨询:yoyou2525@163.com.