emacs-elpa-diffs
[Top][All Lists]
Advanced

[Date Prev][Date Next][Thread Prev][Thread Next][Date Index][Thread Index]

[elpa] externals/substitute be5b7f3e71 11/39: Streamline all commands wi


From: ELPA Syncer
Subject: [elpa] externals/substitute be5b7f3e71 11/39: Streamline all commands with a macro
Date: Mon, 16 Jan 2023 11:58:48 -0500 (EST)

branch: externals/substitute
commit be5b7f3e7193206e080b860d1a25cb72af04d9e8
Author: Protesilaos Stavrou <info@protesilaos.com>
Commit: Protesilaos Stavrou <info@protesilaos.com>

    Streamline all commands with a macro
---
 README.md     |  2 +-
 substitute.el | 63 ++++++++++++++++++++++++++++-------------------------------
 2 files changed, 31 insertions(+), 34 deletions(-)

diff --git a/README.md b/README.md
index 0af9cfae6a..f3e0b08c64 100644
--- a/README.md
+++ b/README.md
@@ -22,7 +22,7 @@ Sample configuration:
   (define-key map (kbd "M-# s") #'substitute-target-below-point)
   (define-key map (kbd "M-# r") #'substitute-target-above-point)
   (define-key map (kbd "M-# d") #'substitute-target-in-function)
-  (define-key map (kbd "M-# M-#") #'substitute-target))
+  (define-key map (kbd "M-# b") #'substitute-target-in-buffer))
 ```
 
 + Package name (GNU ELPA): `substitute` (not available yet)
diff --git a/substitute.el b/substitute.el
index 8fecdafc35..93c2df63f0 100644
--- a/substitute.el
+++ b/substitute.el
@@ -185,49 +185,46 @@ Report a `user-error' if no target is found."
    (t (or (format "\\_<%s\\_>" (thing-at-point 'symbol t))
           (user-error "No substitution target at point")))))
 
-;;;###autoload
-(defun substitute-target (target sub &optional narrow)
-  "Replace TARGET with SUB throughout the buffer.
+(defmacro substitute-command (fn doc scope)
+  "Produce substitute command using FN, DOC, and SCOPE."
+  `(defun ,fn (target sub)
+     ,(format
+      "Replace TARGET with SUB %s.
 
-When called interactively, TARGET is the target at point and
-SUB is a string that is provided at the minibuffer
-prompt.
+When called interactively, TARGET is the symbol at point and SUB
+is a string that is provided at the minibuffer prompt.
 
 If the region is active, TARGET is the text within the region's
-boundaries.
+boundaries." doc)
+     (interactive
+      (let ((target (substitute--target)))
+        (list target
+              (substitute--prompt target current-prefix-arg))))
+     (substitute--operate target sub ,scope)))
 
-With optional NARROW as a prefix argument, limit the substitution
-to the current function by using `narrow-to-defun'."
-  (interactive
-   (let ((target (substitute--target)))
-     (list target
-           (substitute--prompt target current-prefix-arg)
-           current-prefix-arg)))
-  (substitute--operate target sub (when narrow 'defun)))
+;;;###autoload
+(substitute-command
+ substitute-target-in-buffer
+ "throughout the buffer"
+ nil)
 
 ;;;###autoload
-(defun substitute-target-in-function ()
-  "Replace target at point in the scope of the currenct function.
-This is the same as calling `narrow-to-defun' before
-`substitute-target' OR invoking the latter command with its
-NARROW prefix argument."
-  (interactive)
-  (let ((target (substitute--target)))
-    (substitute--operate target (substitute--prompt target 'defun) 'defun)))
+(substitute-command
+ substitute-target-in-function
+ "in the defun (per `narrow-to-defun')"
+ 'defun)
 
 ;;;###autoload
-(defun substitute-target-below-point ()
-  "Replace target from point to the end of the buffer."
-  (interactive)
-  (let ((target (substitute--target)))
-    (substitute--operate target (substitute--prompt target 'below) 'below)))
+(substitute-command
+ substitute-target-below-point
+ "to the end of the buffer"
+ 'below)
 
 ;;;###autoload
-(defun substitute-target-above-point ()
-  "Replace target from point to the end of the buffer."
-  (interactive)
-  (let ((target (substitute--target)))
-    (substitute--operate target (substitute--prompt target 'above) 'above)))
+(substitute-command
+ substitute-target-above-point
+ "to the beginning of the buffer"
+ 'above)
 
 (defun substitute-report-operation (target sub count scope)
   "Print message of substitution.



reply via email to

[Prev in Thread] Current Thread [Next in Thread]