From 05e4a031c7e7fdeed7975f6904dea86bdfda97db Mon Sep 17 00:00:00 2001 From: garinger Date: Tue, 12 Jul 2011 07:56:12 -0700 Subject: [PATCH] * remove a safety belt - no need to check if array has elements, as defaults are provided * reuse $pos instead of using another variable * remove declaration forgotten in last commit --- .../brackets/brackets-highlighter.zsh | 76 +++++++++---------- 1 file changed, 37 insertions(+), 39 deletions(-) diff --git a/highlighters/brackets/brackets-highlighter.zsh b/highlighters/brackets/brackets-highlighter.zsh index a1e59cd..46ab7bd 100644 --- a/highlighters/brackets/brackets-highlighter.zsh +++ b/highlighters/brackets/brackets-highlighter.zsh @@ -46,45 +46,43 @@ _zsh_highlight_brackets_highlighter_predicate() # Brackets highlighting function. _zsh_highlight_brackets_highlighter() { - local bracket_color_size=${#ZSH_HIGHLIGHT_STYLES[(I)bracket-level-*]} - if ((bracket_color_size > 0)); then - local c level pos - typeset -A levelpos lastoflevel matching typepos revmatching - ((level = 0)) - for pos in {1..${#BUFFER}}; do - case $BUFFER[pos] in - "("|"["|"{") - levelpos[$pos]=$((++level)) - lastoflevel[$level]=$pos - typepos[$pos]=$BUFFER[$pos] - ;; - ")"|"]"|"}") - matching[$lastoflevel[$level]]=$pos - matching[$pos]=$lastoflevel[$level] - levelpos[$pos]=$((level--)) - typepos[$pos]=$BUFFER[$pos] - ;; - esac - done - for pos in ${(k)typepos}; do - typepos[$pos]=${typepos[${pos}]/["()"]/round} - typepos[$pos]=${typepos[${pos}]/["[]"]/square} - typepos[$pos]=${typepos[${pos}]/["{}"]/curly} - done - for pos in ${(k)levelpos}; do - if [[ -z $matching[$pos] ]] || [[ $typepos[$pos] != $typepos[$matching[$pos]] ]]; then - region_highlight+=("$((pos - 1)) $pos "$ZSH_HIGHLIGHT_STYLES[bracket-error]) - else - local style=bracket-level-$(( (levelpos[$pos] - 1) % bracket_color_size + 1 )) - region_highlight+=("$((pos - 1)) $pos "$ZSH_HIGHLIGHT_STYLES[$style]) - fi - done - ((c = CURSOR + 1)) - if [[ -n $levelpos[$c] ]]; then - local otherpos - ((otherpos = -1)) - [[ -n $matching[$c] ]] && otherpos=$matching[$c] - region_highlight+=("$((otherpos - 1)) $otherpos standout") + local level pos + local -A levelpos lastoflevel matching typepos + ((level = 0)) + for pos in {1..${#BUFFER}}; do + case $BUFFER[pos] in + "("|"["|"{") + levelpos[$pos]=$((++level)) + lastoflevel[$level]=$pos + typepos[$pos]=$BUFFER[$pos] + ;; + ")"|"]"|"}") + matching[$lastoflevel[$level]]=$pos + matching[$pos]=$lastoflevel[$level] + levelpos[$pos]=$((level--)) + typepos[$pos]=$BUFFER[$pos] + ;; + esac + done + for pos in ${(k)typepos}; do + typepos[$pos]=${typepos[${pos}]/["()"]/round} + typepos[$pos]=${typepos[${pos}]/["[]"]/square} + typepos[$pos]=${typepos[${pos}]/["{}"]/curly} + done + for pos in ${(k)levelpos}; do + if [[ -z $matching[$pos] ]] || [[ $typepos[$pos] != $typepos[$matching[$pos]] ]]; then + region_highlight+=("$((pos - 1)) $pos "$ZSH_HIGHLIGHT_STYLES[bracket-error]) + else + local bracket_color_size=${#ZSH_HIGHLIGHT_STYLES[(I)bracket-level-*]} + local style=bracket-level-$(( (levelpos[$pos] - 1) % bracket_color_size + 1 )) + region_highlight+=("$((pos - 1)) $pos "$ZSH_HIGHLIGHT_STYLES[$style]) fi + done + ((pos = CURSOR + 1)) + if [[ -n $levelpos[$pos] ]]; then + local otherpos + ((otherpos = -1)) + [[ -n $matching[$pos] ]] && otherpos=$matching[$pos] + region_highlight+=("$((otherpos - 1)) $otherpos standout") fi }