A Zsh plugin to help remembering those shell aliases and Git aliases you once defined.
Works with Oh My Zsh, Antigen, zgen or pure Zsh.
It works by trying to find an shell or Git alias for the command you are currently executing and printing a help line reminding you about that alias.
The idea is that you might be too afraid to execute aliases defined because you can't remember them correctly, or just have forgotten about some aliases, or that aliases for your daily commands even exist.
$ ls -lh
You know you have an alias for that, right? ll
:
$ git gui
You know you have an alias for that, right? gg
:
$ git rebase --interactive master
You know you have an alias for that, right? gri master
:
$ git status
You know you have an alias for that, right? git st
:
-
Get it
Go to your custom plugins folder:
$ cd ${ZSH_CUSTOM1:-$ZSH/custom}/plugins
Then either clone:
$ git clone https://github.com/djui/alias-tips.git
Or download:
$ wget https://github.com/djui/alias-tips/archive/master.zip $ unzip master.zip && mv alias-tips-master alias-tips && rm master.zip
Or add it as submodule:
$ git submodule add https://github.com/djui/alias-tips $ git submodule update --init
-
Include it
Then add the plugin to your plugin list in oh-my-zsh configuration:
$ $EDITOR ~/.zshrc # -plugins=(...) # +plugins=(... alias-tips)
- Add
antigen bundle djui/alias-tips
to your.zshrc
with your other antigen bundle commands.
- Add
zgen load djui/alias-tips
to your.zshrc
- Regenerate your
init.zsh
withzgen save
- Get it
git clone https://github.com/djui/alias-tips.git
- Add
source alias-tips/alias-tips.plugin.zsh
to your.zshrc
.
After installation re-source your .zshrc
.
The help string can be configured exporting an environment variable, e.g. in
your .zshrc
:
:
export ZSH_PLUGINS_ALIAS_TIPS_TEXT="Alias tip: "
:
A list of aliases to be excluded from being reminded of can be configured
exporting an environment variable of space separated aliases, e.g. in your
.zshrc
:
:
export ZSH_PLUGINS_ALIAS_TIPS_EXCLUDES="_ ll vi"
:
If you have several alias, e.g. for different git commands the command get expanded before looking for an alias.
Example:
alias gRv='git remote -v'
alias gR='git remote'
Without the expand option gR -v
will execute without a tip, with expand, it
will suggest gRv
.
If this may not be desired, the behaviour can be disabled by setting the environment variable, e.g. in your .zshrc:
:
export ZSH_PLUGINS_ALIAS_TIPS_EXPAND=0
:
- Suffix and Global aliases are currently not supported. Only Prefix
aliases ("command position") are supported. Check the
Zsh manual
on
alias
for their definition. - Multiline aliases (aliases which definition span multiple lines) are not supported. Currently their first line only will be used (likely incorrectly)
Q: Why only Zsh?
A: This works because of feature in Zsh called preexec. Other shells, e.g. Bash, do not have this feature. There are workarounds[1,2] but integrating these is a task left for the reader.
Thanks to the following people for their help:
$ python -m unittest test_alias-tips
$ python3 -m unittest test_alias-tips