From: Lars Ingebrigtsen Date: Mon, 28 Dec 2015 20:55:18 +0000 (+0100) Subject: shr link traversal fixup X-Git-Tag: emacs-26.0.90~2835 X-Git-Url: http://git.eshelyaron.com/gitweb/?a=commitdiff_plain;h=1efc5f8b09273c359683ce13be95fb5df7a84311;p=emacs.git shr link traversal fixup * shr.el (shr-next-link): Don't bug out on adjacent links. --- diff --git a/lisp/net/shr.el b/lisp/net/shr.el index 469ef4ec52f..0b80e81abbc 100644 --- a/lisp/net/shr.el +++ b/lisp/net/shr.el @@ -316,13 +316,25 @@ redirects somewhere else." (defun shr-next-link () "Skip to the next link." (interactive) - (let ((skip (text-property-any (point) (point-max) 'help-echo nil))) - (if (or (eobp) - (not (setq skip (text-property-not-all skip (point-max) - 'help-echo nil)))) - (message "No next link") + (let ((current (get-text-property (point) 'shr-url)) + (start (point)) + skip) + (while (and (not (eobp)) + (equal (get-text-property (point) 'shr-url) current)) + (forward-char 1)) + (cond + ((and (not (eobp)) + (get-text-property (point) 'shr-url)) + ;; The next link is adjacent. + (message "%s" (get-text-property (point) 'help-echo))) + ((or (eobp) + (not (setq skip (text-property-not-all (point) (point-max) + 'shr-url nil)))) + (goto-char start) + (message "No next link")) + (t (goto-char skip) - (message "%s" (get-text-property (point) 'help-echo))))) + (message "%s" (get-text-property (point) 'help-echo)))))) (defun shr-previous-link () "Skip to the previous link."