A LSP text documents manager that helps mapping of textual content.
You may not be able to manage your text documents comfortably when developing an LSP service. There are two reasons why we develop hard.
- Always given a URL variable only, so we need to read the contents of the file ourselves.
- Need map offsets from string index to text dimensional coordinates.
By listening to the notification from the LSP client, lsp-textdocument
can help you automatically manage text documents.
This crate is base on vscode-languageserver-textdocument.
use lsp_textdocument::TextDocuments;
fn main() {
let text_documents = TextDocument::new();
...
let text = text_documents.get_document_content(&url, None);
}
with lsp-server
with tower-lsp
Contact us via issues if you require this with tower-lsp
- The text documents position-encoding only supports
UTF-16