From 6a3bbe72da30ae20885bbda5b783049b975e6d3b Mon Sep 17 00:00:00 2001 From: Wayne Davison Date: Thu, 30 Dec 2010 09:58:20 -0800 Subject: [PATCH] Fix some _hl_string issues: - Avoid unset variable warning at $arg[0]. - Fix highlighting of "\$" and "\\". - Tweak the code style a bit. --- zsh-syntax-highlighting.zsh | 24 +++++++++++++----------- 1 file changed, 13 insertions(+), 11 deletions(-) diff --git a/zsh-syntax-highlighting.zsh b/zsh-syntax-highlighting.zsh index 3fb26f0..8b0f642 100644 --- a/zsh-syntax-highlighting.zsh +++ b/zsh-syntax-highlighting.zsh @@ -74,19 +74,21 @@ _zsh_check-path() { # Highlight special chars inside double-quoted strings _zsh_highlight-string() { - local i - local j - local k - local c - for (( i = 0 ; i < end_pos - start_pos ; i += 1 )) ; do + setopt localoptions noksharrays + local i j k style + # Starting quote is at 1, so start parsing at offset 2 in the string. + for (( i = 2 ; i < end_pos - start_pos ; i += 1 )) ; do (( j = i + start_pos - 1 )) (( k = j + 1 )) - c="$arg[$i]" - [[ "$c" = '$' ]] && region_highlight+=("$j $k $ZSH_SYNTAX_HIGHLIGHTING_STYLES[dollar-double-quoted-argument]") - if [[ "$c" = "\\" ]] ; then - (( k = k + 1 )) - region_highlight+=("$j $k $ZSH_SYNTAX_HIGHLIGHTING_STYLES[back-double-quoted-argument]") - fi + case "$arg[$i]" in + '$') style=$ZSH_SYNTAX_HIGHLIGHTING_STYLES[dollar-double-quoted-argument];; + "\\") style=$ZSH_SYNTAX_HIGHLIGHTING_STYLES[back-double-quoted-argument] + (( k += 1 )) # Color following char too. + (( i += 1 )) # Skip parsing the escaped char. + ;; + *) continue;; + esac + region_highlight+=("$j $k $style") done }