tag is a lightweight wrapper around ag and ripgrep that generates shell aliases for your search matches. tag is a very fast Golang reimagining of sack.
tag supports ag and ripgrep (rg). There are no plans to support ack or grep. If you'd like to add support for more search backends, I encourage you to contribute!
tag makes it easy to immediately jump to a search match in your favorite editor. It eliminates the tedious task of typing vim foo/bar/baz.qux +42 to jump to a match by automatically generating these commands for you as shell aliases.
Inside vim, vim-grepper or ag.vim is probably the way to go. Outside vim (or inside a Neovim :terminal), tag is your best friend.
Finally, tag is unobtrusive. It should behave exactly like ag or ripgrep under most circumstances.
tag processes ag's output on-the-fly with Golang using pipes so the performance loss is neglible. In other words, tag is just as fast as ag!
$ cd ~/github/torvalds/linux
$ time ( for _ in {1..10}; do ag EXPORT_SYMBOL_GPL >/dev/null 2>&1; done )
16.66s user 16.54s system 347% cpu 9.562 total
$ time ( for _ in {1..10}; do tag EXPORT_SYMBOL_GPL >/dev/null 2>&1; done )
16.84s user 16.90s system 356% cpu 9.454 total
-
Update to the latest versions of
agorripgrep.agin particular must be version>= 0.25.0. -
Install the
tagbinary using one of the following methods.-
Homebrew (OSX)
$ brew tap aykamko/tag-ag $ brew install tag-ag -
AUR (Arch Linux)
Using your favorite AUR helper, install the tag-ag AUR package like this:
$ aura -A tag-ag -
Developers and other platforms
$ go get -u github.com/aykamko/tag/... $ go install github.com/aykamko/tag
-
-
By default,
tagusesagas its search backend. To useripgrepinstead, set the environment variableTAG_SEARCH_PROG=rg. (To persist this setting, put it in yourbashrc/zshrc.) -
Since tag generates a file with command aliases for your shell, you'll have to drop the following in your
bashrc/zshrcto actually pick up those aliases.-
bashif hash ag 2>/dev/null; then export TAG_SEARCH_PROG=ag # replace with rg for ripgrep tag() { command tag "$@"; source ${TAG_ALIAS_FILE:-/tmp/tag_aliases} 2>/dev/null; } alias ag=tag # replace with rg for ripgrep fi
-
zshif (( $+commands[tag] )); then export TAG_SEARCH_PROG=ag # replace with rg for ripgrep tag() { command tag "$@"; source ${TAG_ALIAS_FILE:-/tmp/tag_aliases} 2>/dev/null } alias ag=tag # replace with rg for ripgrep fi
-
fish - ~/.config/fish/functions/tag.fishfunction tag set -x TAG_SEARCH_PROG ag # replace with rg for ripgrep set -q TAG_ALIAS_FILE; or set -l TAG_ALIAS_FILE /tmp/tag_aliases command tag $argv; and source $TAG_ALIAS_FILE ^/dev/null alias ag tag # replace with rg for ripgrep end
-
tag exposes the following configuration options via environment variables:
TAG_SEARCH_PROG- Determines whether to use
agorripgrepas the search backend. Must be one ofagorrg. - Default:
ag
- Determines whether to use
TAG_ALIAS_FILE- Path where shortcut alias file will be generated.
- Default:
/tmp/tag_aliases
TAG_ALIAS_PREFIX- Prefix for alias commands, e.g. the
ein generated aliase42. - Default:
e
- Prefix for alias commands, e.g. the
TAG_CMD_FMT_STRING- Format string for alias commands. Must contain
{{.Filename}},{{.LineNumber}}, and{{.ColumnNumber}}for proper substitution. - Default:
vim -c 'call cursor({{.LineNumber}}, {{.ColumnNumber}})' '{{.Filename}}'
- Format string for alias commands. Must contain