Das Dokument wird an onDidChangeTextDocument übergeben. Dies ist, wie ich damit umgehen:
var changeTimeout;
vscode.workspace.onDidChangeTextDocument(function (event) {
if (changeTimeout != null)
clearTimeout(changeTimeout);
changeTimeout = setInterval(function() {
clearTimeout(changeTimeout);
changeTimeout = null;
backend.reparse(event.document.fileName, event.document.getText());
processDiagnostic(event.document);
}, 500);
});
Dies ist, was MS writes in the documentation:
// The content of a text document has changed. This event is emitted
// when the text document first opened or when its content has changed.
documents.onDidChangeContent((change) => {
let diagnostics: Diagnostic[] = [];
let lines = change.document.getText().split(/\r?\n/g);
lines.forEach((line, i) => {
let index = line.indexOf('typescript');
if (index >= 0) {
diagnostics.push({
severity: DiagnosticSeverity.Warning,
range: {
start: { line: i, character: index},
end: { line: i, character: index + 10 }
},
message: `${line.substr(index, 10)} should be spelled TypeScript`,
source: 'ex'
});
}
})
// Send the computed diagnostics to VS Code.
connection.sendDiagnostics({ uri: change.document.uri, diagnostics });
});
so das Dokument (und damit der Text) sollen in der Veranstaltung zur Verfügung.
Sie tun dies in einer Sprache-Server oder in der Client-Erweiterung? – thur
Ah, tut mir leid, ja, das ist eine Client-Erweiterung, kein Sprachserver. Ist es anders dort? –
Ich denke schon, weil ich dieses Event.document nicht erhalten habe .. nur ein params.contentChanges das ist ein Array .. aber ich finde, dass dieses Array mir die Eniry-Datei zurückgibt, aber ich bin mir nicht sicher, ob das das ist richtige Weise, das zu tun. – thur