summaryrefslogtreecommitdiff
path: root/lisp
diff options
context:
space:
mode:
Diffstat (limited to 'lisp')
-rw-r--r--lisp/ChangeLog9
-rw-r--r--lisp/replace.el20
2 files changed, 24 insertions, 5 deletions
diff --git a/lisp/ChangeLog b/lisp/ChangeLog
index 486e5d75343..cc3122f7e6f 100644
--- a/lisp/ChangeLog
+++ b/lisp/ChangeLog
@@ -1,5 +1,14 @@
2013-05-27 Juri Linkov <juri@jurta.org>
+ * replace.el (perform-replace): Ignore invisible matches.
+ In addition to checking `query-replace-skip-read-only', also
+ filter out matches by calling `run-hook-with-args-until-failure'
+ on `isearch-filter-predicates', and also check `search-invisible'
+ for t or call `isearch-range-invisible'.
+ (replace-dehighlight): Call `isearch-clean-overlays'. (Bug#11746)
+
+2013-05-27 Juri Linkov <juri@jurta.org>
+
* isearch.el (isearch-filter-predicates): Rename from
`isearch-filter-predicate'. Doc fix. (Bug#11378)
(isearch-message-prefix): Display text from the property
diff --git a/lisp/replace.el b/lisp/replace.el
index 1bebff448fa..7c26f1ed063 100644
--- a/lisp/replace.el
+++ b/lisp/replace.el
@@ -2003,10 +2003,18 @@ make, or the user didn't cancel the call."
match))))))
;; Optionally ignore matches that have a read-only property.
- (unless (and query-replace-skip-read-only
- (text-property-not-all
- (nth 0 real-match-data) (nth 1 real-match-data)
- 'read-only nil))
+ (when (and (or (not query-replace-skip-read-only)
+ (not (text-property-not-all
+ (nth 0 real-match-data) (nth 1 real-match-data)
+ 'read-only nil)))
+ ;; Optionally filter out matches.
+ (run-hook-with-args-until-failure
+ 'isearch-filter-predicates
+ (nth 0 real-match-data) (nth 1 real-match-data))
+ ;; Optionally ignore invisible matches.
+ (or (eq search-invisible t)
+ (not (isearch-range-invisible
+ (nth 0 real-match-data) (nth 1 real-match-data)))))
;; Calculate the replacement string, if necessary.
(when replacements
@@ -2251,6 +2259,8 @@ make, or the user didn't cancel the call."
(delete-overlay replace-overlay))
(when query-replace-lazy-highlight
(lazy-highlight-cleanup lazy-highlight-cleanup)
- (setq isearch-lazy-highlight-last-string nil)))
+ (setq isearch-lazy-highlight-last-string nil))
+ ;; Close overlays opened by `isearch-range-invisible' in `perform-replace'.
+ (isearch-clean-overlays))
;;; replace.el ends here