The Eclipse Desktop IDE provides a convenient development workflow for the Camel Language Server, but other IDEs may be used as well.
-
Fork and clone the repository
-
Install latest Eclipse Java EE from Download Packages page that will have most needed already installed. Alternately, you can get the Eclipse IDE for Java developers and just install Eclipse PDE from marketplace.
-
Once installed use
File > Open Projects from File System...
and point itcamel-language-server
and Eclipse should automatically detect the projects and import it properly. -
If you discover an error on
pom.xml
after import about Tycho, you can use Quick Fix (Ctrl+1) to install the Tycho Maven integration.
Eclipse desktop allows to debug Language Server projects being written in the same workspace. To do that:
- Create a Content type for the file type you want to test:
Windows -> Preferences -> General -> Content types
- Select
Text
- Click
Add child...
and provide configuration. For instance:- name:
Camel K
- File association
*.camelk.*
- name:
- Associate the created Content type to the
Camel Language Server
Launch configurationWindows -> Preferences -> Language Servers
- At the bottom, click on
Add...
- Select the added Content type in the left column (
Camel K
if following example) - Select the launch configuration
Camel Language Server
in the right column underJava Application
- Select the
debug
option in the drop down below the right column - Click
Ok
and thenApply and close
- Open the file you want to test with the
Generic Text Editor
- To be sure that the file opens with the Generic Text Editor, you can right-click on it and then
Open With -> Generic Text Editor
- To be sure that the file opens with the Generic Text Editor, you can right-click on it and then
-
Install Apache Maven
-
This command will build the server:
$ mvn clean verify
- Ensure pom is using only non-snapshot dependencies
- Modify pom version to use a non-snapshot version
- Provide a PR
- Wait that it is reviewed and merged
- A build will start automatically on GitHub Actions
- Ensure build is OK
- Create a tag
- Push the tag to camel-tooling organization repository
- Modify pom version to use an incremented snapshot version to prepare next release iteration
- Provide a PR
As this is an implementation of Language Server Protocol for Apache Camel, it is recommended to start by reading:
- information about the Language Server Protocol (LSP):
- LSP overview (a must)
- LSP specification (can be useful to search for specific parts when needed)
- an important point is that all API is based on position (line, column) in a text file, so the LSP for Apache Camel implementation needs to be able to always provide and understand this information
- information about LSP4J
- LSP4J is a Java implementation of the LSP. This is library used for writing the LSP for Apache Camel
- it is recommended to read at least the getting started
- LSP4J is using Future, the goal is to provide an API which is completely asynchronous for a better User Experience, see Future javadoc and Vogella doc about CompletableFuture and there is also a lot of tutorial on the web
- information about Camel
- see official website
CamelTextDocumentService is the main entry point currently as the current implementation is dealing with a single XML file. The various methods of the CamelTextDocumentService are called by the LSP clients. When clients are implemented correctly, they are called depending on the capabilities declared in CamelLanguageServer.createServerCapabilities().
The metamodel from the Camel Catalog describing the Camel components is represented by the java class ComponentModel. The model describing the Camel URI is in com.github.cameltooling.lsp.internal.instancemodel package. The top-level Camel element is CamelURIInstance.
The model describing the Camel URI is storing the position of each sub-model elements (Camel component name, path parameter, Option parameter with its key and value). The naming tries to be as close as possible as the Apache Camel one. All Camel elements of the model are inheriting from CamelUriElementInstance.
For instance, with the Camel URI "timer:timerName?delay=10s":
- CamelURIInstance represents "timer:timerName?delay=10s"
- CamelComponentURIInstance represents "timer"
- PathParamURIInstance represents "timerName"
- OptionParamURIInstance represents "delay=10s"
- OptionParamKeyURIInstance represents "delay"
- OptionParamValueURIInstance represents "10s"