Skip to content

Language Server Protocol

What is Language Server?


From the Language Server web site: The Language Server Protocol (LSP) is used between the IDE and a language smartness provider (the server) to integrate features like auto complete, go to definition, find all references and alike into the tool

Install Language Servers


Below you may find the installation instructions for the most common Language Servers, select the ones you are interested in and then configure them in CodeLite

clangd is the LSP implementation from the clang for C/C++/Objective-C team. It provide a compiler level completion with an unmatched accuracy. Visit the project home page

All

clangd relies on a file named compile_commands.json or compile_flags.txt. When using CodeLite default C++ workspace CodeLite can generate this file for the current workspace:

  1. From the menu bar: SettingsCode Completion ...
  2. Select the option Generate compile_commands.json file
  3. Build your project

Windows

Install clangd by install the recommended packages as described here

Linux

On Linux machines, you will need to manually install clangd via your package manager. On Ubuntu and Debian it is usually part of the clang-tools package. So to install it, use the below code snippet:

sudo apt-get update
sudo apt-get install clang-tools

Once installed, follow the steps in the manual configuration section

Note

Often, the clang-tools package comes with a version number, e.g. clang-tools-10 Make sure to install the one with the highest number

macOS

On macOS, clangd is provided as part of the llvm formula. To install it (via brew):

brew install llvm

on ARM based macOS, clangd is placed under: /opt/homebrew/opt/llvm/bin/clangd

ctagsd is CodeLite's builtin code completion engine for C/C++ that implements the Language Server Protocol. ctagsd is installed along with CodeLite on all platforms.

CodeLite configures ctagsd for you, but it is disabled by default. To enable it:

PluginsSettingsctagsd

pylsps is installed via pip. For this, you will need to install the following:

  • python 3 installed
  • pip3 installed
pip install python-lsp-server

On Windows / MSYS2, use this command:

pacman -S mingw-w64-clang-x86_64-python mingw-w64-clang-x86_64-python-pip mingw-w64-clang-x86_64-python-ujson
pip install python-lsp-server

Visit the project home page

  • Install node
  • Type:
npm install -g typescript typescript-language-server

If you choose to configure it manually in CodeLite, use this as the command:

typescript-language-server --stdio

rust-analyzer is the recommended LSP for the rust language. To install it, follow these steps:

  • Install rust
  • Open a terminal and type:

    • On macOS and Linux:

      rustup update
      rustup +nightly component add rust-src rust-analyzer-preview
      

    • On Windows, we build it from sources. Open MSYS2 terminal and type:

      pacman -Sy mingw-w64-clang-x86_64-rust mingw-w64-clang-x86_64-rust-src
      

You should now have rust-analyzer installed under rustup local folder, for example, under Linux or macOS, it can be found here:

TARGET=$(rustup target list|grep installed|cut -d" " -f1)
$HOME/.rustup/toolchains/nightly-$TARGET/bin/rust-analyzer

gopls (pronounced "Go Please") is the official LSP for golang

To install it:

go install golang.org/x/tools/gopls@latest


Automatic detection


Once you have installed your favourite Language Servers, its time to tell CodeLite about it:

  • Goto PluginsLanguage ServerSettings
  • Click on the Scan button

Manual configuration


The above instructions are for the most common language servers. However, you can install and configure any server the follows the LSP protocol. You will however, need to do this manually:

  • Install the LSP you want on your computer. You can visit this site to get a complete list of all LSP implementations out there
  • From the main menu, PluginsLanguage ServerSettings...
  • Click on the Add button
  • In the dialogue that opens, fill the mandatory fields:
Field Mandatory Description
Enabled Is this LSP enabled?
Name Provide a descriptive name for this LSP
Remote server - When enabled, the Command is executed on a remote machine
Command The LSP execution command. For example, for clangd, the command can be as simple as /usr/bin/clangd
Working directory - Path to set before running the command
Languages Since CodeLite can have multiple LSP configured, you can associate each LSP with a language. CodeLite will use the proper LSP based on the current file's language. Use the ... button to see a list of supported languages
Connection string Defines the protocol that CodeLite communicates with the LSP. Most of the LSP servers out there supporting the stdio protocol
Display diagnostics - When checked, CodeLite will display little red arrows next to potential code errors

Resolving conflicts


It is allowed to configure multiple language servers for the same coding language (e.g. ctagsd and clangd for C++). But make sure you only have one enabled at at time

CMake clangd / ctagsd


compile_flags.txt & compile_commands.json

clangd and ctagsd are using these two files as instructions for "how to build" any source file. clangd and ctagsd will search for these files from the active file folder and going up to the parent until it finds a match (or it can't go up any more)

In case both files are found on the same directory, compile_flags.txt takes precedence.

When using CodeLite's default C++ workspace CodeLite generate these files for your automatically once the build process is completed

However, when using other workspaces (e.g. the File System Workspace) you need to provide these files (at least one of them) in order for clangd code completion to function.

If you are using cmake as your build system, you can add these two commands in the top level CMakeLists.txt file:

  • At the top of your CMakeLists.txt add this line:
set(CMAKE_EXPORT_COMPILE_COMMANDS ON)
  • Or alternatively, you can pass this variable as part of CMake invocation line:
cmake -DCMAKE_EXPORT_COMPILE_COMMANDS=1 <other arguments here>
  • and somewhere at the bottom of the top level CMakeLists.txt file, add this command:
execute_process(COMMAND ${CMAKE_COMMAND} -E create_symlink ${CMAKE_CURRENT_BINARY_DIR}/compile_commands.json
                ${CMAKE_SOURCE_DIR}/compile_commands.json)

this way, after running cmake, you will get an up-to-date compile_commands.json file for clangd

Generating compile_commands.json for a traditional Makefile project


Use the cc-wrapper utility that comes with CodeLite - see the docs here

Back to top