From 2b933c644ea693c1b027883f4eb56466d52dbb02 Mon Sep 17 00:00:00 2001
From: azerr
Date: Sat, 2 Dec 2023 14:33:19 +0100
Subject: [PATCH] docs: Getting started documentation
Fixes #24
Signed-off-by: azerr
---
README.md | 18 +-
docs/DeveloperGuide.md | 255 ++++++++++++++++++
docs/UserGuide.md | 12 +
...ings.png => LanguageServerPreferences.png} | Bin
docs/images/MyLanguageServerInLSPConsole.png | Bin 0 -> 11003 bytes
src/main/resources/META-INF/plugin.xml | 21 +-
6 files changed, 295 insertions(+), 11 deletions(-)
create mode 100644 docs/DeveloperGuide.md
create mode 100644 docs/UserGuide.md
rename docs/images/{LanguageServerSettings.png => LanguageServerPreferences.png} (100%)
create mode 100644 docs/images/MyLanguageServerInLSPConsole.png
diff --git a/README.md b/README.md
index c7fd18bff..31c3d1ca1 100644
--- a/README.md
+++ b/README.md
@@ -19,15 +19,21 @@ It currently doesn't provide any useful functionality on its own, but is instead
LSP4IJ provides:
* Language server `extension points` to add any language server:
- * `com.redhat.devtools.lsp4ij.server` extension point to define a language server.
- * `com.redhat.devtools.lsp4ij.languageMapping` to associate an Intellij language with a language server definition.
-* an `LSP Consoles view` to tracks LSP requests, responses and notifications in a console:
+ * [com.redhat.devtools.lsp4ij.server](./docs/DeveloperGuide.md#declare-server-with-extension-point) extension point to define a language server.
+ * [com.redhat.devtools.lsp4ij.languageMapping](./docs/DeveloperGuide.md#declare-language-mapping-with-extension-point) to associate an IntelliJ language with a language server definition.
+* an [LSP Consoles view](./docs/UserGuide.md#lsp-console) to tracks LSP requests, responses and notifications in a console:
-![LSP console](https://github.com/redhat-developer/lsp4ij/blob/HEAD/docs/images/LSPConsole.png?raw=true)
+![LSP console](./docs/images/LSPConsole.png)
-* a `Language Servers settings page` to configure the LSP trace level, the debug port to use to debug language server:
+* a [Language Servers preferences page](./docs/UserGuide.md#language-servers-preferences) to configure the LSP trace level, the debug port to use to debug language server:
+
+![Language Server preferences](./docs/images/LanguageServerPreferences.png)
+
+You can start with :
+
+ * [Developer guide](./docs/DeveloperGuide.md) which explains step by step how to integrate a language server in LSP4J in an external IntelliJ plugin.
+ * [User guide](./docs/UserGuide.md) which explains how to use LSP console and Language server preferences.
-![Language Server settings](https://github.com/redhat-developer/lsp4ij/blob/HEAD/docs/images/LanguageServerSettings.png?raw=true)
## Who is using LSP4IJ?
diff --git a/docs/DeveloperGuide.md b/docs/DeveloperGuide.md
new file mode 100644
index 000000000..547fe5018
--- /dev/null
+++ b/docs/DeveloperGuide.md
@@ -0,0 +1,255 @@
+# Developer guide
+
+This section explains step by step how to add your own LSP language server in your IntelliJ plugin.
+
+## Reference LSP4IJ
+
+### plugin.xml
+
+The first step is to reference LSP4IJ. LSP4IJ uses `com.redhat.devtools.lsp4ij` as plugin Id.
+
+You need [to declare dependency in your plugin.xml](https://plugins.jetbrains.com/docs/intellij/plugin-dependencies.html#3-dependency-declaration-in-pluginxml) like this:
+
+```xml
+
+ ...
+
+ com.redhat.devtools.lsp4ij
+
+ ...
+
+```
+
+### Exclude all LSP4J dependencies
+
+LSP4IJ depends on [Eclipse LSP4J](https://github.com/eclipse-lsp4j/lsp4j) (Java binding for the [Language Server Protocol](https://microsoft.github.io/language-server-protocol) and the [Debug Adapter Protocol](https://microsoft.github.io/debug-adapter-protocol).). It uses a given version of LSPJ and their classes are loaded in the LSP4IJ plugin class loader.
+
+Your IntelliJ Plugin should use `the same LSP4J classes than LSP4IJ` to avoid some `ClassCastException` errors. To do that you need to `exclude all LSP4J dependencies` from your plugin.
+
+Here a sample used in [Quarkus Tools](https://github.com/redhat-developer/intellij-quarkus) in [build.gradle.kts](https://github.com/redhat-developer/intellij-quarkus/blob/main/build.gradle.kts) to exclude LSP4J dependency from the [Qute Language Server](https://github.com/redhat-developer/quarkus-ls/tree/master/qute.ls) which have a dependency to LSP4J:
+
+```
+implementation("com.redhat.microprofile:com.redhat.qute.ls:0.17.0) {
+ exclude("org.eclipse.lsp4j")
+}
+```
+
+## Declare server
+
+
+### StreamConnectionProvider Implementation
+
+You need to implement the [StreamConnectionProvider](https://github.com/redhat-developer/lsp4ij/blob/main/src/main/java/com/redhat/devtools/lsp4ij/server/StreamConnectionProvider.java) API which manages:
+
+ * start of your language server
+ * returns the input/error stream of LSP requests, responses, notifications.
+
+Generally, the language server is started with a process by using a runtime like Java, NodeJS, etc. In this case you need to extend [ProcessStreamConnectionProvider](https://github.com/redhat-developer/lsp4ij/blob/main/src/main/java/com/redhat/devtools/lsp4ij/server/ProcessStreamConnectionProvider.java)
+
+Here a basic sample which starts the `path/to/my/language/server/main.js` language server written in JavaScript with NodeJS runtime "path/to/nodejs/node.exe":
+
+```java
+package my.language.server;
+
+import com.redhat.devtools.lsp4ij.server.ProcessStreamConnectionProvider;
+
+import java.util.Arrays;
+import java.util.List;
+
+public class MyLanguageServer extends ProcessStreamConnectionProvider {
+
+ public MyLanguageServer() {
+ List commands = Arrays.asList("path/to/nodejs/node.exe", "path/to/my/language/server/main.js");
+ super.setCommands(commands);
+ }
+}
+```
+
+If your language server is written in Java, to build the command, you can use [JavaProcessCommandBuilder](https://github.com/redhat-developer/lsp4ij/blob/main/src/main/java/com/redhat/devtools/lsp4ij/server/JavaProcessCommandBuilder.java):
+
+```java
+package my.language.server;
+
+import com.intellij.openapi.project.Project;
+import com.redhat.devtools.lsp4ij.server.JavaProcessCommandBuilder;
+import com.redhat.devtools.lsp4ij.server.ProcessStreamConnectionProvider;
+
+import java.util.Arrays;
+import java.util.List;
+
+public class MyLanguageServer extends ProcessStreamConnectionProvider {
+
+ public MyLanguageServer(Project project) {
+ List commands = new JavaProcessCommandBuilder(project, "myLanguageServerId")
+ .setJar("path/to/my/language/server/main.java")
+ .create();
+ super.setCommands(commands);
+ }
+}
+```
+
+This builder takes care of filling command with Java runtime and generate the command with debug if the settings of the language server `myLanguageServerId` defines a debug port.
+
+You can see a full sample with [QuteServer](https://github.com/redhat-developer/intellij-quarkus/blob/main/src/main/java/com/redhat/devtools/intellij/qute/lsp/QuteServer.java)
+
+### LanguageClientImpl
+
+It is not required but you can override the [LanguageClientImpl](https://github.com/redhat-developer/lsp4ij/blob/main/src/main/java/com/redhat/devtools/lsp4ij/client/LanguageClientImpl.java) to for instance:
+
+ * some IJ listeners when language client is created
+ * override some LSP methods
+
+```java
+package my.language.server;
+
+import com.intellij.openapi.project.Project;
+import com.redhat.devtools.lsp4ij.client.LanguageClientImpl;
+
+public class MyLanguageClient extends LanguageClientImpl {
+ public MyLanguageClient(Project project) {
+ super(project);
+ }
+}
+```
+
+If your language server manages custom LSP requests, it is advised to extend [IndexAwareLanguageClient](https://github.com/redhat-developer/lsp4ij/blob/main/src/main/java/com/redhat/devtools/lsp4ij/client/IndexAwareLanguageClient.java)
+
+You can see a full sample with [QuteLanguageClient](https://github.com/redhat-developer/intellij-quarkus/blob/main/src/main/java/com/redhat/devtools/intellij/qute/lsp/QuteLanguageClient.java)
+
+## Declare server with extension point
+
+The last step is to declare the server in your plugin.xml with `com.redhat.devtools.lsp4ij.server` extension point
+to use your `my.language.server.MyLanguageServer` and `my.language.server.MyLanguageClient`:
+
+```xml
+
+
+
+
+
+
+
+
+
+
+```
+
+Once the declaration is done, your server should appear in the LSP console:
+
+![My LanguageServer in LSP Console](./images/MyLanguageServerInLSPConsole.png)
+
+## Declare language mapping with extension point
+
+Once server is defined, you need to associate an IntelliJ language with the `server` defined by the id attribute
+with `com.redhat.devtools.lsp4ij.languageMapping` extension point.
+
+Here a sample which associates the `XML` language with the `myLanguageServerId` server:
+
+```xml
+
+
+
+
+
+
+
+```
+
+If the language check is not enough, you can implement a [DocumentMatcher](https://github.com/redhat-developer/lsp4ij/blob/main/src/main/java/com/redhat/devtools/lsp4ij/DocumentMatcher.java) to implement some check in Java code.
+For instance our language server could map `Java` as language and you could implement a DocumentMatcher
+to check if the module of the file have some Java class in the classpath.
+
+The DocumentMatcher is executed in a non blocking read action.
+
+A document matcher looks like this:
+
+```java
+package my.language.server;
+
+import com.intellij.openapi.project.Project;
+import com.intellij.openapi.vfs.VirtualFile;
+import com.redhat.devtools.lsp4ij.AbstractDocumentMatcher;
+import org.jetbrains.annotations.NotNull;
+
+public class MyDocumentMatcher extends AbstractDocumentMatcher {
+
+ @Override
+ public boolean match(@NotNull VirtualFile virtualFile, @NotNull Project project) {
+ return true;
+ }
+}
+```
+
+and it must be registered in language mapping with `documentMatcher` attribute:
+
+```xml
+
+
+
+
+
+
+
+```
+
+## Supported LSP features
+
+Here the current supported LSP features:
+
+| LSP support | Implemented with | Action required |
+|---------------------------------|--------------------------------------------|-----------------|
+| textDocument/publishDiagnostics | externalAnnotator | No |
+| textDocument/completion | completion.contributor | No |
+| textDocument/definition | gotoDeclarationHandler | No |
+| textDocument/documentLink | externalAnnotator + gotoDeclarationHandler | No |
+| textDocument/documentHighlight | highlightUsagesHandlerFactory | No |
+| textDocument/hover | lang.documentationProvider | Yes |
+| textDocument/codeLens | codeInsight.inlayProvider | Yes |
+| textDocument/inlayHint | codeInsight.inlayProvider | Yes |
+
+When it is possible, LSP4IJ declare the IJ feature with language any (see Action required with No).
+For instance `textDocument/publishDiagnostics` is managed with `externalAnnotator` in LSP4IJ with empty language to support any language:
+
+```xml
+
+
+```
+
+Some IJ feature cannot use any language, so you need to declare it in your plugin (see Action required with Yes):
+
+ * `textDocument/hover`:
+
+```xml
+
+```
+
+ * `textDocument/codeLens`:
+
+```xml
+
+```
+
+ * `textDocument/inlayHint`:
+
+```xml
+
+```
\ No newline at end of file
diff --git a/docs/UserGuide.md b/docs/UserGuide.md
new file mode 100644
index 000000000..a62de9906
--- /dev/null
+++ b/docs/UserGuide.md
@@ -0,0 +1,12 @@
+# User guide
+
+## LSP console
+
+
+
+## Language Servers preferences
+
+The preference page under `Preferences | Languages & Frameworks | Language Servers` allows power users
+to configure language servers debugging and tracing:
+
+:
\ No newline at end of file
diff --git a/docs/images/LanguageServerSettings.png b/docs/images/LanguageServerPreferences.png
similarity index 100%
rename from docs/images/LanguageServerSettings.png
rename to docs/images/LanguageServerPreferences.png
diff --git a/docs/images/MyLanguageServerInLSPConsole.png b/docs/images/MyLanguageServerInLSPConsole.png
new file mode 100644
index 0000000000000000000000000000000000000000..7286a5c915eebefc5e1872242a36975f625f8ea4
GIT binary patch
literal 11003
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
literal 0
HcmV?d00001
diff --git a/src/main/resources/META-INF/plugin.xml b/src/main/resources/META-INF/plugin.xml
index a82acd686..38b0d21a6 100644
--- a/src/main/resources/META-INF/plugin.xml
+++ b/src/main/resources/META-INF/plugin.xml
@@ -14,7 +14,7 @@
LSP4IJ is a free and open-source Language Server protocol (LSP) client compatible with all flavors of IntelliJ.
+ LSP4IJ is a free and open-source Language Server protocol (LSP) client compatible with all flavors of IntelliJ.
It currently doesn't provide any useful functionality on its own but is instead used as a dependency for other extensions, willing to integrate language servers with IntelliJ products.
@@ -22,13 +22,24 @@
- Language server
extension points
to add any language server:
- com.redhat.devtools.lsp4ij.server
extension point to define a language server.
- com.redhat.devtools.lsp4ij.languageMapping
to associate an IntelliJ language with a language server definition.
+ - com.redhat.devtools.lsp4ij.server extension point to define a language server.
+ - com.redhat.devtools.lsp4ij.languageMapping to associate an IntelliJ language with a language server definition.
- - An
LSP Consoles view
to track LSP requests, responses, and notifications in a console.
- - A
Language Servers settings page
to configure the LSP trace level and the debug port to use to debug the language server.
+ - An LSP Consoles view to track LSP requests, responses, and notifications in a console.
+ - A Language Servers preferences page to configure the LSP trace level and the debug port to use to debug the language server.
+
+ You can start with :
+
+
]]>