From: Richard M. Stallman Date: Sun, 2 Jan 1994 17:43:16 +0000 (+0000) Subject: (isearch-repeat): If we matched a null string and there's X-Git-Tag: emacs-19.34~10440 X-Git-Url: http://git.eshelyaron.com/gitweb/?a=commitdiff_plain;h=6fefdc4b48213f269c70b269b7bac93283a05056;p=emacs.git (isearch-repeat): If we matched a null string and there's no place to advance to, fail instead. --- diff --git a/lisp/isearch.el b/lisp/isearch.el index ba24618d1a6..c157f51ecd2 100644 --- a/lisp/isearch.el +++ b/lisp/isearch.el @@ -4,7 +4,7 @@ ;; Author: Daniel LaLiberte -;; |$Date: 1993/12/24 03:30:11 $|$Revision: 1.57 $ +;; |$Date: 1993/12/25 00:50:10 $|$Revision: 1.58 $ ;; This file is part of GNU Emacs. @@ -838,14 +838,21 @@ Use `isearch-exit' to quit without signalling." (setq isearch-forward (not isearch-forward))) (setq isearch-barrier (point)) ; For subsequent \| if regexp. - (setq isearch-success t) - (or (equal isearch-string "") - (progn + + (if (equal isearch-string "") + (setq isearch-success t) + (if (and isearch-success (equal (match-end 0) (match-beginning 0))) ;; If repeating a search that found ;; an empty string, ensure we advance. - (if (equal (match-end 0) (match-beginning 0)) - (forward-char (if isearch-forward 1 -1))) - (isearch-search))) + (if (if isearch-forward (eobp) (bobp)) + ;; If there's nowhere to advance to, fail (and wrap next time). + (progn + (setq isearch-success nil) + (ding)) + (forward-char (if isearch-forward 1 -1)) + (isearch-search)) + (isearch-search))) + (isearch-push-state) (isearch-update))