Goto

Alias and navigate to directories with tab completion in Linux
Alternatives To Goto
Project NameStarsDownloadsRepos Using ThisPackages Using ThisMost Recent CommitTotal ReleasesLatest ReleaseOpen IssuesLicenseLanguage
Zsh Autosuggestions26,292
13 days ago1March 03, 2021144mitShell
Fish-like autosuggestions for zsh
Kubectx14,910
3 months ago26January 11, 202246apache-2.0Go
Faster way to switch between clusters and namespaces in kubectl
Zsh Completions6,039
5 days ago1March 03, 202136otherShell
Additional completion definitions for Zsh.
Fasd5,027
3 years ago1February 27, 2018109mitShell
Command-line productivity booster, offers quick access to files and directories, inspired by autojump, z and v.
Zsh Autocomplete3,376
2 days ago6mitShell
🤖 Real-time type-ahead completion for Zsh. Asynchronous find-as-you-type autocompletion.
Git Flow Completion2,588
5 years ago16mitShell
Bash, Zsh and fish completion support for git-flow.
Dotfiles2,154
4 years ago7mitVimL
config files for zsh, bash, completions, gem, git, irb, rails
Fzf Tab2,055
2 months ago57mitShell
Replace zsh's default completion selection menu with fzf!
Gibo1,814
9 months ago1February 27, 20181unlicenseShell
Easy access to gitignore boilerplates
Omelette1,260155101a year ago21September 21, 202115mitCoffeeScript
Omelette is a simple, template based autocompletion tool for Node and Deno projects with super easy API. (For Bash, Zsh and Fish)
Alternatives To Goto
Select To Compare


Alternative Project Comparisons
Readme

goto

A shell utility allowing users to navigate to aliased directories supporting auto-completion 🐾

Generic badge

How does it work?

User registers directory aliases, for example:

goto -r dev /home/iridakos/development

and then cds to that directory with:

goto dev

goto demo gif

goto completion

goto comes with a nice auto-completion script so that whenever you press the tab key after the goto command, bash or zsh prompts with suggestions of the available aliases:

$ goto <tab>
bc /etc/bash_completion.d                     
dev /home/iridakos/development
rubies /home/iridakos/.rvm/rubies

Installation

Via script

Clone the repository and run the install script as super user or root:

git clone https://github.com/iridakos/goto.git
cd goto
sudo ./install

Manually

Copy the file goto.sh somewhere in your filesystem and add a line in your .zshrc or .bashrc to source it.

For example, if you placed the file in your home folder, all you have to do is add the following line to your .zshrc or .bashrc file:

source ~/goto.sh

macOS - Homebrew

A formula named goto is available for the bash shell in macOS.

brew install goto

Add colored output

echo -e "\$include /etc/inputrc\nset colored-completion-prefix on" >> ~/.inputrc

Note:

  • you need to restart your shell after installation
  • you need to have the bash completion feature enabled for bash in macOS (see this issue):
    • you can install it with brew install bash-completion in case you don't have it already

Usage

Change to an aliased directory

To change to an aliased directory, type:

goto <alias>

Example:

goto dev

Register an alias

To register a directory alias, type:

goto -r <alias> <directory>

or

goto --register <alias> <directory>

Example:

goto -r blog /mnt/external/projects/html/blog

or

goto --register blog /mnt/external/projects/html/blog

Notes

  • goto expands the directories hence you can easily alias your current directory with:
goto -r last_release .

and it will automatically be aliased to the whole path.

  • Pressing the tab key after the alias name, you have the default directory suggestions by the shell.

Unregister an alias

To unregister an alias, use:

goto -u <alias>

or

goto --unregister <alias>

Example

goto -u last_release

or

goto --unregister last_release

Notes

Pressing the tab key after the command (-u or --unregister), the completion script will prompt you with the list of registered aliases for your convenience.

List aliases

To get the list of your currently registered aliases, use:

goto -l

or

goto --list

Expand an alias

To expand an alias to its value, use:

goto -x <alias>

or

goto --expand <alias>

Example

goto -x last_release

or

goto --expand last_release

Cleanup

To cleanup the aliases from directories that are no longer accessible in your filesystem, use:

goto -c

or

goto --cleanup

Help

To view the tool's help information, use:

goto -h

or

goto --help

Version

To view the tool's version, use:

goto -v

or

goto --version

Extras

Push before changing directories

To first push the current directory onto the directory stack before changing directories, type:

goto -p <alias>

or

goto --push <alias>

Revert to a pushed directory

To return to a pushed directory, type:

goto -o

or

goto --pop

Notes

This command is equivalent to popd, but within the goto command.

Troubleshooting

Updating from 1.x to 2.x

From version 2.x and after, the goto DB file is located in the $XDG_CONFIG_HOME or in the ~/.config directory under the name goto.

If you updated from version 1.x to 2.x or newer, you need to move this file which was previously located at ~/.goto.

Note that the new file is not hidden, it does not start with a dot .

zsh

command not found: compdef

In case you get such an error, you need to load the bashcompinit. Append this to your .zshrc file:

autoload bashcompinit
bashcompinit

TODO

  • Test on macOS extensively
  • Write tests

Contributing

  1. Fork it ( https://github.com/iridakos/goto/fork )
  2. Create your feature branch (git checkout -b my-new-feature)
  3. Commit your changes (git commit -am 'Add some feature')
  4. Push to the branch (git push origin my-new-feature)
  5. Make sure that the script does not have errors or warning on ShellCheck
  6. Create a new Pull Request

License

This tool is open source under the MIT License terms.

[Back To Top]

Popular Completion Projects
Popular Zsh Projects
Popular Text Processing Categories
Related Searches

Get A Weekly Email With Trending Projects For These Categories
No Spam. Unsubscribe easily at any time.
Shell
Bash
Zsh
Completion