From: Thierry Volpiatto Date: Mon, 4 Feb 2013 21:23:15 +0000 (-0500) Subject: * lisp/vc/vc.el (vc-next-action): Fix inf-loop. X-Git-Tag: emacs-24.3.90~173^2~7^2~148 X-Git-Url: http://git.eshelyaron.com/gitweb/?a=commitdiff_plain;h=50fdf3998794e013c5cb752962e75b883422b75b;p=emacs.git * lisp/vc/vc.el (vc-next-action): Fix inf-loop. (vc-update-change-log): Use dolist. Fixes: debbugs:13610 --- diff --git a/lisp/ChangeLog b/lisp/ChangeLog index 9a7a48b186a..671bd6bdf3f 100644 --- a/lisp/ChangeLog +++ b/lisp/ChangeLog @@ -1,3 +1,8 @@ +2013-02-04 Thierry Volpiatto + + * vc/vc.el (vc-next-action): Fix inf-loop (bug#13610). + (vc-update-change-log): Use dolist. + 2013-02-04 Chong Yidong * thingatpt.el: Rewrite the URL detection routines, absorbing some @@ -10,13 +15,13 @@ (thing-at-point-newsgroup-heads) (thing-at-point-default-mail-uri-scheme): New variables. (thing-at-point-bounds-of-url-at-point): Rewrite. Use ffap's - method to find the possible bounds of the URI at point. New - optional argument to find ill-formed URIs. + method to find the possible bounds of the URI at point. + New optional argument to find ill-formed URIs. (thing-at-point-url-at-point): Rewrite. New arguments for finding ill-formed URIs. Use thing-at-point-bounds-of-url-at-point, and the scheme-adding heuristics from ffap-url-at-point. - (thing-at-point--bounds-of-well-formed-url): New function. Do - parens matching to decide whether to include parens in the URI + (thing-at-point--bounds-of-well-formed-url): New function. + Do parens matching to decide whether to include parens in the URI (Bug#9153). * ffap.el: Require thingatpt. @@ -41,8 +46,8 @@ (tramp-handle-insert-file-contents): Use `visit' when inserting the local copy. - * net/tramp-sh.el (tramp-sh-handle-set-visited-file-modtime): Use - `remote-file-name-inhibit-cache'. + * net/tramp-sh.el (tramp-sh-handle-set-visited-file-modtime): + Use `remote-file-name-inhibit-cache'. 2013-02-03 Stefan Monnier diff --git a/lisp/vc/vc.el b/lisp/vc/vc.el index 9b8b94916c4..a0ef6f9d6d7 100644 --- a/lisp/vc/vc.el +++ b/lisp/vc/vc.el @@ -1079,15 +1079,13 @@ For old-style locking-based version control systems, like RCS: ;; If a buffer has unsaved changes, a checkout would discard those ;; changes, so treat the buffer as having unlocked changes. (when (and (not (eq model 'implicit)) (eq state 'up-to-date)) - (let ((files files)) - (while files - (let ((buffer (get-file-buffer (car files)))) - (and buffer - (buffer-modified-p buffer) - (setq state 'unlocked-changes - files nil)))))) - - ;; Do the right thing + (dolist (file files) + (let ((buffer (get-file-buffer file))) + (and buffer + (buffer-modified-p buffer) + (setq state 'unlocked-changes))))) + + ;; Do the right thing. (cond ((eq state 'missing) (error "Fileset files are missing, so cannot be operated on")) @@ -2667,14 +2665,11 @@ log entries should be gathered." (cond ((consp current-prefix-arg) ;C-u (list buffer-file-name)) (current-prefix-arg ;Numeric argument. - (let ((files nil) - (buffers (buffer-list)) - file) - (while buffers - (setq file (buffer-file-name (car buffers))) - (and file (vc-backend file) - (setq files (cons file files))) - (setq buffers (cdr buffers))) + (let ((files nil)) + (dolist (buffer (buffer-list)) + (let ((file (buffer-file-name buffer))) + (and file (vc-backend file) + (setq files (cons file files))))) files)) (t ;; Don't supply any filenames to backend; this means