zsh-syntax-highlighting/docs/highlighters/regexp.md
Nuri Jung d7d9f8fddc
Add comments for BSD-based platform users
In BSD-based platform such as macOS, the metacharacters with leading "\" are not supported.
This adds comments for users with those OS, to avoid confusing results.

Also changes the wrong associative array name in the example(s).
2020-07-01 21:38:38 +09:00

1.9 KiB

zsh-syntax-highlighting / highlighters / regexp

This is the regexp highlighter, that highlights user-defined regular expressions. It's similar to the pattern highlighter, but allows more complex patterns.

How to tweak it

To use this highlighter, associate regular expressions with styles in the ZSH_HIGHLIGHT_REGEXP associative array, for example in ~/.zshrc:

typeset -A ZSH_HIGHLIGHT_REGEXP
ZSH_HIGHLIGHT_REGEXP+=('\bsudo\b' fg=123,bold)

This will highlight "sudo" only as a complete word, i.e., "sudo cmd", but not "sudoedit"

The syntax for values is the same as the syntax of "types of highlighting" of the zsh builtin $zle_highlight array, which is documented in the zshzle(1) manual page.

See also: regular expressions tutorial, zsh regexp operator =~ in the zshmisc(1) manual page

Cautions to BSD-based platform users

In BSD-based platform such as macOS, the regex metacharacters with leading backslash (\) such as \b, \w, etc. are not supported.

So if you want something like the above example, you should use [[:<:]](matches the beginning of a word) with [[:>:]](matches the end of a word). The complete example would be like:

typeset -A ZSH_HIGHLIGHT_REGEXP
ZSH_HIGHLIGHT_REGEXP+=('[[:<:]]sudo[[:>:]]' fg=123,bold)

For other metacharacters, consider using POSIX ERE instead.