C/C++/ObjC language server supporting cross references, hierarchies, completion and semantic highlighting
Go to file
2019-10-24 01:01:20 -07:00
ci Use clang_File_tryGetRealPathName 2019-10-23 21:56:50 -07:00
clang_archive_hashes clang+llvm-6.0.0-x86_64-linux-gnu-ubuntu-14.04.tar.xz.SHA256 -> 16.04 2019-10-23 21:56:51 -07:00
cmake Remove libclang 2019-10-24 01:01:20 -07:00
index_tests Fix diagnostics on MacOS and duplicated bases. 2019-10-24 01:01:20 -07:00
src Fix diagnostics on MacOS and duplicated bases. 2019-10-24 01:01:20 -07:00
third_party Remove submodule doctest 2019-10-24 01:01:20 -07:00
.clang-format First draft: replace libclang indexer with clangIndex 2019-10-24 00:53:16 -07:00
.gitignore . 2019-10-23 21:56:50 -07:00
.gitmodules Remove submodule doctest 2019-10-24 01:01:20 -07:00
CMakeLists.txt Misc. 2019-10-24 01:01:20 -07:00
README.md links 2019-10-24 01:01:20 -07:00

ccls

Telegram Gitter

ccls, which originates from cquery, is a C/C++/Objective-C language server.

It makes use of C++17 features, has less third-party dependencies and slimmed-down code base. Cross reference features are strenghened, (see wiki/FAQ. It currently uses libclang to index C++ code but will switch to Clang C++ API. Refactoring and formatting are non-goals as they can be provided by clang-format, clang-include-fixer and other Clang based tools.

The comparison with cquery as noted on 2018-07-15:

cquery ccls
third_party more fewer
C++ C++14 C++17
clang API libclang (C) clang/llvm C++
Filesystem AbsolutePath + custom routines llvm/Support
index libclang clangIndex, some enhancement
pipeline index merge+id remapping simpler and more robust

cquery has system include path detection (through running the compiler driver) while ccls uses clangDriver.

>>> Getting started (CLICK HERE) <<<