Skip to main content

Magic goto - goto where you need to be, right now.

Project description



Goto is a magic tool that takes you were you want to be, now.

When you are involved in different projects, they all have their own folders, important files, links to good articles or key websites. The problem is that all these are spread out on different locations.

By adding shortcuts to goto, so called magic words, you can jump to them. The shortcuts are associated with a project name. And you can switch the project context any time.


$ project your-project
active project is now: your-project

$ goto add github
Added magic word github

$ goto github
# opens in your browser


Mac OS-X / Linux / Win (git bash)

pip install magicgoto

After install, close and reopen your terminal.

Windows (using gitbash)

Open git bash and do the same as above.

git bash is included when you install git on windows usually.

Some git bash installs comes without any rcfile. If you get this error: Ah hoy! Failed to determine rcfile... you can fix it by runningtouch ~/.bash_profile and then install_goto

Linux - User Site install

On linux, the recommended way to install goto is by pip install --user magicgoto

This requires that you have your User site bin in your path. Usually this is ~/.local/bin. So adding PATH="${HOME}/.local/bin:$PATH" to your rcfile should do the trick in most cases.



Used to add and jump to shortcuts.

    The basics
        goto <magicword>                        Go to shortcut
        goto [<magicword>...]                   Go to many shortcuts
        goto add    <magicword> <url or path>   Add shortcut
        goto update <magicword> <new url/path>  Update shortcut
        goto rename <magicword> <new name>      Rename shortcut
        goto rm     <magicword>                 Remove shortcut
        goto show   <magicword>                 Show url of shortcut
        goto list                               List all shortcuts
        goto list -v                            With the urls printed

    Working with folders and files
        goto <magicword>              Goto will cd to a folder shortcut by default.
        goto cd   <magicword>         cd in terminal
        goto open <magicword>         Open in finder/file explorer

    Launching Code editors
        goto subl                     Opens Sublime Text in code folder*
        goto idea                     Opens IntelliJ in code folder*
        goto vscode                   Opens Visual Studio Code in code folder*

    * requires a magicword named code pointing to a folder.
        goto add code <path to folder with code>


Used to add and switch project contexts.

Usage: project [add <projectname>] | [list]
   other commands:
     add <projectname> - adds a new project and makes it the active project.
     rm  <projectname> - removes the project
     list              - lists all projects
     deactivate        - deactivates goto project
     help              - if you want to read this one more time.

How does Goto know which project is the active one?

You tell goto with this command: project <project-name>

Examples: project django-blog | project website | project goto

$ project goto
active project is now: goto

Running project with no arguments, will show you the current active project.

$ project

How does Goto know which projects exists?

You tell Goto with the command:

 project add <project-name>

How does Goto know which shortcuts there are in the project?

Define them once, and use them a thousand times. By this command:

 goto add <magic-word> <URI>

A magic-word is the name of your shortcut. The URI is the target of your shortcut. It could be a file, a directory, a web-url.

  • goto add github
  • goto add music ~/the/sound/of/music
  • goto add jira

First one adds a url to a repo on github relevant to the project. The second one adds a folder path.

When you activate a project, Goto remembers which project you are thinking about right now.

Then it makes sense to call the shortcut visualstudio, because it implicit means the visual studio project associated with this project.


goto add jira


pip uninstall magicgoto
# remove source start_goto from your ~/.bash_profile | ~/.bashrc | ~/.zshrc
# project data is kept intact in ~/.goto


Goto many things with one command


Project details

Download files

Download the file for your platform. If you're not sure which to choose, learn more about installing packages.

Source Distribution

magicgoto-1.6.2.tar.gz (31.5 kB view hashes)

Uploaded source

Built Distribution

magicgoto-1.6.2-py3-none-any.whl (32.0 kB view hashes)

Uploaded py3

Supported by

AWS AWS Cloud computing Datadog Datadog Monitoring Facebook / Instagram Facebook / Instagram PSF Sponsor Fastly Fastly CDN Google Google Object Storage and Download Analytics Huawei Huawei PSF Sponsor Microsoft Microsoft PSF Sponsor NVIDIA NVIDIA PSF Sponsor Pingdom Pingdom Monitoring Salesforce Salesforce PSF Sponsor Sentry Sentry Error logging StatusPage StatusPage Status page