]> git.eshelyaron.com Git - emacs.git/commitdiff
(isearch-yank-internal): New helper function.
authorKarl Fogel <kfogel@red-bean.com>
Wed, 28 Nov 2001 22:34:20 +0000 (22:34 +0000)
committerKarl Fogel <kfogel@red-bean.com>
Wed, 28 Nov 2001 22:34:20 +0000 (22:34 +0000)
(isearch-yank-char): New function.
(isearch-yank-word, isearch-yank-line): Rewrite to use
isearch-yank-internal.

lisp/ChangeLog
lisp/isearch.el

index af7972964b9d0c11ca2d487c3ac8fd75a04d6b0c..3eef5436502b72dacfaaa8779fbff4b16e16fdb7 100644 (file)
@@ -1,3 +1,10 @@
+2001-11-28  Karl Fogel  <kfogel@red-bean.com>
+
+       * isearch.el (isearch-yank-internal): New helper function.
+       (isearch-yank-char): New function.
+       (isearch-yank-word, isearch-yank-line): Rewrite to use
+       isearch-yank-internal.
+
 2001-11-28  Eli Zaretskii  <eliz@is.elta.co.il>
 
        * mouse.el (mouse-set-font): Make it a no-op if multiple fonts
index a11783473bd5b754b7e20e0655e60c799f12ab98..4777b49b629db210d43bbf7e047087803537a215 100644 (file)
@@ -1073,24 +1073,32 @@ Otherwise invoke whatever mouse-2 is bound to outside of Isearch."
          (funcall binding click))))))
 
 
-(defun isearch-yank-word ()
-  "Pull next word from buffer into search string."
-  (interactive)
+(defun isearch-yank-internal (jumpform)
+  "Pull the text from point to the point reached by JUMPFORM.
+JUMPFORM is a lambda expression that takes no arguments and returns a
+buffer position, possibly having moved point to that position.  For
+example, it might move point forward by a word and return point, or it
+might return the position of the end of the line."
   (isearch-yank-string
    (save-excursion
      (and (not isearch-forward) isearch-other-end
          (goto-char isearch-other-end))
-     (buffer-substring-no-properties
-      (point) (progn (forward-word 1) (point))))))
+     (buffer-substring-no-properties (point) (funcall jumpform)))))
+
+(defun isearch-yank-char ()
+  "Pull next letter from buffer into search string."
+  (interactive)
+  (isearch-yank-internal (lambda () (forward-char 1) (point))))
+
+(defun isearch-yank-word ()
+  "Pull next word from buffer into search string."
+  (interactive)
+  (isearch-yank-internal (lambda () (forward-word 1) (point))))
 
 (defun isearch-yank-line ()
   "Pull rest of line from buffer into search string."
   (interactive)
-  (isearch-yank-string
-   (save-excursion
-     (and (not isearch-forward) isearch-other-end
-         (goto-char isearch-other-end))
-     (buffer-substring-no-properties (point) (line-end-position)))))
+  (isearch-yank-internal (lambda () (line-end-position))))
 
 
 (defun isearch-search-and-update ()