Code navigation features
Using our integrations, all code navigation features are available everywhere you read code! This includes in browsers and GitHub pull requests.
Popover
Popovers allow you to quickly glance at the type signature and accompanying documentation of a symbol definition without having to context switch to another source file (which may or may not be available while browsing code).
Go to definition
When you click on the 'Go to definition' button in the popover or click on a symbol's name (in the sidebar or code view), you will be navigated directly to the definition of the symbol.
Find references
When you select 'Find references' from the popover, a panel will be shown at the bottom of the page that lists all of the references, definitions and implementations found for both precise and search-based results (from search heuristics).
Dependency navigation
Dependency navigation enables "Find references" and "Go to definition" to show usages across multiple repositories, including transitive dependencies.
For example, the animation below demonstrates how to trigger "Find references" in the repository github.com/Netflix/Hystrix
and navigate to results in the Java standard library (JDK).
The instructions to setup dependency navigation are different depending on what language ecosystem you use.
- Go: Setup auto-indexing.
- Java, Scala, Kotlin: Setup auto-indexing and a JVM dependencies code host.
- JavaScript, TypeScript: Setup auto-indexing and a npm dependencies code host.
Find implementations
If precise code navigation is enabled for your repositories, you can click on “Find Implementations” to navigate to a symbol’s interface definition. If you’re at the interface definition itself, clicking on “Find Implementations” will show all the places where the interface is being implemented, allowing you to explore how it’s being used by other users across repositories. It can also show which interfaces a struct implements.
Symbol search
We use Ctags to index the symbols of a repository on-demand. These symbols are used to implement symbol search, which will match declarations instead of plain-text.
Symbol sidebar
We use Ctags to index the symbols of a repository on-demand. These symbols are also used for the symbol sidebar, which categorizes declarations by type (variable, function, interface, etc). Clicking on a symbol in the sidebar jumps you to the line where it is defined.
Symbol search behavior and performance
Here is the query path for symbol searches:
- Zoekt: if indexed search is enabled and the search is for the tip commit of an indexed branch, then Zoekt will service the query and it should respond quickly. Zoekt indexes the default branch (usually
master
ormain
) and can be configured for multi-branch indexing. The high commit frequency of monorepos reduces the likelihood that Zoekt will be able to respond to symbol searches. Zoekt eagerly indexes by listening to repository updates, whereas the symbols service lazily indexes the commit being searched. - Symbols service with Rockskip enabled: if Rockskip is enabled, it'll search for symbols stored in Postgres. After initial indexing, queries should be resolved quickly.
- Symbols service with an index for the commit: if the symbols service has already indexed this commit (i.e. someone has visited the commit before) then the query should be resolved quickly. Indexes are deleted in LRU fashion to remain under the configured maximum disk usage which defaults to 100GB.
- Symbols service with an index for a different commit: if the symbols service has already indexed a different commit in the same repository, then it will make a copy of the previous index on disk then run ctags on the files that changed between the two commits and update the symbols in the new index. This process takes roughly 20 seconds on a monorepo with 40M LOC and 400K files.
- Symbols service without any indexes (cold start): if the symbols service has never seen this repository before, then it needs to run ctags on all symbols and construct the index from scratch. This process takes roughly 20 minutes on a monorepo with 40M LOC and 400K files.
Once the symbols service has built an index for a commit, here's the query performance:
- Exact matches
^foo$
are optimized to use an index - Prefix matches
^foo
are optimized to use an index - General regex queries
foo.*bar
are optimized to use an index when using Rockskip, otherwise the default implementation needs to scan every symbol - Path filtering
file:^cmd/
helps narrow the search space
Search-based code navigation uses exact matches ^foo$
and the symbols sidebar uses prefix matches on paths file:^cmd/
to respond quickly.
Perform an Action
Code Search allows you to harness the power of Search and quickly find, discover, and understand code. However, the end result isn't always to view the results of a search query. Code Search empowers you to perform an action given a set of results.
When browsing code, you can perform the following actions:
- Ask Cody
Cody is a free and open-core AI coding assistant that writes, fixes, and maintains your code and is available on Sourcegraph. It allows you to ask natural language questions about your code and receive intelligent suggestions and explanations.
When browsing code on Sourcegraph, you can ask Cody a question by clicking the Ask Cody button above the file you are viewing. This will open a chat interface where you can have a conversation with Cody about the code you are viewing.
Having Cody integrated directly into Sourcegraph code search makes it fast and easy to get AI-powered insights as you explore code.
- Open in Editor
When viewing a file in Sourcegraph, you can open it in your editor of choice to edit the file. This allows you to seamlessly transition from browsing code in Sourcegraph to editing code in your preferred code editor.
When you click the Open in Editor button, Sourcegraph will detect which editor you have configured and open the file in a new tab in that editor.
If you have not configured a default editor, Sourcegraph will prompt you to select an editor before opening the file.
You can read more about this here.
- View History
The View History action allows you to see the full commit history for a file directly in Sourcegraph.
When you click this button, a sidebar will open showing every commit that touched the file, ordered chronologically from newest to oldest.
For each commit, you can see:
- The commit message
- The author
- The date
- The commit SHA
You can click on any commit to view the full diff and see exactly what changed in that particular version of the file.
Exploring the history of a file helps you understand how it evolved over time and why certain changes were made. This additional context can be invaluable when trying to modify or debug code.
The file history integrates tightly with other Sourcegraph navigation features. You can seamlessly transition from browsing history to blaming lines or searching for references.
- Blame
The Blame action shows annotation on each line of a file indicating the last commit that modified the line and who the author was.
When you click this button on a file, blame information will be displayed inline:
This allows you to easily see the history of every line, without having to explore the full file history. Blame tells you:
- The commit that last modified each line
- The author who made the change
- The commit message
- The timestamp of when it was changed
Using blame makes it easy to answer questions like:
- Who wrote this line of code originally?
- When was this method added?
- What changes were made in this commit?
You can click on any commit in the blame view to explore that snapshot of the file and see the full diff.
Blame data is essential when modifying or debugging existing code in a shared codebase. It helps identify who to talk to when you have questions about particular sections of code.
- Open in Code host
The Open in CodeHost button allows you to quickly view the file in its native code host.
When you click this button, the file will open in a new browser tab taking you directly to that file on the code host website.
For example, if you are viewing a file from a GitHub repository in Sourcegraph, clicking Open in CodeHost will open GitHub.com
in a new tab with that file displayed.
- Copy Link
The Copy Link action allows you to easily copy a permanent link to the exact line range you are viewing in Sourcegraph.
When you click this button, the link is copied to your clipboard. You can then paste the link in any text field or document.
- Raw download
The Raw download action allows you to download the raw file contents displayed in Sourcegraph.
When viewing code, click the Raw download button to save the file to your machine.
- Line Wrapping
The Line Wrap toggle allows you to wrap long lines that extend past the width of the code viewer.
When enabled, any line longer than the window width will wrap to the next line, similar to text in a document.
This makes it easier to read code snippets with very long lines without having to scroll horizontally.
-
When disabled (default), long lines will extend past the edge of the window, requiring horizontal scrolling to see the full line.
-
When enabled, lines will break to the next line before hitting the window edge.
Toggling line wrapping on and off helps optimize code readability depending on personal preference.
Wrapped lines are visually indicated with a faint vertical line connecting the split sections. Hovering also reveals the full continuous line.