我正在编写自己的语法grammar with TextMate to use in VSCode作为扩展,它将使用Oniguruma regular expressions突出显示自定义语言的源代码。
除了块注释(多行注释)之外,我都能正常工作。
有一些TextMate XML文件示例,这些示例似乎实现了块注释,但是它们很大,例如。
https://github.com/aponxi/sublime-better-coffeescript/blob/master/CoffeeScript.tmLanguage#L175
https://github.com/Microsoft/TypeScript-TmLanguage/blob/master/TypeScriptReact.tmLanguage#L8007
我无法使用这些示例来提取块注释功能,因为还有许多其他连接但与我无关的
这是我的package.json
:
{
"name": "mylang",
"version": "0.0.1",
"engines": {
"vscode": "*"
},
"publisher": "me",
"contributes": {
"languages": [
{
"id": "mylang",
"aliases": [
"mylang"
],
"extensions": [
".mylang"
]
}
],
"grammars": [
{
"language": "mylang",
"scopeName": "source.mylang",
"path": "./syntaxes/mylang.tmLanguage"
}
]
}
}
这是我的mylang.tmlanguage
文件(为简便起见,简称:):
<?xml version="1.0" encoding="UTF-8"?>
<!DOCTYPE plist PUBLIC "-//Apple//DTD PLIST 1.0//EN" "http://www.apple.com/DTDs/PropertyList-1.0.dtd">
<plist version="1.0">
<dict>
<key>scopeName</key>
<string>source.mylang</string>
<key>fileTypes</key>
<array>
<string>mylang</string>
</array>
<key>name</key>
<string>mylang file</string>
<key>patterns</key>
<array>
<!-- Numbers -->
<dict>
<key>match</key>
<string>\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|ll|LL|ull|ULL)?\b</string>
<key>name</key>
<string>constant.numeric</string>
</dict>
<!-- Types -->
<dict>
<key>match</key>
<string>\b(date|int|string|float|varchar)\b</string>
<key>name</key>
<string>entity.name.type</string>
</dict>
<!-- single line comment -->
<dict>
<key>match</key>
<string>\/\*(\w|\s|\W|\n|\r\n)*\/</string>
<key>name</key>
<string>comment</string>
</dict>
<!-- Multiline comments -->
</array>
<key>uuid</key>
<string>FF0550E0-3A29-11E3-AA6E-0800200C9A77</string>
</dict>
</plist>
对于所有项目,我都能正确显示突出显示,因此我的扩展程序有效。
如果我理解正确,那么我不能像单行注释那样为多行注释提供正则表达式。我需要使用带有begin
和end
标签的嵌套标签结构,但是我无法弄清楚要使用的结构。