Files
vscode-extension-samples/lsp-sample
2020-05-07 12:13:14 +02:00
..
2020-03-26 13:54:06 +01:00
2020-05-06 12:14:11 -07:00
2020-03-26 13:54:06 +01:00
2020-03-26 15:38:24 +01:00
2020-03-26 13:54:06 +01:00
2018-06-25 02:14:44 -07:00
2019-05-26 23:32:15 +02:00
2018-12-28 09:21:46 +01:00
2020-05-06 12:14:11 -07:00

LSP Example

Heavily documented sample code for https://code.visualstudio.com/api/language-extensions/language-server-extension-guide

Functionality

This Language Server works for plain text file. It has the following language features:

  • Completions
  • Diagnostics regenerated on each file change or configuration change

It also includes an End-to-End test.

Structure

.
├── client // Language Client
│   ├── src
│   │   ├── test // End to End tests for Language Client / Server
│   │   └── extension.ts // Language Client entry point
├── package.json // The extension manifest.
└── server // Language Server
    └── src
        └── server.ts // Language Server entry point

Running the Sample

  • Run npm install in this folder. This installs all necessary npm modules in both the client and server folder
  • Open VS Code on this folder.
  • Press Ctrl+Shift+B to compile the client and server.
  • Switch to the Debug viewlet.
  • Select Launch Client from the drop down.
  • Run the launch config.
  • If you want to debug the server as well use the launch configuration Attach to Server
  • In the [Extension Development Host] instance of VSCode, open a document in 'plain text' language mode.
    • Type j or t to see Javascript and TypeScript completion.
    • Enter text content such as AAA aaa BBB. The extension will emit diagnostics for all words in all-uppercase.