如何为VSCode自定义语言语法突出显示添加TextMate plist xml格式的多行注释支持?

时间:2019-07-01 15:09:55

标签: regex syntax visual-studio-code grammar textmate

我正在编写自己的语法grammar with TextMate to use in VSCode作为扩展,它将使用Oniguruma regular expressions突出显示自定义语言的源代码。

除了块注释(多行注释)之外,我都能正常工作。

有一些TextMate XML文件示例,这些示例似乎实现了块注释,但是它们很大,例如。

我无法使用这些示例来提取块注释功能,因为还有许多其他连接但与我无关的

这是我的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>

对于所有项目,我都能正确显示突出显示,因此我的扩展程序有效。

如果我理解正确,那么我不能像单行注释那样为多行注释提供正则表达式。我需要使用带有beginend标签的嵌套标签结构,但是我无法弄清楚要使用的结构。

0 个答案:

没有答案