简体   繁体   English

vscode 扩展补全:如何替换原文?

[英]vscode extension completion: how to replace the original text?

const scarlingProvider = vscode.languages.registerCompletionItemProvider(
        'javascript',
        {
            provideCompletionItems(document, position, token, context) {
                const linePrefix = document.lineAt(position).text.substr(0, position.character);
                if (!hasChinese(linePrefix)) {
                    return undefined;
                }
                const reminds = starling.match(linePrefix)
                console.log('reminds: ', reminds);
                return [reminds].map(val => {
                    try {
                        const item = new vscode.CompletionItem(val, vscode.CompletionItemKind.Method)
                        item.insertText = `$t('${val}', '${linePrefix.trim()}')`
                        return item
                    } catch(err) {
                        console.log('err: ', err);
                    }
                })
            }
        },
        ' '

As above, it's a snippet of a completion extension.如上所述,它是完成扩展的一个片段。 I want the selected text to replace the original text instead of inserting that after the original text.我希望所选文本替换原始文本,而不是在原始文本之后插入。 What should I do?我应该怎么办?

You have to specify a range with your completion item.您必须为您的完成项目指定一个范围。 The model can give you the position of the original text for which the provider has been invoked: model 可以为您提供已调用提供程序的原始文本的 position:

const scarlingProvider = vscode.languages.registerCompletionItemProvider(
        'javascript',
        {
            provideCompletionItems(document, position, token, context) {
                const linePrefix = document.lineAt(position).text.substr(0, position.character);
                if (!hasChinese(linePrefix)) {
                    return undefined;
                }

                const info = model.getWordUntilPosition(position);
                const range = {
                    startLineNumber: position.lineNumber,
                    startColumn: info.startColumn - 1,
                    endLineNumber: position.lineNumber,
                    endColumn: info.endColumn,
                };


                const reminds = starling.match(linePrefix)
                console.log('reminds: ', reminds);
                return [reminds].map(val => {
                    try {
                        return {
                            label: "<a label>",
                            kind: CompletionItemKind.Method,
                            range,
                            insertText: `$t('${val}', '${linePrefix.trim()}')`,
                            detail: "<a description>",
                        }
                    } catch(err) {
                        console.log('err: ', err);
                    }
                })
            }
        },
        ' '

声明:本站的技术帖子网页,遵循CC BY-SA 4.0协议,如果您需要转载,请注明本站网址或者原文地址。任何问题请咨询:yoyou2525@163.com.

 
粤ICP备18138465号  © 2020-2024 STACKOOM.COM