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.

107 lines
4.3 KiB

3 years ago
  1. # -------------------------------------------------------------------------------------------------
  2. # Copyright (c) 2010-2017 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. pos=0
  50. for char in ${(s..)BUFFER} ; do
  51. (( ++pos ))
  52. case $char in
  53. ["([{"])
  54. levelpos[$pos]=$((++level))
  55. lastoflevel[$level]=$pos
  56. ;;
  57. [")]}"])
  58. if (( level > 0 )); then
  59. matchingpos=$lastoflevel[$level]
  60. levelpos[$pos]=$((level--))
  61. if _zsh_highlight_brackets_match $matchingpos $pos; then
  62. matching[$matchingpos]=$pos
  63. matching[$pos]=$matchingpos
  64. fi
  65. else
  66. levelpos[$pos]=-1
  67. fi
  68. ;;
  69. esac
  70. done
  71. # Now highlight all found brackets
  72. for pos in ${(k)levelpos}; do
  73. if (( $+matching[$pos] )); then
  74. if (( bracket_color_size )); then
  75. _zsh_highlight_add_highlight $((pos - 1)) $pos bracket-level-$(( (levelpos[$pos] - 1) % bracket_color_size + 1 ))
  76. fi
  77. else
  78. _zsh_highlight_add_highlight $((pos - 1)) $pos bracket-error
  79. fi
  80. done
  81. # If cursor is on a bracket, then highlight corresponding bracket, if any.
  82. if [[ $WIDGET != zle-line-finish ]]; then
  83. pos=$((CURSOR + 1))
  84. if (( $+levelpos[$pos] )) && (( $+matching[$pos] )); then
  85. local -i otherpos=$matching[$pos]
  86. _zsh_highlight_add_highlight $((otherpos - 1)) $otherpos cursor-matchingbracket
  87. fi
  88. fi
  89. }
  90. # Helper function to differentiate type
  91. _zsh_highlight_brackets_match()
  92. {
  93. case $BUFFER[$1] in
  94. \() [[ $BUFFER[$2] == \) ]];;
  95. \[) [[ $BUFFER[$2] == \] ]];;
  96. \{) [[ $BUFFER[$2] == \} ]];;
  97. *) false;;
  98. esac
  99. }