gpt4 book ai didi

visual-studio-code - 可以扩展 Visual Studio Code 中的语言吗?

转载 作者:行者123 更新时间:2023-12-04 21:04:51 26 4
gpt4 key购买 nike

场景

我有描述要执行的一系列任务的 JSON 文件,其中每个任务都可以引用 JSON 文件中的其他任务和对象。

{
"tasks": [
{ "id": "first", "action": "doSomething()", "result": {} },
{ "id": "second", "action": "doSomething(${id:first.result})", "result": {} },
]
}

我希望在 JSON 中的字符串中同时拥有 JSON 模式验证和自定义语言文本效果,例如关键字着色,甚至“转到定义”支持。

我能做什么

我可以创建一个扩展名,为文件扩展名“*.foo.json”指定一个 JSON 模式。如果 vscode 将文件识别为 JSON 文件,这将在编辑器中提供模式验证和代码完成。

我还可以在“*.foo.json”文件的扩展名中创建一种新的“foo”语言,该文件在 JSON 字符串中具有自定义关键字着色。为此,我创建了一个从 JSON.tmLanguage.json 复制的 TextMate (*.tmLanguage.json) 文件,然后修改“stringcontent”定义。

问题

问题是模式验证和提示仅在我在状态栏中选择“JSON”作为文件类型时才有效,而自定义文本着色仅在我在状态栏中选择“foo”作为文件类型时才有效。

有没有办法同时拥有两者?我可以以某种方式扩展 vscode 中的 JSON 语言处理吗?

最佳答案

与一些 help from the vscode team ,下面的代码使事情正常工作。

Syntax highlighting within a JSON string literal

包.json

  ...
"activationEvents": [
"onLanguage:json",
"onLanguage:jsonc"
],
"main": "./src/extension",
"dependencies": {
"jsonc": "^0.1.0",
"jsonc-parser": "^1.0.0",
"vscode-nls": "^3.2.1"
},
...

源代码/扩展.js

'use strict';

const path = require( 'path' );
const vscode = require( 'vscode' );
const { getLocation, visit, parse, ParseError, ParseErrorCode } = require( 'jsonc-parser' );

module.exports = {
activate
};

let pendingFooJsonDecoration;

const decoration = vscode.window.createTextEditorDecorationType( {
color: '#04f1f9' // something like cyan
} );

// wire up *.foo.json decorations
function activate ( context /* vscode.ExtensionContext */) {

// decorate when changing the active editor editor
context.subscriptions.push( vscode.window.onDidChangeActiveTextEditor( editor => updateFooJsonDecorations( editor ), null, context.subscriptions ) );

// decorate when the document changes
context.subscriptions.push( vscode.workspace.onDidChangeTextDocument( event => {
if ( vscode.window.activeTextEditor && event.document === vscode.window.activeTextEditor.document ) {
if ( pendingFooJsonDecoration ) {
clearTimeout( pendingFooJsonDecoration );
}
pendingFooJsonDecoration = setTimeout( () => updateFooJsonDecorations( vscode.window.activeTextEditor ), 1000);
}
}, null, context.subscriptions ) );

// decorate the active editor now
updateFooJsonDecorations( vscode.window.activeTextEditor );

// decorate when then cursor moves
context.subscriptions.push( new EditorEventHandler() );
}

const substitutionRegex = /\$\{[\w\:\.]+\}/g;
function updateFooJsonDecorations ( editor /* vscode.TextEditor */ ) {
if ( !editor || !path.basename( editor.document.fileName ).endsWith( '.foo.json' ) ) {
return;
}

const ranges /* vscode.Range[] */ = [];
visit( editor.document.getText(), {
onLiteralValue: ( value, offset, length ) => {
const matches = [];
let match;
while ( ( match = substitutionRegex.exec( value ) ) !== null) {
matches.push( match );
const start = offset + match.index + 1;
const end = match.index + 1 + offset + match[ 0 ].length;

ranges.push( new vscode.Range( editor.document.positionAt( start ), editor.document.positionAt( end ) ) );
}
}
});

editor.setDecorations( decoration, ranges );
}

class EditorEventHandler {

constructor () {
let subscriptions /*: Disposable[] */ = [];
vscode.window.onDidChangeTextEditorSelection( ( e /* TextEditorSelectionChangeEvent */ ) => {
if ( e.textEditor === vscode.window.activeTextEditor) {
updateFooJsonDecorations( e.textEditor );
}
}, this, subscriptions );
this._disposable = vscode.Disposable.from( ...subscriptions );
}

dispose () {
this._disposable.dispose();
}
}

关于visual-studio-code - 可以扩展 Visual Studio Code 中的语言吗?,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/48723181/

26 4 0
Copyright 2021 - 2024 cfsdn All Rights Reserved 蜀ICP备2022000587号
广告合作:1813099741@qq.com 6ren.com