Ecosyste.ms: Awesome
An open API service indexing awesome lists of open source software.
https://github.com/0mp/goat
POSIX-compliant shell movement boosting hack for real ninjas (aka `cd x` and `cd ...`)
https://github.com/0mp/goat
bash cd hack posix posix-compliant posix-sh productivity sh shell terminal utility
Last synced: 20 days ago
JSON representation
POSIX-compliant shell movement boosting hack for real ninjas (aka `cd x` and `cd ...`)
- Host: GitHub
- URL: https://github.com/0mp/goat
- Owner: 0mp
- License: other
- Created: 2016-03-06T21:11:51.000Z (almost 9 years ago)
- Default Branch: master
- Last Pushed: 2023-10-02T15:45:18.000Z (over 1 year ago)
- Last Synced: 2024-11-08T13:03:07.489Z (2 months ago)
- Topics: bash, cd, hack, posix, posix-compliant, posix-sh, productivity, sh, shell, terminal, utility
- Language: Shell
- Homepage:
- Size: 130 KB
- Stars: 38
- Watchers: 5
- Forks: 5
- Open Issues: 1
-
Metadata Files:
- Readme: README.md
- Contributing: CONTRIBUTING.md
- License: LICENSE
Awesome Lists containing this project
README
# goat
### Overview
> I used to retrieve carefully-constructed `cd` commands from my history.
> But then, I got a goat.
>
> _~ [Jonathan Paugh][jpaugh] on [Google+]_```console
[ ~/Pictures ] $ goat dev ~/Documents/devel # create a link to the dev directory
[ ~/Pictures ] $ ls # see that there is no ~/Pictures/dev directory here
seahorses wallpapers
[ ~/Pictures ] $ cd dev # the goat framework's got you covered!
[ ~/Documents/devel ] $
```> Oh my! This is a **POSIX-compliant** shell _movement boosting_ **hack** for
> **real ninjas**.
> #[posix\_me\_harder][posix_me_harder] #[posixly\_correct][posixly_correct]
>
> _~ 0mp_Sometimes you jump around your filesystem tree a lot and you end up putting a
couple of ugly aliases into your shell's rc file.> I should try it, even if it is dumb!
>
> _~ [dse] on [What the Daily WTF?] about goat v1.1.1_With goat you can easily manage your ninja shortcuts - just type `goat p
~/Projects` to introduce a new link and then `cd p` to jump to its destination.> Rad! I can do `cd ....` now instead of performing a horse galloping-like
> waltz with `../` being my miserable dance floor. I'm cloning this goat
> straight away!
>
> _~ YA0mp_BTW, Bash completion is now fully working with goat's shortcuts.
## Building
```console
$ make all
```## Installation
```console
$ make install
```Aferwards:
- Make sure that `~/.local/bin` is in your `PATH`:
```console
$ cat <<'EOF' >> ~/.bashrc
case "$PATH" in
*$HOME/.local/bin*) ;;
*) PATH="$HOME/.local/bin:$PATH" ;;
esac
EOF
```- Make sure that files inside `~/.local/etc/bash_completion.d` are actually
sourced by the Bash completion library:```console
$ cat <<'EOF' >> ~/.bash_completion
if [[ -d ~/.bash_completion.d ]]
then
for f in ~/.local/etc/bash_completion.d/*
do
[[ -f $f ]] && source "$f"
done
fi
EOF
```## Usage overview
```console
Create a shortcut named “f” to ~/Documents/dev/freebsd (no need to use
the link command explicitly here):$ goat f ~/Documents/dev/freebsd
Follow a link to change a directory with cd(1):
$ cd f
Take the “f” shortcut and enter its destination subdirectory with just
one command:$ pwd
/home/0mp
$ cd f/ports
$ pwd
/usr/home/0mp/freebsd/portsCreate a shortcut named “p” to the current directory:
$ goat p .
Go up the filesystem tree with ... (same as the standard “cd ../../”):
$ cd ...
List all your links:
$ goat list
dots -> /usr/home/0mp/.dotfiles
down -> /usr/home/0mp/Downloads
f -> /usr/home/0mp/freebsd
p -> /usr/home/0mp/freebsd/ports
pa -> /usr/home/0mp/freebsd/patches
src -> /usr/home/0mp/freebsd/svn/src
svn -> /usr/home/0mp/freebsd/svnDelete a link (or more):
$ goat delete f p
Delete all the links which point to directories with the given prefix:
$ goat deleteprefix "$HOME/Documents"
```## License
Licensed under 2-Clause BSD license. Copyright © 2016-2021 Mateusz Piotrowski
[posix_me_harder]: http://wiki.wlug.org.nz/POSIX_ME_HARDER
[posixly_correct]: http://wiki.wlug.org.nz/POSIXLY_CORRECT
[dse]: https://what.thedailywtf.com/user/dse
[What the Daily WTF?]: https://what.thedailywtf.com/topic/16122/quick-links-thread/2121
[Google+]: https://plus.google.com/113949504369826627206/posts/bqSfYTrQxLN
[jpaugh]: https://github.com/jpaugh