CTags
CTags support for Sublime Text
Details
Installs
- Total 305K
- Win 179K
- Mac 70K
- Linux 57K
| Nov 6 | Nov 5 | Nov 4 | Nov 3 | Nov 2 | Nov 1 | Oct 31 | Oct 30 | Oct 29 | Oct 28 | Oct 27 | Oct 26 | Oct 25 | Oct 24 | Oct 23 | Oct 22 | Oct 21 | Oct 20 | Oct 19 | Oct 18 | Oct 17 | Oct 16 | Oct 15 | Oct 14 | Oct 13 | Oct 12 | Oct 11 | Oct 10 | Oct 9 | Oct 8 | Oct 7 | Oct 6 | Oct 5 | Oct 4 | Oct 3 | Oct 2 | Oct 1 | Sep 30 | Sep 29 | Sep 28 | Sep 27 | Sep 26 | Sep 25 | Sep 24 | Sep 23 | Sep 22 | |
|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|
| Windows | 6 | 5 | 12 | 6 | 3 | 5 | 14 | 10 | 9 | 10 | 1 | 1 | 1 | 2 | 5 | 12 | 0 | 5 | 3 | 3 | 4 | 2 | 6 | 2 | 6 | 1 | 5 | 2 | 3 | 3 | 4 | 0 | 0 | 3 | 2 | 1 | 2 | 4 | 0 | 8 | 2 | 4 | 8 | 6 | 3 | 3 |
| Mac | 2 | 1 | 2 | 3 | 1 | 0 | 1 | 1 | 0 | 1 | 1 | 0 | 1 | 0 | 1 | 0 | 2 | 0 | 0 | 3 | 1 | 0 | 2 | 1 | 0 | 0 | 3 | 1 | 2 | 2 | 1 | 1 | 0 | 2 | 0 | 1 | 2 | 2 | 2 | 1 | 0 | 1 | 0 | 2 | 1 | 1 |
| Linux | 2 | 1 | 1 | 3 | 0 | 1 | 5 | 1 | 2 | 1 | 0 | 0 | 0 | 1 | 2 | 0 | 0 | 0 | 2 | 0 | 0 | 0 | 2 | 0 | 1 | 1 | 1 | 0 | 1 | 1 | 1 | 1 | 1 | 1 | 0 | 1 | 1 | 1 | 1 | 0 | 1 | 1 | 0 | 1 | 1 | 0 |
Readme
- Source
- raw.githubusercontent.com
CTags
This Sublime Text package provides support for working with tags generated by Exuberant CTags or Universal CTags.
ctags command is searched for on the system PATH. It works by doing a binary
search of a memory-mapped tags file, so it will work efficiently with very large
(50MB+) tags files if needed.
Installation
Package Control
The easiest way to install is using Package Control. It's listed as CTags.
- Open
Command Paletteusing menu itemTools → Command Palette... - Choose
Package Control: Install Package - Find
CTagsand hitEnter
Manual Download
- Download the
.zip - Unzip and rename folder to
CTags - Copy folder into
Packagesdirectory, which can be found using the menu itemPreferences → Browse Packages...
Using Git
Go to your Sublime Text Packages directory and clone the repository using the command below::
git clone https://github.com/SublimeText/CTags
Additional Setup Steps
Linux
To install ctags use your package manager.
- For Debian-based systems (Ubuntu, Mint, etc.)::
sudo apt-get install exuberant-ctags
or
sudo apt-get install universal-ctags
- For Red Hat-based systems (Red Hat, Fedora, CentOS)::
sudo yum install ctags
MacOS
The default ctags executable in OSX does not support recursive directory
search (i.e. ctags -R). To get a proper copy of ctags, use one of the
following options:
- Using Homebrew
brew install ctags
- Using MacPorts
port install ctags
Ensure that the PATH is updated so the correct version is run:
- If
which ctagsdoesn't point at ctags in/usr/local/bin, make sure you add/usr/local/binto yourPATHahead of the folderwhich ctagsreported. - Alternatively, add the path to the new
ctagsexecutable to the settings, undercommand. If you have Xcode / Apple Developer Tools installed this path will likely be/usr/local/bin/ctags.
Windows
Download Exuberant CTags binary or Universal CTags binary
Extract
ctags.exefrom the downloaded zip toC:\Program Files\Sublime Textor any folder within your PATH so that Sublime Text can run it.Alternatively, extract to any folder and add the path to this folder to the
commandsetting.
Usage
This uses tag files created by the ctags -R -f .tags command by default
(although this can be overridden in settings).
The plugin will try to find a .tags file in the same directory as the
current view, walking up directories until it finds one. If it can't find one
it will offer to build one (in the directory of the current view)
If a symbol can't be found in a tags file, it will search in additional
locations that are specified in the CTags.sublime-settings file (see
below).
If you are a Rubyist, you can build a Ruby Gem's tags with the following script:
require 'bundler'
paths = Bundler.load.specs.map(&:full_gem_path)
system("ctags -R -f .gemtags #{paths.join(' ')}")
Settings
To open CTags.sublime-settings
- Open
Command Paletteusing menu itemTools → Command Palette... - Choose
Preferences: CTags Settingsand hitEnter
filterswill allow you to set scope specific filters against a field of the tag. In the excerpt above, imports tags likefrom a import bare filtered:
'(?P<symbol>[^\t]+)\t'
'(?P<filename>[^\t]+)\t'
'(?P<ex_command>.*?);"\t'
'(?P<type>[^\t\r\n]+)'
'(?:\t(?P<fields>.*))?'
extra_tag_pathsis a list of extra places to look for keyed by(selector, platform). Note theplatformis tested againstsublime.platform()so any values that function returns are valid.extra_tag_filesis a list of extra files relative to the original filecommandis the path to the version of ctags to use, for example::
"command" : "/usr/local/bin/ctags"
or:
"command" : "C:\\Users\\<username>\\Downloads\\CTags\\ctag.exe"
The rest of the options are fairly self explanatory.
Hide .tags files from side bar
By default, Sublime will include ctags files in your project, which causes
them to show up in the file tree and search results. To disable this behaviour
you should add a file_exclude_patterns entry to your
Preferences.sublime-settings or your project file. For example:
"file_exclude_patterns": [".tags", ".tags_sorted_by_file", ".gemtags"]
Support
If there are any problems or you have a suggestion, open an issue, and we will receive a notification.
Commands Listing
| Command | Key Binding | Alt Binding | Mouse Binding |
|---|---|---|---|
| rebuild_ctags | ctrl+t, ctrl+r | ||
| navigate_to_definition | ctrl+t, ctrl+t | ctrl+> | ctrl+shift+left_click |
| jump_back | ctrl+t, ctrl+b | ctrl+< | ctrl+shift+right_click |
| show_symbols | alt+s | ||
| show_symbols (all files) | alt+shift+s | ||
| show_symbols (suffix) | ctrl+alt+shift+s |