6

我正在尝试在 Visual Studio Code 中创建一个扩展,以便为自定义语言启用语法突出显示。我在这里找到了@Wosi 提供的有用建议:在 Visual Studio Code 中创建自定义语言。基于此,我尝试进行以下测试。我在根目录下创建了一个子文件夹,%USERPROFILE%\.vscode\extensions定义package.json如下(来自上面的示例):

{
    "name": "mylang",
    "version": "0.0.1",
    "engines": {
        "vscode": ">=0.9.0-pre.1"
    },
    "publisher": "me",
    "contributes": {
        "languages": [{
            "id": "mylang",
            "aliases": ["MyLang", "mylang"],
            "extensions": [".mylang",".myl"]
        }],
        "grammars": [{
            "language": "mylang",
            "scopeName": "source.mylang",
            "path": "./syntaxes/mylang.tmLanguage"
        }]
    }
}

然后我在其下创建了一个 syntaxes 子文件夹,并包含一个mylang.tmLanguage基于@wozi 在此处给出的示例的文件:How to create a simple custom language colorization to VS Code有一些小的修改只是为了使命名与上述 JSON 一致文件:

<?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>
            <string>myl</string>
        </array>

        <key>name</key>
        <string>mylang file</string>

        <key>patterns</key>
        <array>
            <dict>
                <key>match</key>
                <string>\b(?i:(hint|info|information))\b</string>
                <key>name</key>

                <string>info-token</string>
            </dict>                
            <dict>
                <key>match</key>
                <string>\b(?i:(warning|warn))\b</string>
                <key>name</key>
                <string>warn-token</string>
            </dict>
            <dict>
                <key>match</key>
                <string>\b(?i:(Error|Failure|Fail))\b</string>
                <key>name</key>
                <string>error-token</string>
            </dict>
            <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>                                
        </array>
        <key>uuid</key>
        <string>FF0550E0-3A29-11E3-AA6E-0800200C9A77</string>
    </dict>
</plist>

但是,当我使用以下测试文件 ( test.mylang) 打开 Visual Studio Code (v1.11.2) 时:

2017-04-17 18:38 Hint This should be blue!
2017-04-17 18:38 Warning This should be amber!
2017-04-17 18:38 Fail This should be red!

关键字(提示、警告、失败)没有颜色。我需要做其他事情来指定主题吗?或者我是否需要指定一个新的唯一 UUID(如果需要,我可以自己制作,还是需要以某种方式注册)?

4

1 回答 1

6

运行Developer: Inspect TM scopes命令时,您可以看到正在使用正确的范围:

问题是默认主题中没有与info-token范围关联的颜色(因此是“无主题选择器”)。似乎由于您链接的其他答案,这些范围的名称已更改为包含token.VSCode 1.9.0 的 - 前缀。这在#18839中进行了讨论,使用新名称重新引入这些范围的相关提交是b2aa308

在 VSCode 1.13.0 中,我使用token.info-token,token.warn-token和得到预期的颜色token.error-token

于 2017-06-26T12:24:35.250 回答