A plugin that aims at providing what
vim-startify plugin does, but in Zsh. The
analogy isn't fully easy to make. vim-startify
states:
It provides dynamically created headers or footers and uses configurable lists to show recently used or bookmarked files and persistent sessions.
zsh-startify:
- shows recently used files if used by a shell-util command, with name of the command(s) on other right,
- shows recently used vim files,
- will show active tmux sessions,
- will show statistics of most popular aliases in use,
- will show recently visited projects (i.e.
git
repositories, but also directories with aMakefile
, aCMakeLists.txt
, aconfigure
script, etc. – a very advanced feature, inherited fromzsh-startify
's predecessor:z-shell/zaccumulator
plugin), - will show recently ran
git
commands, with analysis of e.g. recently checked-out branches, - will cooperate with any bookmarking plugins to show their bookmarks.
Issue the regular loading command of your plugin manager, pointing it to
z-shell/zsh-startify
. Then, add invocation of zsh-startify
to the end of
~/.zshrc
:
% tail -n 5 ~/.zshrc (git)-[master●]
#zmodload -i zsh/sched
#schedprompt
# ADD TO ~/.zshrc
zsh-startify
# Option A – normal load without Turbo-Mode
zi ice atload'zsh-startify'
zi load z-shell/zsh-startify
# Option B – a load with Turbo-Mode being in use
zi ice wait'0' lucid atload'zsh-startify'
zi load z-shell/zsh-startify
The first option (A) loads the plugin synchronously, at the time of execution of the
zi load ...
command. The second option (B) loads in an asynchronous manner, 0
seconds after the prompt being first displayed.
zsh-startify
accumulates data in its own history file. To pre-fill it quickly with a
few of entries (basing on the regular history) you can run the
__from-zhistory-accumulate
command.
The zstyles used to configure the plugin (add such commands anywhere in the zshrc
):
zstyle ":plugin:zsh-startify:shellutils" size 5 # The size of the recently used file list (default: 5)
zstyle ":plugin:zsh-startify:vim" size 5 # The size of the recently opened in Vim list (default: 5)