emacs-diffs
[Top][All Lists]
Advanced

[Date Prev][Date Next][Thread Prev][Thread Next][Date Index][Thread Index]

[Emacs-diffs] Changes to emacs/lisp/log-edit.el


From: Stefan Monnier
Subject: [Emacs-diffs] Changes to emacs/lisp/log-edit.el
Date: Sat, 31 May 2003 12:43:31 -0400

Index: emacs/lisp/log-edit.el
diff -c emacs/lisp/log-edit.el:1.21 emacs/lisp/log-edit.el:1.22
*** emacs/lisp/log-edit.el:1.21 Sat May 17 23:01:22 2003
--- emacs/lisp/log-edit.el      Sat May 31 12:43:30 2003
***************
*** 57,66 ****
    `(("\C-c\C-c" . log-edit-done)
      ("\C-c\C-a" . log-edit-insert-changelog)
      ("\C-c\C-f" . log-edit-show-files)
!     ("\M-n"   . vc-next-comment)
!     ("\M-p"   . vc-previous-comment)
!     ("\M-r"   . vc-comment-search-reverse)
!     ("\M-s"   . vc-comment-search-forward)
      ("\C-c?"  . log-edit-mode-help))
    "Keymap for the `log-edit-mode' (to edit version control log messages)."
    :group 'log-edit)
--- 57,66 ----
    `(("\C-c\C-c" . log-edit-done)
      ("\C-c\C-a" . log-edit-insert-changelog)
      ("\C-c\C-f" . log-edit-show-files)
!     ("\M-n"   . log-edit-next-comment)
!     ("\M-p"   . log-edit-previous-comment)
!     ("\M-r"   . log-edit-comment-search-backward)
!     ("\M-s"   . log-edit-comment-search-forward)
      ("\C-c?"  . log-edit-mode-help))
    "Keymap for the `log-edit-mode' (to edit version control log messages)."
    :group 'log-edit)
***************
*** 81,90 ****
      ["List files" log-edit-show-files
       :help "Show the list of relevant files."]
      "--"
!     ["Previous comment" vc-previous-comment]
!     ["Next comment" vc-next-comment]
!     ["Search comment forward" vc-comment-search-forward]
!     ["Search comment backward" vc-comment-search-reverse]))
  
  (defcustom log-edit-confirm 'changed
    "*If non-nil, `log-edit-done' will request confirmation.
--- 81,90 ----
      ["List files" log-edit-show-files
       :help "Show the list of relevant files."]
      "--"
!     ["Previous comment"               log-edit-previous-comment]
!     ["Next comment"           log-edit-next-comment]
!     ["Search comment forward" log-edit-comment-search-forward]
!     ["Search comment backward"        log-edit-comment-search-backward]))
  
  (defcustom log-edit-confirm 'changed
    "*If non-nil, `log-edit-done' will request confirmation.
***************
*** 170,188 ****
  (defvar log-edit-listfun nil)
  (defvar log-edit-parent-buffer nil)
  
! ;;; Taken from VC-Log mode
  
! (defconst vc-maximum-comment-ring-size 32
    "Maximum number of saved comments in the comment ring.")
! (defvar vc-comment-ring (make-ring vc-maximum-comment-ring-size))
! (defvar vc-comment-ring-index nil)
! (defvar vc-last-comment-match "")
  
! (defun vc-new-comment-index (stride len)
    "Return the comment index STRIDE elements from the current one.
! LEN is the length of `vc-comment-ring'."
    (mod (cond
!       (vc-comment-ring-index (+ vc-comment-ring-index stride))
        ;; Initialize the index on the first use of this command
        ;; so that the first M-p gets index 0, and the first M-n gets
        ;; index -1.
--- 170,188 ----
  (defvar log-edit-listfun nil)
  (defvar log-edit-parent-buffer nil)
  
! ;;; Originally taken from VC-Log mode
  
! (defconst log-edit-maximum-comment-ring-size 32
    "Maximum number of saved comments in the comment ring.")
! (defvar log-edit-comment-ring (make-ring log-edit-maximum-comment-ring-size))
! (defvar log-edit-comment-ring-index nil)
! (defvar log-edit-last-comment-match "")
  
! (defun log-edit-new-comment-index (stride len)
    "Return the comment index STRIDE elements from the current one.
! LEN is the length of `log-edit-comment-ring'."
    (mod (cond
!       (log-edit-comment-ring-index (+ log-edit-comment-ring-index stride))
        ;; Initialize the index on the first use of this command
        ;; so that the first M-p gets index 0, and the first M-n gets
        ;; index -1.
***************
*** 190,255 ****
        (t stride))
         len))
  
! (defun vc-previous-comment (arg)
    "Cycle backwards through comment history.
  With a numeric prefix ARG, go back ARG comments."
    (interactive "*p")
!   (let ((len (ring-length vc-comment-ring)))
      (if (<= len 0)
        (progn (message "Empty comment ring") (ding))
        ;; Don't use `erase-buffer' because we don't want to `widen'.
        (delete-region (point-min) (point-max))
!       (setq vc-comment-ring-index (vc-new-comment-index arg len))
!       (message "Comment %d" (1+ vc-comment-ring-index))
!       (insert (ring-ref vc-comment-ring vc-comment-ring-index)))))
  
! (defun vc-next-comment (arg)
    "Cycle forwards through comment history.
  With a numeric prefix ARG, go forward ARG comments."
    (interactive "*p")
!   (vc-previous-comment (- arg)))
  
! (defun vc-comment-search-reverse (str &optional stride)
    "Search backwards through comment history for substring match of STR.
  If the optional argument STRIDE is present, that is a step-width to use
  when going through the comment ring."
    ;; Why substring rather than regexp ?   -sm
    (interactive
!    (list (read-string "Comment substring: " nil nil vc-last-comment-match)))
    (unless stride (setq stride 1))
    (if (string= str "")
!       (setq str vc-last-comment-match)
!     (setq vc-last-comment-match str))
    (let* ((str (regexp-quote str))
!        (len (ring-length vc-comment-ring))
!        (n (vc-new-comment-index stride len)))
      (while (progn (when (or (>= n len) (< n 0)) (error "Not found"))
!                 (not (string-match str (ring-ref vc-comment-ring n))))
        (setq n (+ n stride)))
!     (setq vc-comment-ring-index n)
!     (vc-previous-comment 0)))
  
! (defun vc-comment-search-forward (str)
    "Search forwards through comment history for a substring match of STR."
    (interactive
!    (list (read-string "Comment substring: " nil nil vc-last-comment-match)))
!   (vc-comment-search-reverse str -1))
  
! 
! 
! (defun vc-comment-to-change-log (&optional whoami file-name)
    "Enter last VC comment into the change log for the current file.
  WHOAMI (interactive prefix) non-nil means prompt for user name
  and site.  FILE-NAME is the name of the change log; if nil, use
  `change-log-default-name'.
  
! This may be useful as a `vc-checkin-hook' to update change logs
  automatically."
    (interactive (if current-prefix-arg
                   (list current-prefix-arg
                         (prompt-for-change-log-name))))
    (let (;; Extract the comment first so we get any error before doing 
anything.
!       (comment (ring-ref vc-comment-ring 0))
        ;; Don't let add-change-log-entry insert a defun name.
        (add-log-current-defun-function 'ignore)
        end)
--- 190,253 ----
        (t stride))
         len))
  
! (defun log-edit-previous-comment (arg)
    "Cycle backwards through comment history.
  With a numeric prefix ARG, go back ARG comments."
    (interactive "*p")
!   (let ((len (ring-length log-edit-comment-ring)))
      (if (<= len 0)
        (progn (message "Empty comment ring") (ding))
        ;; Don't use `erase-buffer' because we don't want to `widen'.
        (delete-region (point-min) (point-max))
!       (setq log-edit-comment-ring-index (log-edit-new-comment-index arg len))
!       (message "Comment %d" (1+ log-edit-comment-ring-index))
!       (insert (ring-ref log-edit-comment-ring log-edit-comment-ring-index)))))
  
! (defun log-edit-next-comment (arg)
    "Cycle forwards through comment history.
  With a numeric prefix ARG, go forward ARG comments."
    (interactive "*p")
!   (log-edit-previous-comment (- arg)))
  
! (defun log-edit-comment-search-backward (str &optional stride)
    "Search backwards through comment history for substring match of STR.
  If the optional argument STRIDE is present, that is a step-width to use
  when going through the comment ring."
    ;; Why substring rather than regexp ?   -sm
    (interactive
!    (list (read-string "Comment substring: " nil nil 
log-edit-last-comment-match)))
    (unless stride (setq stride 1))
    (if (string= str "")
!       (setq str log-edit-last-comment-match)
!     (setq log-edit-last-comment-match str))
    (let* ((str (regexp-quote str))
!        (len (ring-length log-edit-comment-ring))
!        (n (log-edit-new-comment-index stride len)))
      (while (progn (when (or (>= n len) (< n 0)) (error "Not found"))
!                 (not (string-match str (ring-ref log-edit-comment-ring n))))
        (setq n (+ n stride)))
!     (setq log-edit-comment-ring-index n)
!     (log-edit-previous-comment 0)))
  
! (defun log-edit-comment-search-forward (str)
    "Search forwards through comment history for a substring match of STR."
    (interactive
!    (list (read-string "Comment substring: " nil nil 
log-edit-last-comment-match)))
!   (log-edit-comment-search-backward str -1))
  
! (defun log-edit-comment-to-change-log (&optional whoami file-name)
    "Enter last VC comment into the change log for the current file.
  WHOAMI (interactive prefix) non-nil means prompt for user name
  and site.  FILE-NAME is the name of the change log; if nil, use
  `change-log-default-name'.
  
! This may be useful as a `log-edit-checkin-hook' to update change logs
  automatically."
    (interactive (if current-prefix-arg
                   (list current-prefix-arg
                         (prompt-for-change-log-name))))
    (let (;; Extract the comment first so we get any error before doing 
anything.
!       (comment (ring-ref log-edit-comment-ring 0))
        ;; Don't let add-change-log-entry insert a defun name.
        (add-log-current-defun-function 'ignore)
        end)
***************
*** 281,286 ****
--- 279,300 ----
      (or (eobp) (looking-at "\n\n")
        (insert "\n"))))
  
+ ;; Compatibility with old names.
+ (defvaralias 'vc-comment-ring 'log-edit-comment-ring)
+ (make-obsolete-variable 'vc-comment-ring 'log-edit-comment-ring "21.5")
+ (defvaralias 'vc-comment-ring-index 'log-edit-comment-ring-index)
+ (make-obsolete-variable 'vc-comment-ring-index 'log-edit-comment-ring-index 
"21.5")
+ (defalias 'vc-previous-comment 'log-edit-previous-comment)
+ (make-obsolete 'vc-previous-comment 'log-edit-previous-comment "21.5")
+ (defalias 'vc-next-comment 'log-edit-next-comment)
+ (make-obsolete 'vc-next-comment 'log-edit-next-comment "21.5")
+ (defalias 'vc-comment-search-reverse 'log-edit-comment-search-backward)
+ (make-obsolete 'vc-comment-search-reverse 'log-edit-comment-search-backward 
"21.5")
+ (defalias 'vc-comment-search-forward 'log-edit-comment-search-forward)
+ (make-obsolete 'vc-comment-search-forward 'log-edit-comment-search-forward 
"21.5")
+ (defalias 'vc-comment-to-change-log 'log-edit-comment-to-change-log)
+ (make-obsolete 'vc-comment-to-change-log 'log-edit-comment-to-change-log 
"21.5")
+ 
  ;;;
  ;;; Actual code
  ;;;
***************
*** 323,329 ****
  commands (under C-x v for VC, for example).
  
  \\{log-edit-mode-map}"
!   (make-local-variable 'vc-comment-ring-index))
  
  (defun log-edit-hide-buf (&optional buf where)
    (when (setq buf (get-buffer (or buf log-edit-files-buf)))
--- 337,343 ----
  commands (under C-x v for VC, for example).
  
  \\{log-edit-mode-map}"
!   (make-local-variable 'log-edit-comment-ring-index))
  
  (defun log-edit-hide-buf (&optional buf where)
    (when (setq buf (get-buffer (or buf log-edit-files-buf)))
***************
*** 352,360 ****
        (goto-char (point-max))
        (insert ?\n)))
    (let ((comment (buffer-string)))
!     (when (or (ring-empty-p vc-comment-ring)
!             (not (equal comment (ring-ref vc-comment-ring 0))))
!       (ring-insert vc-comment-ring comment)))
    (let ((win (get-buffer-window log-edit-files-buf)))
      (if (and log-edit-confirm
             (not (and (eq log-edit-confirm 'changed)
--- 366,374 ----
        (goto-char (point-max))
        (insert ?\n)))
    (let ((comment (buffer-string)))
!     (when (or (ring-empty-p log-edit-comment-ring)
!             (not (equal comment (ring-ref log-edit-comment-ring 0))))
!       (ring-insert log-edit-comment-ring comment)))
    (let ((win (get-buffer-window log-edit-files-buf)))
      (if (and log-edit-confirm
             (not (and (eq log-edit-confirm 'changed)
***************
*** 453,464 ****
    "Insert this log message into the appropriate ChangeLog file."
    (interactive)
    ;; Yuck!
!   (unless (string= (buffer-string) (ring-ref vc-comment-ring 0))
!     (ring-insert vc-comment-ring (buffer-string)))
    (dolist (f (log-edit-files))
      (let ((buffer-file-name (expand-file-name f)))
        (save-excursion
!       (vc-comment-to-change-log)))))
  
  ;;;;
  ;;;; functions for getting commit message from ChangeLog a file...
--- 467,478 ----
    "Insert this log message into the appropriate ChangeLog file."
    (interactive)
    ;; Yuck!
!   (unless (string= (buffer-string) (ring-ref log-edit-comment-ring 0))
!     (ring-insert log-edit-comment-ring (buffer-string)))
    (dolist (f (log-edit-files))
      (let ((buffer-file-name (expand-file-name f)))
        (save-excursion
!       (log-edit-comment-to-change-log)))))
  
  ;;;;
  ;;;; functions for getting commit message from ChangeLog a file...




reply via email to

[Prev in Thread] Current Thread [Next in Thread]