2015-04-28 14:56:59 +08:00
|
|
|
This document is an unfinished draft.
|
|
|
|
|
2018-08-12 02:14:46 +08:00
|
|
|
# Documentation
|
2015-04-28 14:56:59 +08:00
|
|
|
Table of contents:
|
2018-08-11 14:37:17 +08:00
|
|
|
|
2015-04-28 14:56:59 +08:00
|
|
|
* Installation
|
|
|
|
* Distribution
|
|
|
|
* Source code
|
|
|
|
* Ubuntu
|
|
|
|
* Debian
|
|
|
|
* Mint
|
|
|
|
* Arch
|
|
|
|
* Mac OS
|
|
|
|
* Configuration
|
|
|
|
* Keyboard shortcut
|
|
|
|
* Colors
|
|
|
|
* View
|
|
|
|
* Verbosity
|
|
|
|
* Shell specific
|
|
|
|
* Bash
|
|
|
|
* Zsh
|
|
|
|
* Features
|
|
|
|
* History views
|
|
|
|
* Ranking
|
|
|
|
* Raw
|
|
|
|
* Favorites
|
|
|
|
* History filtering
|
|
|
|
* Choosing a command
|
|
|
|
* Favorite commands
|
|
|
|
* Blacklist
|
2018-02-21 16:06:00 +08:00
|
|
|
* Delete last command
|
2015-04-28 14:56:59 +08:00
|
|
|
* Examples
|
|
|
|
|
|
|
|
|
2018-08-11 14:48:25 +08:00
|
|
|
## Features
|
2018-08-13 05:37:33 +08:00
|
|
|
HSTR is typically started by pressing <kbd>Ctrl</kbd><kbd>r</kbd> after
|
2015-04-28 14:56:59 +08:00
|
|
|
you configure it for this shorcut for your shell. However,
|
|
|
|
you can run it as a normal program just by typing:
|
2018-08-12 02:14:46 +08:00
|
|
|
|
2015-04-28 14:56:59 +08:00
|
|
|
```bash
|
|
|
|
hh
|
|
|
|
```
|
|
|
|
|
|
|
|
It opens a page with a history view (ranking view is default).
|
|
|
|
Alternatively you can run `hh` in non-interactive mode -
|
|
|
|
commands are just listed on standard output based on history
|
|
|
|
view:
|
2018-08-12 02:14:46 +08:00
|
|
|
|
2015-04-28 14:56:59 +08:00
|
|
|
```bash
|
|
|
|
hh --non-interactive
|
|
|
|
```
|
|
|
|
|
|
|
|
Filtering pattern can be optionally specified as well:
|
2018-08-12 02:14:46 +08:00
|
|
|
|
2015-04-28 14:56:59 +08:00
|
|
|
```bash
|
|
|
|
hh -i git
|
|
|
|
```
|
|
|
|
|
|
|
|
Prints history items containing `git` to standard output and
|
|
|
|
exits.
|
|
|
|
|
2018-08-12 02:14:46 +08:00
|
|
|
### History Filtering
|
|
|
|
When HSTR starts in interative mode, a view of commands
|
2015-04-28 14:56:59 +08:00
|
|
|
is shown. This list of commands can be filtered just by typing
|
|
|
|
a string pattern.
|
|
|
|
|
2018-08-12 02:14:46 +08:00
|
|
|
|
|
|
|
### Choosing a Command
|
2015-04-28 14:56:59 +08:00
|
|
|
When you filtered the view of history items enough, you can
|
|
|
|
move around it with `UP` and `DOWN` arrow keys. Selected history
|
|
|
|
items is highlighted. Once you are done with your choice:
|
|
|
|
|
|
|
|
* press `ENTER` to choose the command and execute it
|
|
|
|
* or press `TAB` or `RIGHT` arrow key to choose the command and edit it on command line after exiting `hh`
|
|
|
|
* or press `LEFT` arrow key to choose the command and open it in editor (Bash `fc` i.e. fix command)
|
|
|
|
|
2018-08-12 02:14:46 +08:00
|
|
|
|
|
|
|
### Favorite Commands
|
|
|
|
HSTR allows you to store and manage your favorite
|
2015-04-28 14:56:59 +08:00
|
|
|
commands.
|
|
|
|
|
|
|
|
A new favorite command can be added from
|
2018-08-13 05:37:33 +08:00
|
|
|
ranking or raw history view by pressing <kbd>Ctrl</kbd><kbd>f</kbd>.
|
2015-04-28 14:56:59 +08:00
|
|
|
|
|
|
|
You can check your favorite commands by choosing
|
2018-08-13 05:37:33 +08:00
|
|
|
favorite view - rotate views using <kbd>Ctrl</kbd><kbd>/</kbd> or start
|
2015-04-28 14:56:59 +08:00
|
|
|
`hh` by adding `favorites` to `HH_CONFIG` environment
|
|
|
|
property. A favorite command can be choosen just
|
|
|
|
by pressing `ENTER` when on command in favorite view.
|
|
|
|
Last chosen favorite commands appears as the first
|
|
|
|
one (at the top of the page) in the favorite view.
|
|
|
|
You can delete a favorite command with `DEL` key.
|
|
|
|
|
|
|
|
Tips:
|
2018-08-12 02:14:46 +08:00
|
|
|
|
2015-04-28 14:56:59 +08:00
|
|
|
* Favorite commands are stored in `~/.hh_favorites`
|
|
|
|
* Suffix your favorite commands with comments
|
2018-08-13 21:42:09 +08:00
|
|
|
describing their purpose. For example:
|
|
|
|
|
|
|
|
```
|
|
|
|
printf "\e[?2004l" # fix terminal copy/paste
|
|
|
|
```
|
|
|
|
|
|
|
|
* Such comment can be used for normal commands
|
2015-04-28 14:56:59 +08:00
|
|
|
as well and may serve as a way how to **tag**
|
|
|
|
commands.
|
|
|
|
|
2018-08-13 21:42:09 +08:00
|
|
|
```bash
|
|
|
|
COMMAND # TAG1 TAG2 TAG3
|
|
|
|
...
|
|
|
|
printf "\e[?2004l" # fix broken copy/paste in terminal #TERM
|
|
|
|
```
|
2018-08-12 02:14:46 +08:00
|
|
|
### Blacklist
|
|
|
|
HSTR allows you to specify a set of commands to be
|
2015-04-28 14:56:59 +08:00
|
|
|
skipped from all the views. Blacklist typically contains
|
|
|
|
frequently used commands whose completion from history
|
|
|
|
has a little or no value. The default blacklist looks
|
|
|
|
like this:
|
|
|
|
|
|
|
|
```bash
|
|
|
|
pwd
|
|
|
|
cd
|
|
|
|
cd ..
|
|
|
|
ls
|
|
|
|
hh
|
|
|
|
mc
|
|
|
|
```
|
|
|
|
|
|
|
|
Tips:
|
2018-08-12 02:14:46 +08:00
|
|
|
|
2015-04-28 14:56:59 +08:00
|
|
|
* Blacklist of commands is stored in `~/.hh_blacklist`
|
|
|
|
If the file doesn't exist, you may create it and complete
|
|
|
|
it with your own blacklist.
|
|
|
|
* You can skip any command from history just by
|
|
|
|
prefixing it with `SPACE`. For example:
|
|
|
|
` echo "Skip this from history"` It's a Bash
|
|
|
|
option that is configured using
|
|
|
|
`HISTCONTROL=ignorespace` environment variable.
|
|
|
|
|
2018-08-12 02:14:46 +08:00
|
|
|
|
|
|
|
### Kill the Last Command
|
2018-02-21 16:06:00 +08:00
|
|
|
Using `hh` you can easily delete the last command from history
|
|
|
|
e.g. when you make a typo or write something sensitive:
|
2018-08-12 02:14:46 +08:00
|
|
|
|
2018-02-21 16:06:00 +08:00
|
|
|
```
|
|
|
|
hh --kill-last-command
|
|
|
|
```
|
2018-08-12 02:14:46 +08:00
|
|
|
|
2018-02-21 16:06:00 +08:00
|
|
|
See configuration section for how to bind this functionality to
|
2018-08-13 05:37:33 +08:00
|
|
|
a key - bound to <kbd>Ctrl</kbd><kbd>x</kbd> <kbd>k</kbd> by default.
|
2018-02-21 16:06:00 +08:00
|
|
|
|
2018-08-12 02:14:46 +08:00
|
|
|
|
2018-08-11 14:48:25 +08:00
|
|
|
## Examples
|
2015-04-28 14:56:59 +08:00
|
|
|
Get more colors when running `hh`:
|
2018-08-12 02:14:46 +08:00
|
|
|
|
2015-04-28 14:56:59 +08:00
|
|
|
```bash
|
|
|
|
export HH_CONFIG=hicolor
|
|
|
|
```
|
|
|
|
|
|
|
|
Start `hh` in configured view and filter out history items
|
|
|
|
containing 'git':
|
2018-08-12 02:14:46 +08:00
|
|
|
|
2015-04-28 14:56:59 +08:00
|
|
|
```bash
|
|
|
|
hh git
|
|
|
|
```
|
|
|
|
|
|
|
|
Print history items containing 'git' to standard output and exit:
|
2018-08-12 02:14:46 +08:00
|
|
|
|
2015-04-28 14:56:59 +08:00
|
|
|
```bash
|
|
|
|
hh --non-interactive git
|
|
|
|
```
|
|
|
|
|
|
|
|
Append default `hh` configuration to your Bash profile:
|
2018-08-12 02:14:46 +08:00
|
|
|
|
2015-04-28 14:56:59 +08:00
|
|
|
```bash
|
|
|
|
hh --show-configuration >> ~/.bashrc
|
|
|
|
```
|
|
|
|
|
|
|
|
Check `hh` man page:
|
2018-08-12 02:14:46 +08:00
|
|
|
|
2015-04-28 14:56:59 +08:00
|
|
|
```bash
|
|
|
|
man hh
|
|
|
|
```
|