zsh-peco-history
Search shell history with peco when pressing ctrl+r.
Based on zsh-history-search snippet from percol.
Usage
- Press ctrl+r while in a zsh shell and it should load up peco with your shell's history.
- Start typing to filter history down.
- Press enter/return to pick a command from history.
Requirements
- peco
- zsh
tac
, ortail
with support for-r
option.perl
,awk
, oruniq
if de-duplication is turned on.
Installation
Manual
-
Clone this repo to your machine. This guide uses
~/.zsh/zsh-peco-history
:git clone https://github.com/jimeh/zsh-peco-history.git ~/.zsh/zsh-peco-history
-
Add the following to the end of your
.zshrc
:source ~/.zsh/zsh-peco-history/zsh-peco-history.zsh
-
Start a new terminal session.
Zplug
-
Add a zplug definition for zsh-peco-history to your
.zshrc
:zplug "jimeh/zsh-peco-history", defer:2
-
Start a new terminal session.
Antigen
-
Add a antigen bundle definition for zsh-peco-history to the end of the antigen setup in your
.zshrc
:antigen bundle jimeh/zsh-peco-history
-
Start a new terminal session.
Oh My Zsh
-
Clone this repository into
$ZSH_CUSTOM/plugins
(by default~/.oh-my-zsh/custom/plugins
)git clone https://github.com/jimeh/zsh-peco-history.git ${ZSH_CUSTOM:-~/.oh-my-zsh/custom}/plugins/zsh-peco-history
-
Add the plugin to the list of plugins for Oh My Zsh to load:
plugins=(zsh-peco-history)
-
Start a new terminal session.
Configuration Options
ZSH_PECO_HISTORY_OPTS
Command-line arguments passed to peco
. Defaults to --layout=bottom-up
if the
variable is not set.
A lot of the Peco options available on the command-line, are also available via Peco's config file. It's up to you how you want to manage your Peco settings.
For example, if you want to use the bottom-up
layout, and change to fuzzy
filtering:
ZSH_PECO_HISTORY_OPTS="--layout=bottom-up --initial-filter=Fuzzy"
ZSH_PECO_HISTORY_DEDUP
De-duplicates all history entries before they are handed over to peco. Disabled by default.
To enable, set the ZSH_PECO_HISTORY_DEDUP
environment variable to a non-zero
value before zsh-peco-history is loaded.
This is useful if you often have a lot of duplicate entries when searching through your history. However in that case it often enough to configure ZSH to not save duplicate commands to history in the first place. This can be done by setting the following options:
setopt HIST_EXPIRE_DUPS_FIRST
setopt HIST_IGNORE_DUPS
setopt HIST_IGNORE_ALL_DUPS
setopt HIST_FIND_NO_DUPS
setopt HIST_SAVE_NO_DUPS
Oh My Zsh for example sets the
above options, and more in it's
history.zsh
file.
Recommended Peco Config
You don't have to use this config, it's simply what I personally use. So here's
what my ~/.peco/config.json
file looks like:
{
"Keymap": {
"M-v": "peco.ScrollPageUp",
"C-v": "peco.ScrollPageDown",
"C-g": "peco.Cancel",
"M-Space": "peco.ToggleRangeMode",
"M-c": "peco.CancelRangeMode"
},
"Style": {
"Basic": ["on_default", "default"],
"Matched": ["cyan"],
"Query": ["default"],
"SavedSelection": ["on_blue", "white"],
"Selected": ["on_magenta", "default"]
}
}