2016-05-05 09:20:32 +08:00
|
|
|
Hacking on zsh-syntax-highlighting itself
|
|
|
|
=========================================
|
|
|
|
|
|
|
|
This document includes information for people working on z-sy-h itself: on the
|
|
|
|
core driver (`zsh-syntax-highlighting.zsh`), on the highlighters in the
|
|
|
|
distribution, and on the test suite. It does not target third-party
|
|
|
|
highlighter authors (although they may find it an interesting read).
|
|
|
|
|
2016-04-25 12:22:14 +08:00
|
|
|
The `main` highlighter
|
2016-05-05 09:20:32 +08:00
|
|
|
----------------------
|
|
|
|
|
|
|
|
The following function `pz` is useful when working on the `main` highlighting:
|
|
|
|
|
|
|
|
pq() {
|
|
|
|
(( $#argv )) || return 0
|
|
|
|
print -r -l -- ${(qqqq)argv}
|
|
|
|
}
|
|
|
|
pz() {
|
|
|
|
local arg
|
|
|
|
for arg; do
|
|
|
|
pq ${(z)arg}
|
|
|
|
done
|
|
|
|
}
|
|
|
|
|
|
|
|
It prints, for each argument, its token breakdown, similar to how the main
|
|
|
|
loop of the `main` highlighter sees it.
|
|
|
|
|
2016-04-25 12:22:14 +08:00
|
|
|
Testing the `brackets` highlighter
|
|
|
|
----------------------------------
|
|
|
|
|
|
|
|
Since the test harness empties `ZSH_HIGHLIGHT_STYLES` and the `brackets`
|
|
|
|
highlighter interrogates `ZSH_HIGHLIGHT_STYLES` to determine how to highlight,
|
|
|
|
tests must set the `bracket-level-#` keys themselves. For example:
|
|
|
|
|
|
|
|
ZSH_HIGHLIGHT_STYLES[bracket-level-1]=
|
|
|
|
ZSH_HIGHLIGHT_STYLES[bracket-level-2]=
|
|
|
|
|
|
|
|
BUFFER='echo ({x})'
|
|
|
|
|
|
|
|
expected_region_highlight=(
|
|
|
|
"6 6 bracket-level-1" # (
|
|
|
|
"7 7 bracket-level-2" # {
|
|
|
|
"9 9 bracket-level-2" # }
|
|
|
|
"10 10 bracket-level-1" # )
|
|
|
|
)
|
|
|
|
|
2016-05-05 13:12:18 +08:00
|
|
|
Testing the `pattern` highlighter
|
|
|
|
---------------------------------
|
|
|
|
|
|
|
|
Because the `pattern` highlighter modifies `region_highlight` directly instead
|
|
|
|
of using `_zsh_highlight_add_highlight`, the test harness cannot get the
|
|
|
|
`ZSH_HIGHLIGHT_STYLES` keys. Therefore, when writing tests, use the style
|
|
|
|
itself as third word (cf. the [documentation for `expected_region_highlight`]
|
|
|
|
(docs/highlighters.md)). For example:
|
|
|
|
|
|
|
|
ZSH_HIGHLIGHT_PATTERNS+=('rm -rf *' 'fg=white,bold,bg=red')
|
|
|
|
|
|
|
|
BUFFER='rm -rf /'
|
|
|
|
|
|
|
|
expected_region_highlight=(
|
|
|
|
"1 8 fg=white,bold,bg=red" # rm -rf /
|
|
|
|
)
|
|
|
|
|
2016-06-03 16:46:30 +08:00
|
|
|
Miscellany
|
|
|
|
----------
|
|
|
|
|
|
|
|
If you work on the driver (`zsh-syntax-highlighting.zsh`), you may find the following zstyle useful:
|
|
|
|
|
|
|
|
zstyle ':completion:*:*:*:*:globbed-files' ignored-patterns {'*/',}zsh-syntax-highlighting.plugin.zsh
|
|
|
|
|
2016-05-05 09:20:32 +08:00
|
|
|
IRC channel
|
|
|
|
-----------
|
|
|
|
|
|
|
|
We're on #zsh-syntax-highlighting on freenode.
|
|
|
|
|