Support literal newlines, part 2

This commit is contained in:
Daniel Shahaf 2015-09-02 08:28:03 +00:00
parent 52ece975c3
commit c2b9327b07
2 changed files with 22 additions and 26 deletions

View File

@ -102,28 +102,24 @@ _zsh_highlight_main_highlighter()
local substr_color=0 local substr_color=0
local style_override="" local style_override=""
[[ $start_pos -eq 0 && $arg = 'noglob' ]] && highlight_glob=false [[ $start_pos -eq 0 && $arg = 'noglob' ]] && highlight_glob=false
# advance $start_pos, skipping over whitespace in $buf.
((start_pos+=${#buf[$start_pos+1,-1]}-${#${buf[$start_pos+1,-1]##([[:space:]]|\\[[:space:]])#}}))
((end_pos=$start_pos+${#arg}))
# Deal with faked colons. # advance $start_pos, skipping over whitespace in $buf.
if [[ $arg == ';' ]] ; then
# We're looking for either a semicolon or a newline, whichever comes
# first. Both of these are rendered as a ";" (SEPER) by the ${(z)..}
# flag.
# #
# We can't use the (Z+n+) flag because that elides the end-of-command # We can't use the (Z+n+) flag because that elides the end-of-command
# token altogether, so 'echo foo\necho bar' (two commands) becomes # token altogether, so 'echo foo\necho bar' (two commands) becomes
# indistinguishable from 'echo foo echo bar' (one command with three # indistinguishable from 'echo foo echo bar' (one command with three
# words for arguments). # words for arguments).
if [[ $arg == ';' ]] ; then local needle=$'[;\n]'
if [[ $buf[start_pos+1] == ';' ]] ; then integer offset=${${buf[start_pos+1,-1]}[(i)$needle]}
# Literally-input colon. That's the normal case. (( start_pos += offset ))
elif [[ $buf[start_pos] == $'\n' ]] ; then (( end_pos += offset ))
# Newline token rendered as a colon. Empirically we're off-by-one.
(( start_pos -= 1 ))
(( end_pos -= 1 ))
else else
# Currently, there aren't any other sources of ";" (SEPER) tokens ((start_pos+=${#buf[$start_pos+1,-1]}-${#${buf[$start_pos+1,-1]##([[:space:]]|\\[[:space:]])#}}))
# besides literally-input semicolons and (Z+n+)-converted newlines, ((end_pos=$start_pos+${#arg}))
# If that ever changes, handle them here.
fi
fi fi
# Parse the sudo command line # Parse the sudo command line

View File

@ -32,9 +32,9 @@ PREBUFFER=$'echo foo; echo bar\n\n\n'
BUFFER=' echo baz; echo qux' BUFFER=' echo baz; echo qux'
expected_region_highlight=( expected_region_highlight=(
"0 4 $ZSH_HIGHLIGHT_STYLES[builtin]" # echo "1 5 $ZSH_HIGHLIGHT_STYLES[builtin]" # echo
"5 7 $ZSH_HIGHLIGHT_STYLES[default]" # baz "6 8 $ZSH_HIGHLIGHT_STYLES[default]" # baz
"8 9 $ZSH_HIGHLIGHT_STYLES[default]" # semicolon "9 10 $ZSH_HIGHLIGHT_STYLES[default]" # semicolon
"11 14 $ZSH_HIGHLIGHT_STYLES[builtin]" # echo "12 15 $ZSH_HIGHLIGHT_STYLES[builtin]" # echo
"16 18 $ZSH_HIGHLIGHT_STYLES[default]" # qux "17 19 $ZSH_HIGHLIGHT_STYLES[default]" # qux
) )