From: Teodor Zlatanov Date: Tue, 5 Aug 2008 18:37:12 +0000 (+0000) Subject: (change-log-next-error, change-log-mode): Add support X-Git-Tag: emacs-pretest-23.0.90~3642 X-Git-Url: http://git.eshelyaron.com/gitweb/?a=commitdiff_plain;h=7be2b0943a334fcc902c1dbf177c01f4010b2575;p=emacs.git (change-log-next-error, change-log-mode): Add support for `next-error' to call `change-log-goto-source' on named files in a ChangeLog. --- diff --git a/lisp/ChangeLog b/lisp/ChangeLog index ed10a856484..9b0e652701e 100644 --- a/lisp/ChangeLog +++ b/lisp/ChangeLog @@ -1,3 +1,9 @@ +2008-08-05 Teodor Zlatanov + + * add-log.el (change-log-next-error, change-log-mode): Add support + for `next-error' to call `change-log-goto-source' on named files + in a ChangeLog. + 2008-08-05 Jay Belanger * calc/calc.el (math-read-number): Handle all C-like languages diff --git a/lisp/add-log.el b/lisp/add-log.el index d0a21e8286e..1acc064beff 100644 --- a/lisp/add-log.el +++ b/lisp/add-log.el @@ -511,6 +511,29 @@ comma-separated list." (error (format "Cannot find matches for tag `%s' in `%s'" tag file)))))))) +(defun change-log-next-error (&optional argp reset) + "Move to the Nth (default 1) next match in an Occur mode buffer. +Compatibility function for \\[next-error] invocations." + (interactive "p") + (let* ((argp (or argp 0)) + (count (abs argp)) ; how many cycles + (down (< argp 0)) ; are we going down? (is argp negative?) + (up (not down)) + (search-function (if up 're-search-forward 're-search-backward))) + + ;; set the starting position + (goto-char (cond (reset (point-min)) + (down (line-beginning-position)) + (up (line-end-position)) + ((point)))) + + (funcall search-function change-log-file-names-re nil t count)) + + (beginning-of-line) + ;; if we found a place to visit... + (when (looking-at change-log-file-names-re) + (change-log-goto-source))) + (defvar change-log-mode-map (let ((map (make-sparse-keymap))) (define-key map [?\C-c ?\C-p] 'add-log-edit-prev-comment) @@ -997,7 +1020,10 @@ Runs `change-log-mode-hook'. (set (make-local-variable 'beginning-of-defun-function) 'change-log-beginning-of-defun) (set (make-local-variable 'end-of-defun-function) - 'change-log-end-of-defun)) + 'change-log-end-of-defun) + ;; next-error function glue + (setq next-error-function 'change-log-next-error) + (setq next-error-last-buffer (current-buffer))) (defun change-log-next-buffer (&optional buffer wrap) "Return the next buffer in the series of ChangeLog file buffers.