极速快3_快3电脑版_极速快3电脑版 - 极速快3,快3电脑版,极速快3电脑版提供图书、电影、音乐唱片的推荐、评论和价格比较,以及城市独特的文化生活。

使用Theia——添加语言支持

  • 时间:
  • 浏览:1

上一篇:使用Theia——创建插件

Theia——打上去语言支持

Theia中TextMate的支持

  使用TextMate语法还要为大部分源文件提供精准的着色修饰,真是 这就说 在语法级别上(那么语言四种 的层厚解析)。语义着色还要由语言服务器提供。

  TextMate语法主要有四种 格式:.plist.tmLanguage.json,这四种 Theia都支持。

  更多有关TextMate语法的内容还要查看

这里

  注意:特定语言的语法应该蕴含在该语言的专用扩展包中。@theia/textmate-grammars中只注册了当前那么任何特定扩展包的语言。

打上去新语法

  要提供四种 新语法,通常的做法是在扩展包的根目录下创建一有有有有一个data目录,在其中保存不同的语法。

extension/
    data/
        grammars go here
    lib/
        ...
    src/
        ...
    package.json
    ...

  假如,在package.json文件中声明以下属性,那我新提供的语法还要与源代码和编译的文件一并发布。

"files": [
    "data",
    "lib",
    "src"
  ],

  在扩展包中,亲戚亲戚当你们歌词 还要通过LanguageGrammarDefinitionContribution的contribution point来提供这种 行态。

@injectable()
export class YourContribution implements LanguageGrammarDefinitionContribution {

    readonly id = 'languageId';
    readonly scopeName = 'source.yourLanguage';

    registerTextmateLanguage(registry: TextmateRegisty) {
        registry.registerTextmateGrammarScope(this.scopeName, {
            async getGrammarDefinition() {
                return {
                    format: 'json',
                    content: require('../data/yourGrammar.tmLanguage.json'),
                }
            }
        });
        registry.mapLanguageIdToTextmateGrammar(this.id, this.scopeName);
    }
}

  肯能使用.plist语法,则不也能使用require来直接获取内容,肯能Webpack将返回从服务器获取的文件的名称。这种 情况表下,还要使用下面的模式来获取文件的内容:

@injectable()
export class YourContribution implements LanguageGrammarDefinitionContribution {

    readonly id = 'languageId';
    readonly scopeName = 'source.yourLanguage';

    registerTextmateLanguage(registry: TextmateRegisty) {
        registry.registerTextmateGrammarScope(this.scopeName, {
            async getGrammarDefinition() {
                const response = await fetch(require('../data/yourGrammar.plist'));
                return {
                    format: 'plist',
                    content: await response.text(),
                }
            }
        });
        registry.mapLanguageIdToTextmateGrammar(this.id, this.scopeName);
    }
}

原文地址:https://theia-ide.org/docs/textmate