1
0
mirror of https://git.savannah.gnu.org/git/emacs.git synced 2025-01-21 18:23:59 +00:00

Add more isearch submatch faces

* doc/emacs/search.texi (Search Customizations): Adjust
documentation.
* lisp/isearch.el (search-highlight-submatches): Be a boolean.
(isearch-group-{6-9}): New faces.
(isearch-highlight): Use the variable as a boolean.
This commit is contained in:
Lars Ingebrigtsen 2020-09-21 15:56:55 +02:00
parent ebad35e4d9
commit d2b754ec1a
3 changed files with 54 additions and 22 deletions

View File

@ -1981,15 +1981,13 @@ setting the variable @code{search-highlight} to @code{nil}.
When searching for regular expressions (with @kbd{C-M-s}, for When searching for regular expressions (with @kbd{C-M-s}, for
instance), subexpressions receive special highlighting depending on instance), subexpressions receive special highlighting depending on
the @code{search-highlight-submatches} variable. If this variable's the @code{search-highlight-submatches} variable. If this variable's
value is zero, no special highlighting is done, but if the value is a value is @code{nil}, no special highlighting is done, but if the value
positive integer @var{n}, the strings matching the first @var{n} is non-@code{nil}, text that matches @samp{\( @dots{} \)} constructs
@samp{\( @dots{} \)} constructs (a.k.a.@: ``subexpressions'') in the (a.k.a.@: ``subexpressions'') in the regular expression will be
regular expression will be highlighted with distinct faces, named highlighted with distinct faces, named @code{isearch-group-@var{n}}.
@code{isearch-group-@var{n}}. For instance, when searching for For instance, when searching for @samp{foo-\([0-9]+\)}, the part
@samp{foo-\([0-9]+\)}, the part matched by @samp{[0-9]+} will be matched by @samp{[0-9]+} will be highlighted with the
highlighted with the @code{isearch-group-1} face if @code{isearch-group-1} face.
@code{search-highlight-submatches} is greater or equal to 1. The
default value of @code{search-highlight-submatches} is 5.
@cindex lazy highlighting customizations @cindex lazy highlighting customizations
@vindex isearch-lazy-highlight @vindex isearch-lazy-highlight

View File

@ -1046,8 +1046,7 @@ window after starting). This variable defaults to nil.
*** Interactive regular expression search now uses faces for sub-groups. *** Interactive regular expression search now uses faces for sub-groups.
E.g., 'C-M-s foo-\([0-9]+\)' will now use the 'isearch-group-1' face E.g., 'C-M-s foo-\([0-9]+\)' will now use the 'isearch-group-1' face
on the part of the regexp that matches the sub-expression "[0-9]+". on the part of the regexp that matches the sub-expression "[0-9]+".
This is controlled by the 'search-highlight-submatches' variable, This is controlled by the 'search-highlight-submatches' variable.
whose default value is 5.
--- ---
*** New user option 'reveal-auto-hide'. *** New user option 'reveal-auto-hide'.

View File

@ -269,17 +269,12 @@ are `word-search-regexp' \(`\\[isearch-toggle-word]'), `isearch-symbol-regexp'
"Non-nil means incremental search highlights the current match." "Non-nil means incremental search highlights the current match."
:type 'boolean) :type 'boolean)
(defcustom search-highlight-submatches 5 (defcustom search-highlight-submatches t
"Whether to highlight regexp subexpressions of the current regexp match. "Whether to highlight regexp subexpressions of the current regexp match.
A positive integer N means highlight regexp subexpressions 1 to N.
When 0, do not highlight regexp subexpressions. A negative value is
treated as zero.
The faces used to do the highlights are named `isearch-group-1', The faces used to do the highlights are named `isearch-group-1',
`isearch-group-2', and so on, and if you increase this variable from `isearch-group-2', and so on."
the default, you have to add more of these faces." :type 'boolean
:type 'integer
:version "28.1") :version "28.1")
(defface isearch (defface isearch
@ -3719,6 +3714,47 @@ since they have special meaning in a regexp."
:group 'isearch :group 'isearch
:version "28.1") :version "28.1")
(defface isearch-group-6
'((((class color) (background light))
(:background "#500050" :foreground "lightskyblue1"))
(((class color) (background dark))
(:background "#703050" :foreground "white"))
(t (:inverse-video t)))
"Face for highlighting Isearch sub-group matches (sixth sub-group)."
:group 'isearch
:version "28.1")
(defface isearch-group-7
'((((class color) (background light))
(:background "#400040" :foreground "lightskyblue1"))
(((class color) (background dark))
(:background "#602050" :foreground "white"))
(t (:inverse-video t)))
"Face for highlighting Isearch sub-group matches (seventh sub-group)."
:group 'isearch
:version "28.1")
(defface isearch-group-8
'((((class color) (background light))
(:background "#300030" :foreground "lightskyblue1"))
(((class color) (background dark))
(:background "#501050" :foreground "white"))
(t (:inverse-video t)))
"Face for highlighting Isearch sub-group matches (eighth sub-group)."
:group 'isearch
:version "28.1")
(defface isearch-group-9
'((((class color) (background light))
(:background "#200020" :foreground "lightskyblue1"))
(((class color) (background dark))
(:background "#400040" :foreground "white"))
(t (:inverse-video t)))
"Face for highlighting Isearch sub-group matches (ninth sub-group)."
:group 'isearch
:version "28.1")
(defun isearch-highlight (beg end) (defun isearch-highlight (beg end)
(if search-highlight (if search-highlight
(if isearch-overlay (if isearch-overlay
@ -3729,13 +3765,12 @@ since they have special meaning in a regexp."
;; 1001 is higher than lazy's 1000 and ediff's 100+ ;; 1001 is higher than lazy's 1000 and ediff's 100+
(overlay-put isearch-overlay 'priority 1001) (overlay-put isearch-overlay 'priority 1001)
(overlay-put isearch-overlay 'face isearch-face))) (overlay-put isearch-overlay 'face isearch-face)))
(when (and (integerp search-highlight-submatches) (when (and search-highlight-submatches
(> search-highlight-submatches 0)
isearch-regexp) isearch-regexp)
(mapc 'delete-overlay isearch-submatches-overlays) (mapc 'delete-overlay isearch-submatches-overlays)
(setq isearch-submatches-overlays nil) (setq isearch-submatches-overlays nil)
(let ((i 0) ov) (let ((i 0) ov)
(while (<= i search-highlight-submatches) (while (<= i 9)
(when (match-beginning i) (when (match-beginning i)
(setq ov (make-overlay (match-beginning i) (match-end i))) (setq ov (make-overlay (match-beginning i) (match-end i)))
(overlay-put ov 'face (intern-soft (format "isearch-group-%d" i))) (overlay-put ov 'face (intern-soft (format "isearch-group-%d" i)))