Tovi Jaeschke-Rogers c471a12974 | 3 years ago | |
---|---|---|
.. | ||
.github/workflows | 3 years ago | |
docs | 3 years ago | |
highlighters | 3 years ago | |
images | 3 years ago | |
tests | 3 years ago | |
.editorconfig | 3 years ago | |
.gitattributes | 3 years ago | |
.gitignore | 3 years ago | |
.revision-hash | 3 years ago | |
.version | 3 years ago | |
COPYING.md | 3 years ago | |
HACKING.md | 3 years ago | |
INSTALL.md | 3 years ago | |
Makefile | 3 years ago | |
README.md | 3 years ago | |
changelog.md | 3 years ago | |
release.md | 3 years ago | |
zsh-syntax-highlighting.plugin.zsh | 3 years ago | |
zsh-syntax-highlighting.zsh | 3 years ago |
Fish shell-like syntax highlighting for Zsh.
Requirements: zsh 4.3.11+.
This package provides syntax highlighting for the shell zsh. It enables highlighting of commands whilst they are typed at a zsh prompt into an interactive terminal. This helps in reviewing commands before running them, particularly in catching syntax errors.
Some examples:
See INSTALL.md.
zsh-syntax-highlighting.zsh
be sourced at the end of the .zshrc
file?zsh-syntax-highlighting works by hooking into the Zsh Line Editor (ZLE) and computing syntax highlighting for the command-line buffer as it stands at the time z-sy-h's hook is invoked.
In zsh 5.2 and older,
zsh-syntax-highlighting.zsh
hooks into ZLE by wrapping ZLE widgets. It must
be sourced after all custom widgets have been created (i.e., after all zle -N
calls and after running compinit
) in order to be able to wrap all of them.
Widgets created after z-sy-h is sourced will work, but will not update the
syntax highlighting.
In zsh newer than 5.8 (not including 5.8 itself),
zsh-syntax-highlighting uses the add-zle-hook-widget
facility to install
a zle-line-pre-redraw
hook. Hooks are run in order of registration,
therefore, z-sy-h must be sourced (and register its hook) after anything else
that adds hooks that modify the command-line buffer.
Highlighting the command line during an incremental history search (by default bound to to Ctrl+R in zsh's emacs keymap) requires zsh 5.4 or newer.
Under zsh versions older than 5.4, the zsh-default underlining of the matched portion of the buffer remains available, but zsh-syntax-highlighting's additional highlighting is unavailable. (Those versions of zsh do not provide enough information to allow computing the highlighting correctly.)
See issues #288 and #415 for details.
There is currently no "push" announcements channel. However, the following alternatives exist:
Syntax highlighting is done by pluggable highlighter scripts. See the documentation on highlighters for details and configuration settings.