Fish-like autosuggestions for zsh
Go to file
Michael Robinson dde838c226 Merge pull request #63 from jirutka/patch-7 2015-05-23 12:41:27 +12:00
.editorconfig Update readme 2015-05-21 20:23:09 +02:00
.gitignore First commit 2013-10-26 13:05:17 -03:00
LICENSE Rename LICENSE-MIT to LICENSE 2015-05-21 18:09:33 +02:00
README.md Readme: extend section Known issues (closes #14) 2015-05-23 01:57:51 +02:00
autosuggestions.plugin.zsh add autosuggestions.plugin.zsh to get this repo working with antigen 2014-02-25 22:45:29 +02:00
autosuggestions.zsh Add widget autosuggest-execute-suggestion 2015-05-22 00:54:27 +02:00
completion-client.zsh Refactored, only use completion server on 2013-11-07 18:42:17 -03:00
completion-server-init.zsh Fix and unify formatting and code-style 2015-05-18 14:51:21 +02:00
completion-server.zsh Fix and unify formatting and code-style 2015-05-18 14:51:21 +02:00
install Fix and unify formatting and code-style 2015-05-18 14:51:21 +02:00

README.md

zsh-autosuggestions

Fish-like fast/unobtrusive autosuggestions for zsh.

It suggests commands as you type, based on command history.

Installation

If you already use zsh-syntax-highlighting plugin, then make sure to be loaded before zsh-autosuggestions.

Note: .zshrc is a file that contains user-specific ZSH configuration. ZSH assumes this file in your home directory (i.e. ~/.zshrc), but the location can be changed using ZDOTDIR variable.

Using zgen

Zgen is a simple and fast plugin manager for ZSH. If you dont use zgen, then use instructions for the manual installation.

  1. Load tarruda/zsh-autosuggestions and jimmijj/zsh-syntax-highlighting using zgen in your .zshrc file, for example:

    if ! zgen saved; then
        echo "Creating a zgen save"
    
        zgen load jimmijj/zsh-syntax-highlighting
    
        # autosuggestions should be loaded last
        zgen load tarruda/zsh-autosuggestions
    
        zgen save
    fi
    
  2. Enable zsh-autosuggestions; copy the following snippet and put it after the zgen config section in your .zshrc file:

    # Enable autosuggestions automatically.
    zle-line-init() {
        zle autosuggest-start
    }
    zle -N zle-line-init
    
  3. Run zgen reset and reopen your terminal.

Manually

  1. Clone this repository to ~/.zsh/zsh-autosuggestions (or anywhere else):

    git clone git://github.com/tarruda/zsh-autosuggestions ~/.zsh/zsh-autosuggestions
    
  2. Clone zsh-syntax-highlighting repository to ~/.zsh/zsh-syntax-highlighting (or anywhere else):

    git clone git://github.com/jimmijj/zsh-syntax-highlighting ~/.zsh/zsh-syntax-highlighting
    
  3. Load and enable autosuggestions; copy the following snippet and put it to your .zshrc file:

    # Load zsh-syntax-highlighting.
    source ~/.zsh/zsh-syntax-highlighting/zsh-syntax-highlighting.zsh
    
    # Load zsh-autosuggestions.
    source ~/.zsh/zsh-autosuggestions/autosuggestions.zsh
    
    # Enable autosuggestions automatically.
    zle-line-init() {
        zle autosuggest-start
    }
    zle -N zle-line-init
    
  4. Reopen your terminal.

Uninstallation

Just remove the config lines from .zshrc that youve added during “installation.” If you dont use zgen, then also delete ~/.zsh/zsh-autosuggestions and ~/.zsh/zsh-syntax-highlighting.

How to use

As you type commands, you will see a completion offered after the cursor, in a muted gray color (which can be changed, see Configuration). To accept the autosuggestion (replacing the command line contents), hit End, Alt+F, Ctrl+F, or any other key that moves the cursor to the right. If the autosuggestion is not what you want, just ignore it: it wont execute unless you accept it.

Any widget that moves the cursor to the right (forward-word, forward-char, end-of-line…) will accept parts of the suggested text. For example, vi-mode users can do this:

# Accept suggestions without leaving insert mode
bindkey '^f' vi-forward-word
# or
bindkey '^f' vi-forward-blank-word

You can also use right arrow key to accept the suggested text as in Fish shell; see Configuration section to enable it.

Exposed widgets

This plugin defines some ZLE widgets (think about them as functions) which you can bind to some key using bindkey. For example, to toggle autosuggestions using Ctrl+T add this to your .zshrc:

bindkey '^T' autosuggest-toggle

List of widgets:

  • autosuggest-toggle disable/enable autosuggestions.
  • autosuggest-execute-suggestion accept the suggestion and execute it.

Configuration

You may override default global config variables after plugin load, i.e. put it to your .zshrc after the code that loads plugins.

  • AUTOSUGGESTION_HIGHLIGHT_COLOR suggestion highlight color, default is 'fg=8'.
  • AUTOSUGGESTION_HIGHLIGHT_CURSOR highlight word after cursor, or not. Must be integer value 1 or 0, default is 1.
  • AUTOSUGGESTION_ACCEPT_RIGHT_ARROW complete entire suggestion with right arrow. Must be integer value 1 or 0, default is 0 (right arrow completes one letter at a time).

Known Issues

When I hit Tab and autosuggestions is enabled, it deletes the previous line, and scrolls up the terminal.

This usually happens when autosuggestions is used along with something like “completion waiting dots.” Check which widget is bind to the Tab key; run bindkey "^I". If it prints something other than "^I" expand-or-complete, then this may be the problem.

If you use Oh My Zsh, then make sure that the variable COMPLETION_WAITING_DOTS is not set (it enables this problematic code).

If you use module editor from Prezto, then you must comment out these lines.

License

This project is licensed under MIT license. For the full text of the license, see the LICENSE file.