scip-go

module
v0.2.6 Latest Latest
Warning

This package is not in the latest version of its module.

Go to latest
Published: May 16, 2026 License: Apache-2.0

README

scip-go

SCIP indexer for Golang.

Quick Start

Installation

This will build and install the latest version of scip-go

go install github.com/scip-code/scip-go/cmd/scip-go@latest

You can confirm it's been installed by running:

scip-go --version

Indexing a Go project

Standard go.mod project

From the root of your project, you can run:

scip-go

If scip-go is unable to determine some project information, you may need to provide some command-line arguments.

scip-go --module-name=NAME --module-version=VERSION

If this doesn't solve the problem, check the rest of the available flags in:

scip-go --help
Other build systems

The other build systems Buck/Bazel/Please/etc are supported via Go Packages Driver Protocol.

Usage:

GOPACKAGESDRIVER=your_driver scip-go

Note: Due to the current protocol design cross-repo navigation will not work.

Common Problems:
  • Unable to navigate to Go standard library.
    • To solve this, you may want to use the --go-version=go1.X.Y flag when indexing and then also index the go versions manually.
    • To index the Go standard library, you'll want to check out https://github.com/golang/go, checkout the tag you want, navigate to the src/ directory, and then run:
      • $ scip-go --go-version=go1.X.Y and then upload that index to your local sourcegraph instance.
      • After you've done this, you should be able to navigate to the standard library.

(NOTE: Projects without a go.mod may experience challenges indexing. See next section for details)

Indexing without shelling to go binary

scip-go by default uses a few different go commands from the command line to gain information about the project and module. To avoid running go directly (perhaps you have some other build system), you will need to supply the following args.

scip-go --module-name="<my modules name here>"

NOTE: The rest of this isn't properly implemented yet. It's on the todo list for scip-go.

Indexing in CI

# Install scip-go
go install github.com/scip-code/scip-go/cmd/scip-go@latest

# Run scip-go
scip-go

# Upload index with any necessary tokens (shown here using GitHub workflow syntax)
src code-intel upload -github-token='${{ secrets.GITHUB_TOKEN }}' -no-progress

Docker

To build a self-contained Docker image with the indexer, use:

nix build .#docker
docker load < result

Development

Run tests

Run all tests:

go test ./...

Update snapshot tests:

go test ./internal/index -update-snapshots

Cutting releases

  1. Land a PR with updated internal/index/version.txt
  2. From the main branch, trigger the release workflow via Actions → release → Run workflow, entering M.N.P as the version.

Contributing

Contributors should follow the Sourcegraph Community Code of Conduct.

Directories

Path Synopsis
cmd
scip-go command
internal
git
implementations/fingerprint
Package fingerprint defines a function to Encode types as strings with the property that identical types have equal string encodings, in most cases.
Package fingerprint defines a function to Encode types as strings with the property that identical types have equal string encodings, in most cases.

Jump to

Keyboard shortcuts

? : This menu
/ : Search site
f or F : Jump to
y or Y : Canonical URL