ctrl+shift+p filters: :st2 :st3 :win :osx :linux
Browse

CTags

by SublimeText ALL Top 100

CTags support for Sublime Text

Details

Installs

  • Total 302K
  • Win 176K
  • Mac 69K
  • Linux 56K
Jul 27 Jul 26 Jul 25 Jul 24 Jul 23 Jul 22 Jul 21 Jul 20 Jul 19 Jul 18 Jul 17 Jul 16 Jul 15 Jul 14 Jul 13 Jul 12 Jul 11 Jul 10 Jul 9 Jul 8 Jul 7 Jul 6 Jul 5 Jul 4 Jul 3 Jul 2 Jul 1 Jun 30 Jun 29 Jun 28 Jun 27 Jun 26 Jun 25 Jun 24 Jun 23 Jun 22 Jun 21 Jun 20 Jun 19 Jun 18 Jun 17 Jun 16 Jun 15 Jun 14 Jun 13 Jun 12
Windows 0 9 7 10 7 6 1 6 11 14 11 4 5 3 3 8 9 11 17 9 7 5 10 9 12 5 5 1 3 13 12 15 15 6 4 1 13 5 10 5 7 9 2 7 17 4
Mac 0 0 3 2 2 2 1 2 3 3 1 1 1 3 2 1 2 2 3 5 1 0 2 1 0 1 2 0 2 2 3 3 4 2 1 0 2 1 1 2 0 3 0 1 4 3
Linux 0 3 2 3 1 3 0 1 1 4 1 6 2 1 0 0 4 2 2 1 0 0 1 2 1 2 5 1 3 1 3 1 4 1 0 0 8 0 2 1 1 0 3 3 2 3

Readme

Source
raw.​githubusercontent.​com

CTags

CI

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.

  1. Open Command Palette using menu item Tools → Command Palette...
  2. Choose Package Control: Install Package
  3. Find CTags and hit Enter

Manual Download

  1. Download the .zip
  2. Unzip and rename folder to CTags
  3. Copy folder into Packages directory, which can be found using the menu item Preferences → 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:

brew install ctags
port install ctags

Ensure that the PATH is updated so the correct version is run:

  • If which ctags doesn't point at ctags in /usr/local/bin, make sure you add /usr/local/bin to your PATH ahead of the folder which ctags reported.
  • Alternatively, add the path to the new ctags executable to the settings, under command. 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.exe from the downloaded zip to C:\Program Files\Sublime Text or 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 command setting.

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

  1. Open Command Palette using menu item Tools → Command Palette...
  2. Choose Preferences: CTags Settings and hit Enter

  • filters will allow you to set scope specific filters against a field of the tag. In the excerpt above, imports tags like from a import b are filtered:
'(?P<symbol>[^\t]+)\t'
  '(?P<filename>[^\t]+)\t'
  '(?P<ex_command>.*?);"\t'
  '(?P<type>[^\t\r\n]+)'
  '(?:\t(?P<fields>.*))?'
  • extra_tag_paths is a list of extra places to look for keyed by
  • (selector, platform). Note the platform is tested against sublime.platform() so any values that function returns are valid.
  • extra_tag_files is a list of extra files relative to the original file
  • command is 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