Giter VIP home page Giter VIP logo

zsh-history-substring-search's Introduction

zsh-history-substring-search

This is a clean-room implementation of the Fish shell's history search feature, where you can type in any part of any previously entered command and press the UP and DOWN arrow keys to cycle through the matching commands. You can also use K and J in VI mode or ^P and ^N in EMACS mode for the same.


Requirements

  • ZSH 4.3 or newer

Usage

  1. Load this script into your interactive ZSH session:

    % source zsh-history-substring-search.zsh
    

    If you want to use zsh-syntax-highlighting along with this script, then make sure that you load it before you load this script:

    % source zsh-syntax-highlighting.zsh
    % source zsh-history-substring-search.zsh
    
  2. Bind keyboard shortcuts to this script's functions:

    # bind UP and DOWN arrow keys
    zmodload zsh/terminfo
    bindkey "$terminfo[kcuu1]" history-substring-search-up
    bindkey "$terminfo[kcud1]" history-substring-search-down
    
    # bind P and N for EMACS mode
    bindkey -M emacs '^P' history-substring-search-up
    bindkey -M emacs '^N' history-substring-search-down
    
    # bind k and j for VI mode
    bindkey -M vicmd 'k' history-substring-search-up
    bindkey -M vicmd 'j' history-substring-search-down
    

    Ubuntu 12.04 users might need to use this snippet instead:

    # bind UP and DOWN arrow keys
    bindkey '^[[A' history-substring-search-up
    bindkey '^[[B' history-substring-search-down
    
  3. Type any part of any previous command and then:

    • Press the UP arrow key to select the nearest command that (1) contains your query and (2) is older than the current command in the command history.

    • Press the DOWN arrow key to select the nearest command that (1) contains your query and (2) is newer than the current command in the command history.

    • Press ^U (the Control and U keys simultaneously) to abort the search.

  4. If a matching command spans more than one line of text, press the LEFT arrow key to move the cursor away from the end of the command, and then:

    • Press the UP arrow key to move the cursor to the line above. When the cursor reaches the first line of the command, pressing the UP arrow key again will cause this script to perform another search.

    • Press the DOWN arrow key to move the cursor to the line below. When the cursor reaches the last line of the command, pressing the DOWN arrow key again will cause this script to perform another search.


Configuration

This script defines the following global variables. You may override their default values only after having loaded this script into your ZSH session.

  • HISTORY_SUBSTRING_SEARCH_HIGHLIGHT_FOUND is a global variable that defines how the query should be highlighted inside a matching command. Its default value causes this script to highlight using bold, white text on a magenta background. See the "Character Highlighting" section in the zshzle(1) man page to learn about the kinds of values you may assign to this variable.

  • HISTORY_SUBSTRING_SEARCH_HIGHLIGHT_NOT_FOUND is a global variable that defines how the query should be highlighted when no commands in the history match it. Its default value causes this script to highlight using bold, white text on a red background. See the "Character Highlighting" section in the zshzle(1) man page to learn about the kinds of values you may assign to this variable.

  • HISTORY_SUBSTRING_SEARCH_GLOBBING_FLAGS is a global variable that defines how the command history will be searched for your query. Its default value causes this script to perform a case-insensitive search. See the "Globbing Flags" section in the zshexpn(1) man page to learn about the kinds of values you may assign to this variable.


History

This script was originally written by Peter Stephenson, who published it to the ZSH users mailing list (thereby making it public domain) in September 2009. It was later revised by Guido van Steen and released under the BSD license (see below) as part of the fizsh project in January 2011.

It was later extracted from fizsh release 1.0.1, refactored heavily, and repackaged as both an oh-my-zsh plugin and as an independently loadable ZSH script by Suraj N. Kurapati in 2011.

It was further developed by Guido van Steen, Suraj N. Kurapati, Sorin Ionescu, and Vincent Guerci in 2011.

zsh-history-substring-search's People

Contributors

sunaku avatar guidovansteen avatar sorin-ionescu avatar vguerci avatar vitahall avatar tarrasch avatar colinhebert avatar lonepie avatar

Watchers

James Cloos avatar Max Z avatar

Recommend Projects

  • React photo React

    A declarative, efficient, and flexible JavaScript library for building user interfaces.

  • Vue.js photo Vue.js

    ๐Ÿ–– Vue.js is a progressive, incrementally-adoptable JavaScript framework for building UI on the web.

  • Typescript photo Typescript

    TypeScript is a superset of JavaScript that compiles to clean JavaScript output.

  • TensorFlow photo TensorFlow

    An Open Source Machine Learning Framework for Everyone

  • Django photo Django

    The Web framework for perfectionists with deadlines.

  • D3 photo D3

    Bring data to life with SVG, Canvas and HTML. ๐Ÿ“Š๐Ÿ“ˆ๐ŸŽ‰

Recommend Topics

  • javascript

    JavaScript (JS) is a lightweight interpreted programming language with first-class functions.

  • web

    Some thing interesting about web. New door for the world.

  • server

    A server is a program made to process requests and deliver data to clients.

  • Machine learning

    Machine learning is a way of modeling and interpreting data that allows a piece of software to respond intelligently.

  • Game

    Some thing interesting about game, make everyone happy.

Recommend Org

  • Facebook photo Facebook

    We are working to build community through open source technology. NB: members must have two-factor auth.

  • Microsoft photo Microsoft

    Open source projects and samples from Microsoft.

  • Google photo Google

    Google โค๏ธ Open Source for everyone.

  • D3 photo D3

    Data-Driven Documents codes.