diff --git a/.github/workflows/main.yml b/.github/workflows/build.yml
similarity index 98%
rename from .github/workflows/main.yml
rename to .github/workflows/build.yml
index b3114cfd..129f4e15 100644
--- a/.github/workflows/main.yml
+++ b/.github/workflows/build.yml
@@ -1,4 +1,4 @@
-name: Java CI
+name: Build
on: [push, pull_request]
diff --git a/README.md b/README.md
index 194e9431..bcd17745 100644
--- a/README.md
+++ b/README.md
@@ -1,50 +1,54 @@
-# [LSP4IntelliJ](#sp4intellij) - Language Server Protocol Support for the Jetbrains Plugins
+# [LSP4IntelliJ](#lsp4intellij) - Language Server Protocol Support for JetBrains Plugins
-[data:image/s3,"s3://crabby-images/d038c/d038ca46f405cc042eca2e2228d2ae915f4fa44e" alt="Build Status"](https://travis-ci.com/ballerina-platform/lsp4intellij)
-[data:image/s3,"s3://crabby-images/651ec/651ec86d251203636d379b2cfdfe003192a4f7fb" alt=""](https://jitpack.io/#ballerina-platform/lsp4intellij)
-[data:image/s3,"s3://crabby-images/d8476/d84760294de44407f8d8b90b41a380220563a91a" alt="GitHub last commit"](https://github.com/ballerina-platform/lsp4intellij/commits/master)
+[data:image/s3,"s3://crabby-images/10aec/10aec2174a54ea88bcf12211385f28c575acc1e4" alt="Build status"](https://github.com/ballerina-platform/lsp4intellij/actions/workflows/build.yml)
+[data:image/s3,"s3://crabby-images/651ec/651ec86d251203636d379b2cfdfe003192a4f7fb" alt=""](https://jitpack.io/#ballerina-platform/lsp4intellij)
+[data:image/s3,"s3://crabby-images/d8476/d84760294de44407f8d8b90b41a380220563a91a" alt="GitHub last commit"](https://github.com/ballerina-platform/lsp4intellij/commits/master)
[data:image/s3,"s3://crabby-images/6b474/6b474fd09964f8c0ddcdb2ac24cdfc0e734ae8da" alt="Gitter"](https://gitter.im/ballerina-platform-lsp4intellij/community?utm_source=badge&utm_medium=badge&utm_campaign=pr-badge)
-**Lsp4IntelliJ** is a client library, which provides language server support for IntelliJ IDEA and other Jetbrains IDEs.
+**LSP4IntelliJ** is a client library that enables Language Server Protocol (LSP) support for IntelliJ IDEA and other JetBrains IDEs.
-It is designed to be used with any IntelliJ plugin as its language server client to get the features that are based on the language server.
+Designed for plugin developers, it facilitates integration with LSP-based features and supports language-specific extensions via the [JSON-RPC](https://en.wikipedia.org/wiki/JSON-RPC) protocol.
-Also, it allows the plugin developers to use language-specific language server protocol extensions via the [JSON-RPC](https://en.wikipedia.org/wiki/JSON-RPC)
-protocol.
+---
## Table of Contents
-- [**How To Use**](#how-to-use)
-- [**Features**](#features)
- - [Code Completion](#code-completion)
- - [Code Formatting](#code-formatting)
+
+- [How to Use](#how-to-use)
+- [Features](#features)
+ - [Code Completion](#code-completion-with-code-snippet-support)
+ - [Code Formatting](#code-formatting)
- [Diagnostics](#diagnostics)
- [Code Actions](#code-actions)
- [Goto Definition](#go-to-definition)
- - [Go to References / Find Usages](#goto-references-/-find-usages)
+ - [Goto References / Find Usages](#goto-references--find-usages)
- [Hover Support](#hover-support)
- [Workspace Symbols](#workspace-symbols)
- [Renaming Support](#renaming-support)
-- [**User API**](#user-api)
+- [User API](#user-api)
- [Timeouts](#timeouts)
-- [**License**](#license)
-- [**Inspiration**](#inspiration)
-- [**Useful Links**](#useful-links)
+- [License](#license)
+- [Inspiration](#inspiration)
+- [Useful Links](#useful-links)
+
+---
+## How to use
-## How to use
+Follow the below steps to integrate `LSP4IntelliJ` into your custom language plugin.
-Follow the steps below to use `Lsp4IntelliJ` in your custom language plugin.
+### 1. Add the `lsp4intellij` dependency
+Include `lsp4intellij` in your project's build file. Instructions for popular build tools are available at [jitpack/lsp4intellij](https://jitpack.io/#ballerina-platform/lsp4intellij).
-### 1. Add the `lsp4intellij` dependency in the build file of the project.
+Supported build tools:
+- Gradle
+- Maven
+- SBT
-For instructions on adding **Lsp4IntelliJ** as a dependency when using the below build tools, go to **[jitpack/lsp4intellij](https://jitpack.io/#ballerina-platform/lsp4intellij)**.
- - gradle
- - maven
- - sbt
+> **Info:** Maven Central publishing is a work in progress. Support for Maven Central will be available soon.
->**Info:** - The Maven publishing process is currently WIP. Thus, the possibility to add LSP4IntelliJ as a dependency will be available soon in the Maven central.
+### 2. Add a `plugin.xml` file
+Define the required configurations in your `plugin.xml` file.
-### 2. Add a plugin.xml file
deprecated "components"-based setup
1. Add `IntellijLanguageClient` as an application component.
@@ -117,26 +121,22 @@ For instructions on adding **Lsp4IntelliJ** as a dependency when using the below
> **Note:** You do not need any additional configurations for the other features.
-Copy the example plugin.xml [here](resources/plugin.xml.example) and place it under `src/resources/META-INF` in your plugin and adjust it to your needs.
-
-### 3. Add a preloading activity to configure LSP
+Copy the example `plugin.xml` file from [resources/plugin.xml.example](resources/plugin.xml.example), place it under `src/resources/META-INF`, and adjust it as needed.
-Implement a preloading activity in your plugin as shown below.
+### 3. Configure preloading activity
->**Tip:** For other options you can use instead of implementing a preloading activity, go to [InteliJ Plugin initialization on startup](https://www.plugin-dev.com/intellij/general/plugin-initial-load/)
-to)
-
-Example:
+Add a preloading activity to initialize and configure LSP support:
```java
public class BallerinaPreloadingActivity extends PreloadingActivity {
+ @Override
public void preload(ProgressIndicator indicator) {
IntellijLanguageClient.addServerDefinition(new RawCommandServerDefinition("bal", new String[]{"path/to/launcher-script.sh"}));
}
}
```
-With plugin.xml containing;
+Update your `plugin.xml` to include the preloading activity:
```xml
@@ -145,101 +145,96 @@ With plugin.xml containing;
```
-If you have connected to your language server successfully, you will see a green icon at the bottom-right side of your
-IDE when opening a file that has a registered file extension as shown below.
+>**Tip:** For other options you can use instead of implementing a preloading activity, go to [InteliJ Plugin initialization on startup](https://www.plugin-dev.com/intellij/general/plugin-initial-load/)
-#### Alternative ways to connect to a language server
-Aside RawCommandServerDefinition there are several classes implementing [LanguageServerDefinition](src/main/java/org/wso2/lsp4intellij/client/languageserver/serverdefinition/LanguageServerDefinition.java).
+### 4. Confirm language server connection
-You can use the following concrete class:
+After successfully connecting to the language server, a green icon will appear in the bottom-right corner of your IDE. Clicking on the icon will display connection details and timeouts.
-- **RawCommandServerDefinition(string fileExtension, string[] command)**
+#### Alternative ways to connect to a language server
- This definition can be used to start a language server using a command.
+In addition to `RawCommandServerDefinition`, several classes implement [LanguageServerDefinition](src/main/java/org/wso2/lsp4intellij/client/languageserver/serverdefinition/LanguageServerDefinition.java), allowing you to connect to a language server in different ways. Below are the available options:
- * You can specify multiple extensions for a server by separating them with a comma (e.g., "ts,js").
+##### 1. RawCommandServerDefinition
- * If you want to bind your language server definition only with a specific set of files, you can use that
- specific file pattern as a regex expression instead of binding with the file extension (e.g., "application*.properties").
+You can specify multiple extensions for a server by separating them with a comma (e.g., "ts,js").
- Examples:
+If you want to bind your language server definition only with a specific set of files, you can use that
+specific file pattern as a regex expression instead of binding with the file extension (e.g., "application*.properties").
- Ballerina Language Server
- ```java
- new RawCommandServerDefinition("bal", new String[]{"path/to/launcher-script.sh"});
- ```
+**Example Usage:**
- BSL Language Server
- ```java
- String[] command = new String[]{"java","-jar","path/to/language-server.jar"};
- new RawCommandServerDefinition("bsl,os",command);
- ```
+```java
+new RawCommandServerDefinition("bal", new String[]{"path/to/launcher-script.sh"});
+```
+
+```java
+String[] command = new String[]{"java", "-jar", "path/to/language-server.jar"};
+new RawCommandServerDefinition("bsl,os", command);
+```
-- **ProcessBuilderServerDefinition(string fileExtension, string[] command)**
+##### 2. ProcessBuilderServerDefinition
- This definition is an extended form of the **RawCommandServerDefinition**, which accepts
- `java.lang.ProcessBuilder` instances so that the users will have more controllability over the language
- server
- process to be created.
+This definition is an extended form of the **RawCommandServerDefinition**, which accepts
+`java.lang.ProcessBuilder` instances so that the users will have more controllability over the language
+server
+process to be created.
- * You can specify multiple extensions for a server by separating them with a comma (e.g., "ts,js").
+You can specify multiple extensions for a server by separating them with a comma (e.g., "ts,js").
- * If you want to bind your language server definition only with a specific set of files, you can use that
+If you want to bind your language server definition only with a specific set of files, you can use that
specific file pattern as a regex expression instead of binding with the file extension (e.g., "application*.properties").
- Examples:
-
- Ballerina Language Server
- ```java
- ProcessBuilder process = new ProcessBuilder("path/to/launcher-script.sh");
- new ProcessBuilderServerDefinition("bal", process);
- ```
+**Example Usage:**
- BSL Language Server
- ```java
- ProcessBuilder process = new ProcessBuilder("java","-jar","path/to/language-server.jar");
- new ProcessBuilderServerDefinition("bsl,os", process);
- ```
+```java
+ProcessBuilder process = new ProcessBuilder("path/to/launcher-script.sh");
+new ProcessBuilderServerDefinition("bal", process);
+```
-- **Custom Initialization Params**
+```java
+ProcessBuilder process = new ProcessBuilder("java", "-jar", "path/to/language-server.jar");
+new ProcessBuilderServerDefinition("bsl,os", process);
+```
- If your LSP server needs some custom initialization options when connecting, you can define a class that extends `ProcessBuilderServerDefinition` or `RawCommandServerDefinition`, and then override the `customizeInitializeParams` method to modify any property of the `InitializeParams`.
+#### Custom initialization parameters
- Here's an example:
+If your language server requires custom initialization options, you can extend `ProcessBuilderServerDefinition` or `RawCommandServerDefinition` and override the `customizeInitializeParams` method to modify the initialization parameters.
- ```java
- public class MyServerDefinition extends ProcessBuilderServerDefinition {
- public MyServerDefinition(String ext, ProcessBuilder process) {
- super(ext, process);
- }
+```java
+public class MyServerDefinition extends ProcessBuilderServerDefinition {
+ public MyServerDefinition(String ext, ProcessBuilder process) {
+ super(ext, process);
+ }
- @Override
- public void customizeInitializeParams(InitializeParams params) {
- params.clientInfo = new ClientInfo("MyName", "MyVersion");
- }
- }
- ```
+ @Override
+ public void customizeInitializeParams(InitializeParams params) {
+ params.clientInfo = new ClientInfo("MyName", "MyVersion");
+ }
+}
+```
- Finally, assign your class as a ServerDefinition:
+Finally, assign your class as a ServerDefinition:
- ```java
- ProcessBuilder process = new ProcessBuilder("path/to/launcher-script.sh");
- IntellijLanguageClient.addServerDefinition(new MyServerDefinition("xxx", processBuilder));
- ```
+```java
+ProcessBuilder process = new ProcessBuilder("path/to/launcher-script.sh");
+IntellijLanguageClient.addServerDefinition(new MyServerDefinition("xxx", processBuilder));
+```
You can refer to [#311](https://github.com/ballerina-platform/lsp4intellij/pull/311) for more details.
-> **Note:** All of the above implementations will use server stdin/stdout to communicate.
+> **Note:** All implementations use stdin/stdout for server communication.
data:image/s3,"s3://crabby-images/1e5bf/1e5bf45bc1f2063db626ffc9308e3d679f743c40" alt=""
->**Tip:** You can also click on the icon to see the connected files and the timeouts.
+>**Tip:** A green icon in the IDE's bottom-right corner indicates successful connection to the language server. Clicking on the icon will display connection details and timeouts.
data:image/s3,"s3://crabby-images/04042/04042c74b6750be3531dd4a5144bb36ae57745e2" alt=""
+---
-## Features
+## Features
#### Code Completion (with code snippet support)
Press the `CTRL+SPACE` keys to see the completion items list, which depends on your cursor position.(Code completion items
@@ -253,14 +248,13 @@ snippets with the default values.
data:image/s3,"s3://crabby-images/3e9e9/3e9e9e6ce2ae89f9be4a8c5fcca86248171e9a40" alt=""
-
-#### Code Formatting
+#### Code Formatting
Navigate to **Code->Reformat Code** and you will get a dialog to choose whether to format the whole file or the
selected range.
data:image/s3,"s3://crabby-images/285db/285db18d46e048ccce21d6e836ec7fdba5443554" alt=""
-#### Diagnostics
+#### Diagnostics
To see diagnostics (errors, warnings etc.), hover over them to view the message.
data:image/s3,"s3://crabby-images/3a135/3a135d0bd214015768fc838c4079ff7e2df6a2da" alt=""
@@ -298,29 +292,30 @@ below.
data:image/s3,"s3://crabby-images/5d9d4/5d9d455e22cd6239a80cefd8574413df08e50811" alt=""
> **Note** - Above features are currently tested only with IntelliJ IDEA and
-the [Ballerina Language Server](https://github.com/ballerina-platform/ballerina-lang/tree/master/language-server).
+> the [Ballerina Language Server](https://github.com/ballerina-platform/ballerina-lang/tree/master/language-server).
- **WIP Features**
- - Signature Help
+**WIP Features**
+- Signature Help
+---
-## User API
+## User API
### Timeouts
The Lsp4IntelliJ language client has default timeout values for LSP-based requests as shown below.
-| Type | Default timeout value(in milliseconds)|
-|----------|:-------------------------------------:|
-| Code Actions | 2000 |
-| Completion | 1000 |
-| Goto Definition | 2000 |
-| Execute Command | 2000 |
-| Formatting | 2000 |
-| Hover Support | 2000 |
-| Initialization | 10000 |
-| References | 2000 |
-| Shutdown | 5000 |
-| WillSave | 2000 |
+| Type | Default timeout value(in milliseconds) |
+|-----------------|:--------------------------------------:|
+| Code Actions | 2000 |
+| Completion | 1000 |
+| Goto Definition | 2000 |
+| Execute Command | 2000 |
+| Formatting | 2000 |
+| Hover Support | 2000 |
+| Initialization | 10000 |
+| References | 2000 |
+| Shutdown | 5000 |
+| WillSave | 2000 |
The LspIntelliJ language client provides following methods related to timeout configurations.
@@ -356,19 +351,27 @@ The LspIntelliJ language client provides following methods related to timeout co
IntellijLanguageClient.setTimeout(Timeouts.INIT, 15000);
```
+---
## License
The LSP4Intellij code is distributed under the [Apache license 2.0](LICENSE).
-
+
## Inspiration
-`Lsp4IntelliJ` is heavily inspired by the [intellij-lsp](https://github.com/gtache/intellij-lsp) plugin community.
+`Lsp4IntelliJ` is heavily inspired by the [intellij-lsp](https://github.com/gtache/intellij-lsp) plugin community.
Credits should go to the original author for his astounding work.
-# Useful Links
+## Contributors
+
+A huge thanks to all the amazing contributors! 🚀
+
+
+
+
+## Useful links
- [langserver.org](https://langserver.org/)
- [Language Server Protocol Specification](https://microsoft.github.io/language-server-protocol/specification)