From df01192be7a249c771330e203a9ff6dbcffd72d9 Mon Sep 17 00:00:00 2001 From: "Richard M. Stallman" Date: Fri, 2 Jul 1999 12:53:04 +0000 Subject: [PATCH] (isearch-done): If search ends in middle of intangible text (due to text property), move on to the limit of that text. --- lisp/isearch.el | 23 +++++++++++++++++------ 1 file changed, 17 insertions(+), 6 deletions(-) diff --git a/lisp/isearch.el b/lisp/isearch.el index 6164498de10..59535459849 100644 --- a/lisp/isearch.el +++ b/lisp/isearch.el @@ -647,6 +647,17 @@ is treated as a regexp. See \\[isearch-forward] for more info." (force-mode-line-update) + ;; If we ended in the middle of some intangible text, + ;; move to the further end of that intangible text. + (let ((after (if (eobp) nil + (get-text-property (point) 'intangible))) + (before (if (bobp) nil + (get-text-property (1- (point)) 'intangible)))) + (when (and before after (eq before after)) + (if isearch-forward + (goto-char (next-single-property-change (point) 'intangible)) + (goto-char (previous-single-property-change (point) 'intangible))))) + (if (and (> (length isearch-string) 0) (not nopush)) ;; Update the ring data. (isearch-update-ring isearch-string isearch-regexp)) @@ -1613,13 +1624,13 @@ If there is no completion possible, say so and continue searching." ;; Check that invisibility runs up to END. (save-excursion (goto-char beg) - (let - ;; can-be-opened keeps track if we can open some overlays. - ((can-be-opened (eq search-invisible 'open)) - ;; the list of overlays that could be opened - (crt-overlays nil)) + (let ( + ;; can-be-opened keeps track if we can open some overlays. + (can-be-opened (eq search-invisible 'open)) + ;; the list of overlays that could be opened + (crt-overlays nil)) (when (and can-be-opened isearch-hide-immediately) - (isearch-close-unecessary-overlays beg end)) + (isearch-close-unecessary-overlays beg end)) ;; If the following character is currently invisible, ;; skip all characters with that same `invisible' property value. ;; Do that over and over. -- 2.39.2