mirror of
https://github.com/MaskRay/ccls.git
synced 2025-08-18 20:52:23 +00:00
C/C++/ObjC language server supporting cross references, hierarchies, completion and semantic highlighting
GCC on illumos generates 32-bit object files by default to maintain backward compatibility, despite 32-bit platforms are no longer supported. This may cause link errors, since most distros seem to supply 64-bit LLVM in their repositories (verified on OpenIndiana and OmniOS). This commit adds an ILLUMOS_USE_M64 option, which is turned on by default, to instruct gcc on illumos to generate 64-bit object files, as this is usually the desired behaviour. |
||
---|---|---|
.github | ||
index_tests | ||
src | ||
third_party | ||
.appveyor.yml | ||
.clang-format | ||
.gitignore | ||
.gitmodules | ||
CMakeLists.txt | ||
LICENSE | ||
README.md |
ccls
ccls, which originates from cquery, is a C/C++/Objective-C language server.
- code completion (with both signature help and snippets)
- definition/references, and other cross references
- cross reference extensions:
$ccls/call
$ccls/inheritance
$ccls/member
$ccls/vars
... - formatting
- hierarchies: call (caller/callee) hierarchy, inheritance (base/derived) hierarchy, member hierarchy
- symbol rename
- document symbols and approximate search of workspace symbol
- hover information
- diagnostics and code actions (clang FixIts)
- semantic highlighting and preprocessor skipped regions
- semantic navigation:
$ccls/navigate
It has a global view of the code base and support a lot of cross reference features, see wiki/FAQ. It starts indexing the whole project (including subprojects if exist) parallelly when you open the first file, while the main thread can serve requests before the indexing is complete. Saving files will incrementally update the index.
>>> Getting started (CLICK HERE) <<<
ccls can index itself (~180MiB RSS when idle, noted on 2018-09-01), FreeBSD, glibc, Linux, LLVM (~1800MiB RSS), musl (~60MiB RSS), ... with decent memory footprint. See wiki/Project-Setup for examples.