Files
vscode-extension-samples/lsp-web-extension-sample
Matt Bierner 774ecdb0ee Bump ts-eslint versions
This fixes a warning about running on an unsupported TypeScript version. Also makes sure we do not lint any `.vscode-test` contents if they are present
2024-11-26 22:59:45 -08:00
..
2024-10-28 16:41:49 -07:00
2024-10-26 17:44:03 -07:00
2021-09-15 23:30:24 +02:00
2021-07-21 18:13:58 +02:00
2021-07-21 18:13:58 +02:00
2024-11-26 22:59:45 -08:00
2024-11-26 22:59:45 -08:00

LSP web extension Example

A LSP server that runs in a web extension

Functionality

This Language Server add color decorators to plain text files.

  • create a plain text file
  • enter text that contains colors in hex format (#rrggbb)
  • color decorators

It also includes an End-to-End test.

Structure

.
├── client // Language Client
│   ├── src
│   │   └── browserClientMain.ts // Language Client entry point
├── package.json // The extension manifest.
└── server // Language Server
    └── src
        └── browserServerMain.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 Run Web Extension from the drop down.
  • Run the launch config.
  • In the [Extension Development Host] instance of VSCode, open a document in 'plain text' language mode.
    • Type #00ff00 or any other color in hex format.
    • color decorators will appear.
  • You can set breakpoints in the client or server code.

You can also run and debug the extension in a browser

  • npm run chrome
  • use browser dev tools to set breakpoints