This document is an unfinished draft. # Documentation Table of contents: * 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 * Delete last command * Examples ## Features HSTR is typically started by pressing Ctrlr after you configure it for this shorcut for your shell. However, you can run it as a normal program just by typing: ```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: ```bash hh --non-interactive ``` Filtering pattern can be optionally specified as well: ```bash hh -i git ``` Prints history items containing `git` to standard output and exits. ### History Filtering When HSTR starts in interative mode, a view of commands is shown. This list of commands can be filtered just by typing a string pattern. ### Choosing a Command 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) ### Favorite Commands HSTR allows you to store and manage your favorite commands. A new favorite command can be added from ranking or raw history view by pressing Ctrlf. You can check your favorite commands by choosing favorite view - rotate views using Ctrl/ or start `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: * Favorite commands are stored in `~/.hh_favorites` * Suffix your favorite commands with comments describing their purpose. For example: ``` printf "\e[?2004l" # fix terminal copy/paste ``` * Such comment can be used for normal commands as well and may serve as a way how to **tag** commands. ```bash COMMAND # TAG1 TAG2 TAG3 ... printf "\e[?2004l" # fix broken copy/paste in terminal #TERM ``` ### Blacklist HSTR allows you to specify a set of commands to be 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: * 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. ### Kill the Last Command Using `hh` you can easily delete the last command from history e.g. when you make a typo or write something sensitive: ``` hh --kill-last-command ``` See configuration section for how to bind this functionality to a key - bound to Ctrlx k by default. ## Examples Get more colors when running `hh`: ```bash export HH_CONFIG=hicolor ``` Start `hh` in configured view and filter out history items containing 'git': ```bash hh git ``` Print history items containing 'git' to standard output and exit: ```bash hh --non-interactive git ``` Append default `hh` configuration to your Bash profile: ```bash hh --show-configuration >> ~/.bashrc ``` Check `hh` man page: ```bash man hh ```