Quick Start
Editor Plugins
clice implements the Language Server Protocol. Any editor that supports this protocol can theoretically work with clice to provide features like code completion, diagnostics, go-to-definition, and more.
However, beyond the standard protocol, clice also supports some protocol extensions. For better handling of these protocol extensions and better integration with editors, using clice plugins in specific editors is often a better choice. Most of them work out of the box and support clice's protocol extensions.
Visual Studio Code
Vim/Neovim
Others
Other editors don't have available clice plugins yet (contributions welcome!). To use clice in them, please install clice yourself and refer to the specific editor's documentation on how to use a language server.
Installation
If your editor plugin handles clice's download, you can skip this step.
Download Prebuilt Binary
Download clice binary version through the Release page.
Build from Source
Build clice from source yourself. For specific steps, refer to build.
Project Setup
For clice to correctly understand your code (e.g., find header file locations), you need to provide clice with a compile_commands.json file, also known as a compilation database. The compilation database provides compilation options for each source file.
CMake
For build systems using cmake, add the -DCMAKE_EXPORT_COMPILE_COMMANDS=ON option during build, for example:
cmake -B build -DCMAKE_EXPORT_COMPILE_COMMANDS=ONThis will generate a compile_commands.json file in the build directory.
WARNING
Note: This option only works when cmake's generator is set to makefile and ninja. For other generators, this option will be ignored, meaning the compilation database cannot be generated.
Bazel
Bazel has no native support to generate a compilation database. The recommended solution is to use bazel-compile-commands-extractor. After setting it up, you can generate compile_commands.json with:
bazel run @hedron_compile_commands//:refresh_allVisual Studio
Visual Studio (2019 16.1+) can generate a compilation database via CMake integration. Open your project as a CMake project, then configure the generation in CMakeSettings.json:
{
"configurations": [
{
"name": "x64-Debug",
"generator": "Ninja",
"buildRoot": "${projectDir}\\build",
"cmakeCommandArgs": "-DCMAKE_EXPORT_COMPILE_COMMANDS=ON"
}
]
}Alternatively, for MSBuild-based projects (.vcxproj), you can use compiledb-vs or catter to generate the compilation database.
Makefile
For Makefile-based projects, use bear to intercept compilation commands:
bear -- makeThis will generate a compile_commands.json in the current directory. Note that bear requires a clean build to capture all commands — run make clean before bear -- make if needed.
Alternatively, if you use GNU Make, you can use compiledb:
compiledb makeMeson
Meson generates a compilation database automatically during setup:
meson setup buildThe compile_commands.json will be in the build directory.
Xmake
Use one of the following approaches to generate a compilation database.
Command Line
Run the following command to manually generate a compilation database:
xmake project -k compile_commands --lsp=clangd buildCompilation database generated manually doesn't automatically update itself. Re-generate if changes are made to the project.
VSCode Extension
The Xmake official VSCode extension automatically generates the compilation database when xmake.lua is updated. However, it generates the database to the .vscode directory by default. Add this setting in settings.json:
"xmake.compileCommandsDirectory": "build"to explicitly ask the extension to generate the compilation database in build.
Others
For any other build system, you can use catter to generate a compilation database. It captures compilation commands through a fake compiler approach and is designed to work reliably with any build system that invokes a compiler executable.