Fix bug in adding or removing tag by region.

There was a bug in notmuch-search-{add,remove}-tag-region, which would
not behave correctly if the region went beyond the last message. Now,
instead of simply iterating to the last line of the region, these
functions will iterate to the minimum of the last line of the region
and the last possible line, i.e.

(- (line-number-at-pos (point-max)) 2)

Tested-by: Carl Worth <cworth@cworth.org> Note that the old, buggy
behavior included infinite loops of emacs lisp code, so the new
behavior is significantly better than that.
This commit is contained in:
Jesse Rosenthal 2010-04-13 14:47:19 -04:00 committed by Carl Worth
parent 85baeb6375
commit 2fbb6d05a9

View file

@ -399,10 +399,11 @@ Complete list of currently available key bindings:
(defun notmuch-search-properties-in-region (property beg end) (defun notmuch-search-properties-in-region (property beg end)
(save-excursion (save-excursion
(let ((output nil) (let ((output nil)
(last-line (line-number-at-pos end))) (last-line (line-number-at-pos end))
(max-line (- (line-number-at-pos (point-max)) 2)))
(goto-char beg) (goto-char beg)
(beginning-of-line) (beginning-of-line)
(while (<= (line-number-at-pos) last-line) (while (<= (line-number-at-pos) (min last-line max-line))
(setq output (cons (get-text-property (point) property) output)) (setq output (cons (get-text-property (point) property) output))
(forward-line 1)) (forward-line 1))
output))) output)))
@ -497,9 +498,10 @@ and will also appear in a buffer named \"*Notmuch errors*\"."
(defun notmuch-search-get-tags-region (beg end) (defun notmuch-search-get-tags-region (beg end)
(save-excursion (save-excursion
(let ((output nil) (let ((output nil)
(last-line (line-number-at-pos end))) (last-line (line-number-at-pos end))
(max-line (- (line-number-at-pos (point-max)) 2)))
(goto-char beg) (goto-char beg)
(while (<= (line-number-at-pos) last-line) (while (<= (line-number-at-pos) (min last-line max-line))
(setq output (append output (notmuch-search-get-tags))) (setq output (append output (notmuch-search-get-tags)))
(forward-line 1)) (forward-line 1))
output))) output)))
@ -512,9 +514,10 @@ and will also appear in a buffer named \"*Notmuch errors*\"."
(let ((search-id-string (mapconcat 'identity (notmuch-search-find-thread-id-region beg end) " or "))) (let ((search-id-string (mapconcat 'identity (notmuch-search-find-thread-id-region beg end) " or ")))
(notmuch-call-notmuch-process "tag" (concat "+" tag) search-id-string) (notmuch-call-notmuch-process "tag" (concat "+" tag) search-id-string)
(save-excursion (save-excursion
(let ((last-line (line-number-at-pos end))) (let ((last-line (line-number-at-pos end))
(max-line (- (line-number-at-pos (point-max)) 2)))
(goto-char beg) (goto-char beg)
(while (<= (line-number-at-pos) last-line) (while (<= (line-number-at-pos) (min last-line max-line))
(notmuch-search-set-tags (delete-dups (sort (cons tag (notmuch-search-get-tags)) 'string<))) (notmuch-search-set-tags (delete-dups (sort (cons tag (notmuch-search-get-tags)) 'string<)))
(forward-line)))))) (forward-line))))))
@ -526,9 +529,10 @@ and will also appear in a buffer named \"*Notmuch errors*\"."
(let ((search-id-string (mapconcat 'identity (notmuch-search-find-thread-id-region beg end) " or "))) (let ((search-id-string (mapconcat 'identity (notmuch-search-find-thread-id-region beg end) " or ")))
(notmuch-call-notmuch-process "tag" (concat "-" tag) search-id-string) (notmuch-call-notmuch-process "tag" (concat "-" tag) search-id-string)
(save-excursion (save-excursion
(let ((last-line (line-number-at-pos end))) (let ((last-line (line-number-at-pos end))
(max-line (- (line-number-at-pos (point-max)) 2)))
(goto-char beg) (goto-char beg)
(while (<= (line-number-at-pos) last-line) (while (<= (line-number-at-pos) (min last-line max-line))
(notmuch-search-set-tags (delete tag (notmuch-search-get-tags))) (notmuch-search-set-tags (delete tag (notmuch-search-get-tags)))
(forward-line)))))) (forward-line))))))