You can not select more than 25 topics Topics must start with a letter or number, can include dashes ('-') and can be up to 35 characters long.

106 lines
4.3 KiB

  1. # -------------------------------------------------------------------------------------------------
  2. # Copyright (c) 2010-2016 zsh-syntax-highlighting contributors
  3. # All rights reserved.
  4. #
  5. # Redistribution and use in source and binary forms, with or without modification, are permitted
  6. # provided that the following conditions are met:
  7. #
  8. # * Redistributions of source code must retain the above copyright notice, this list of conditions
  9. # and the following disclaimer.
  10. # * Redistributions in binary form must reproduce the above copyright notice, this list of
  11. # conditions and the following disclaimer in the documentation and/or other materials provided
  12. # with the distribution.
  13. # * Neither the name of the zsh-syntax-highlighting contributors nor the names of its contributors
  14. # may be used to endorse or promote products derived from this software without specific prior
  15. # written permission.
  16. #
  17. # THIS SOFTWARE IS PROVIDED BY THE COPYRIGHT HOLDERS AND CONTRIBUTORS "AS IS" AND ANY EXPRESS OR
  18. # IMPLIED WARRANTIES, INCLUDING, BUT NOT LIMITED TO, THE IMPLIED WARRANTIES OF MERCHANTABILITY AND
  19. # FITNESS FOR A PARTICULAR PURPOSE ARE DISCLAIMED. IN NO EVENT SHALL THE COPYRIGHT HOLDER OR
  20. # CONTRIBUTORS BE LIABLE FOR ANY DIRECT, INDIRECT, INCIDENTAL, SPECIAL, EXEMPLARY, OR CONSEQUENTIAL
  21. # DAMAGES (INCLUDING, BUT NOT LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS OR SERVICES; LOSS OF USE,
  22. # DATA, OR PROFITS; OR BUSINESS INTERRUPTION) HOWEVER CAUSED AND ON ANY THEORY OF LIABILITY, WHETHER
  23. # IN CONTRACT, STRICT LIABILITY, OR TORT (INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY OUT
  24. # OF THE USE OF THIS SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF SUCH DAMAGE.
  25. # -------------------------------------------------------------------------------------------------
  26. # -*- mode: zsh; sh-indentation: 2; indent-tabs-mode: nil; sh-basic-offset: 2; -*-
  27. # vim: ft=zsh sw=2 ts=2 et
  28. # -------------------------------------------------------------------------------------------------
  29. # Define default styles.
  30. : ${ZSH_HIGHLIGHT_STYLES[bracket-error]:=fg=red,bold}
  31. : ${ZSH_HIGHLIGHT_STYLES[bracket-level-1]:=fg=blue,bold}
  32. : ${ZSH_HIGHLIGHT_STYLES[bracket-level-2]:=fg=green,bold}
  33. : ${ZSH_HIGHLIGHT_STYLES[bracket-level-3]:=fg=magenta,bold}
  34. : ${ZSH_HIGHLIGHT_STYLES[bracket-level-4]:=fg=yellow,bold}
  35. : ${ZSH_HIGHLIGHT_STYLES[bracket-level-5]:=fg=cyan,bold}
  36. : ${ZSH_HIGHLIGHT_STYLES[cursor-matchingbracket]:=standout}
  37. # Whether the brackets highlighter should be called or not.
  38. _zsh_highlight_highlighter_brackets_predicate()
  39. {
  40. [[ $WIDGET == zle-line-finish ]] || _zsh_highlight_cursor_moved || _zsh_highlight_buffer_modified
  41. }
  42. # Brackets highlighting function.
  43. _zsh_highlight_highlighter_brackets_paint()
  44. {
  45. local char style
  46. local -i bracket_color_size=${#ZSH_HIGHLIGHT_STYLES[(I)bracket-level-*]} buflen=${#BUFFER} level=0 matchingpos pos
  47. local -A levelpos lastoflevel matching
  48. # Find all brackets and remember which one is matching
  49. for (( pos = 1; pos <= buflen; pos++ )) ; do
  50. char=$BUFFER[pos]
  51. case $char in
  52. ["([{"])
  53. levelpos[$pos]=$((++level))
  54. lastoflevel[$level]=$pos
  55. ;;
  56. [")]}"])
  57. if (( level > 0 )); then
  58. matchingpos=$lastoflevel[$level]
  59. levelpos[$pos]=$((level--))
  60. if _zsh_highlight_brackets_match $matchingpos $pos; then
  61. matching[$matchingpos]=$pos
  62. matching[$pos]=$matchingpos
  63. fi
  64. else
  65. levelpos[$pos]=-1
  66. fi
  67. ;;
  68. esac
  69. done
  70. # Now highlight all found brackets
  71. for pos in ${(k)levelpos}; do
  72. if (( $+matching[$pos] )); then
  73. if (( bracket_color_size )); then
  74. _zsh_highlight_add_highlight $((pos - 1)) $pos bracket-level-$(( (levelpos[$pos] - 1) % bracket_color_size + 1 ))
  75. fi
  76. else
  77. _zsh_highlight_add_highlight $((pos - 1)) $pos bracket-error
  78. fi
  79. done
  80. # If cursor is on a bracket, then highlight corresponding bracket, if any.
  81. if [[ $WIDGET != zle-line-finish ]]; then
  82. pos=$((CURSOR + 1))
  83. if (( $+levelpos[$pos] )) && (( $+matching[$pos] )); then
  84. local -i otherpos=$matching[$pos]
  85. _zsh_highlight_add_highlight $((otherpos - 1)) $otherpos cursor-matchingbracket
  86. fi
  87. fi
  88. }
  89. # Helper function to differentiate type
  90. _zsh_highlight_brackets_match()
  91. {
  92. case $BUFFER[$1] in
  93. \() [[ $BUFFER[$2] == \) ]];;
  94. \[) [[ $BUFFER[$2] == \] ]];;
  95. \{) [[ $BUFFER[$2] == \} ]];;
  96. *) false;;
  97. esac
  98. }