SCIP Code Intelligence Protocol
SCIP (pronunciation: "skip") is a language-agnostic protocol
for indexing source code,
which can be used to power code navigation functionality
such as Go to definition, Find references, and Find implementations.
This repository includes:
- A protobuf schema for SCIP.
- Rich Go and Rust bindings for SCIP: These include many utility functions
to help build tooling on top of SCIP.
- Auto-generated bindings for TypeScript and Haskell.
- The
scip
CLI, which makes SCIP indexes
a breeze to work with.
If you're interested in better understanding the motivation behind SCIP,
check out the announcement blog post.
If you're interested in writing a new indexer that emits SCIP,
check out our documentation on
how to write an indexer.
Also, check out the Debugging section in the Development docs.
If you're interested in consuming SCIP data,
you can either use one of the provided language bindings,
or generate code for the SCIP protobuf schema
using the protobuf toolchain for your language ecosystem.
Also, check out the Debugging section in the Development docs.
Tools using SCIP
Several indexers currently emit SCIP data:
For more details about indexers, including LSIF-based indexers,
see the Sourcegraph documentation.
Other tools which use SCIP include the Sourcegraph CLI,
and the SCIP CLI in this repo.
Installing the scip
CLI
You can find binaries for the scip
CLI tool here.
You can also compile a binary locally using:
git clone https://github.com/sourcegraph/scip.git --depth=1
cd scip
go build ./cmd/scip
You can consult the CLI reference or --help
for usage information.
Contributing
We welcome questions, suggestions as well as code and docs contributions.
For submitting contributions, check out Development.md
to better understand project structure and common workflows.
Contributors should abide by the Sourcegraph Code of Conduct.