| bundles | ||
| cm6 | ||
| data | ||
| docs | ||
| scripts | ||
| test | ||
| webapp | ||
| .dockerignore | ||
| .gitignore | ||
| compose.yaml | ||
| LICENSE | ||
| package-lock.json | ||
| package.json | ||
| README.md | ||
| rollup.config.js | ||
Work in progress.
An attempt to write a Language Server Protocol server for and in XQuery 4.0. It uses the BaseX websocket feature.
Demo
- Requires
DockerorPodmanon the local machine. - Clone this repo
- Run
docker compose up -dThe LSP server shall now running on port 3000 (editcompose.yamlto change port) - In a browser navigate to
http://localhost:3000/static/clients/codemirror/to see the CodeMirror 6 demo.
In principle, the LSP can be used in any environment that can make use of a LSP server accessed via a websocket.
LSP Server
webapp/lspThe LSP implementation in XQuery using WebSockets for transport and the JSON-RPC 2.0 API for data format.
Sample html clients
Samples using common browser based code editors are available. The CodeMirror 6 sample is the most functional.
These examples are self contained (no internet access required). Some make use of recent html features, for instance popovertarget
CodeMirror6 https://codemirror.net/
webapp/static/codemirrorA test html page using the CodeMirror6 editor that connects to the BaseX LSP instance
uses
- https://codemirror.net/docs/ref/#lsp-client
- https://github.com/codemirror/legacy-modes/
xquerymode provides browser based syntax highlighting (XQuery 3.1?)
alternative LSP interfaces
Ace Editor
webapp/static/aceA test html page using the Ace editor that connects to the BaseX LSP instance @TODO fix
Uses
Make a websocket server for lsp on port 3000 https://mkslanc.github.io/ace-linters/websocket.html
http://localhost:3000/exampleServer
c1b317e012/packages/demo/websockets-lsp/server/server.ts
I needed set NODE_OPTIONS=--max_old_space_size=8192 for build to complete
Or node --max-old-space-size=8192 node_modules/webpack-dev-serve r/bin/webpack-dev-server.js
Monaco editor
@TODO create https://socket.dev/npm/package/monaco-editor
Server dev notes
State is held in websocket attributes.
| Name | Use |
|---|---|
| initialized | set true after client sends initialized message |
| files | A map whose keys are open uris, values are maps (doctype-> attribute name where doctype is stored |
| file-{uuid} | name of websocket attribute with textDocument |
| parse-{uuid} | name of websocket attribute with parse tree XML |
XQuery 4.0 parser
The ebnf is taken from Gunther Rademacher's rex-parser-generator XQuery-40.ebnf
The script scripts/rex.xq can generate XQuery or Java parser code from this.
The npm package.json script javac can create a jar file from the Java source.
Related links
java -cp org.eclipse.lemminx-uber.jar org.eclipse.lemminx.XMLServerSocketLauncher`