summaryrefslogtreecommitdiff
path: root/lisp/textmodes/paragraphs.el
diff options
context:
space:
mode:
authorJuri Linkov <juri@linkov.net>2021-12-29 21:10:04 +0200
committerJuri Linkov <juri@linkov.net>2021-12-29 21:10:04 +0200
commitfb4f2aa0389d7d10dfcc1b6d8601c2d5e80730f0 (patch)
tree35a0ebdec29afe7718ff73a21b59e7c6fb3ccc6b /lisp/textmodes/paragraphs.el
parent3fc8032a1aac535e8f6ba03547bd9fa2b0880193 (diff)
downloademacs-fb4f2aa0389d7d10dfcc1b6d8601c2d5e80730f0.tar.gz
* lisp/textmodes/paragraphs.el (repunctuate-sentences-filter): New function.
(repunctuate-sentences): Use it on isearch-filter-predicate to skip unnecessary matches. (bug#52769)
Diffstat (limited to 'lisp/textmodes/paragraphs.el')
-rw-r--r--lisp/textmodes/paragraphs.el18
1 files changed, 16 insertions, 2 deletions
diff --git a/lisp/textmodes/paragraphs.el b/lisp/textmodes/paragraphs.el
index acb26fd1c12..788230141e7 100644
--- a/lisp/textmodes/paragraphs.el
+++ b/lisp/textmodes/paragraphs.el
@@ -479,6 +479,14 @@ sentences. Also, every paragraph boundary terminates sentences as well."
(setq arg (1- arg)))
(constrain-to-field nil opoint t)))
+(defun repunctuate-sentences-filter (_start _end)
+ "Search filter used by `repunctuate-sentences' to skip unneeded spaces.
+By default, it skips occurrences that already have two spaces.
+It is advised to put `advice-add' on this function to add more filters,
+for example, `(looking-back (rx (or \"e.g.\" \"i.e.\") \" \") 5)'
+with a set of predefined abbreviations to skip from adding two spaces."
+ (not (length= (match-string 4) 2)))
+
(defun repunctuate-sentences (&optional no-query start end)
"Put two spaces at the end of sentences from point to the end of buffer.
It works using `query-replace-regexp'. In Transient Mark mode,
@@ -489,14 +497,20 @@ asking for confirmation."
(interactive (list nil
(if (use-region-p) (region-beginning))
(if (use-region-p) (region-end))))
- (let ((regexp "\\([]\"')]?\\)\\([.?!]\\)\\([]\"')]?\\) +")
+ (let ((regexp "\\([]\"')]?\\)\\([.?!]\\)\\([]\"')]?\\)\\( +\\)")
(to-string "\\1\\2\\3 "))
(if no-query
(progn
(when start (goto-char start))
(while (re-search-forward regexp end t)
(replace-match to-string)))
- (query-replace-regexp regexp to-string nil start end))))
+ (unwind-protect
+ (progn
+ (add-function :after-while isearch-filter-predicate
+ #'repunctuate-sentences-filter)
+ (query-replace-regexp regexp to-string nil start end))
+ (remove-function isearch-filter-predicate
+ #'repunctuate-sentences-filter)))))
(defun backward-sentence (&optional arg)