Mercurial > emacs
changeset 94587:42d33dc32553
Refactoring step.
author | Eric S. Raymond <esr@snark.thyrsus.com> |
---|---|
date | Sat, 03 May 2008 13:07:18 +0000 |
parents | d5d0ca913104 |
children | 5511b69db00e |
files | lisp/vc.el |
diffstat | 1 files changed, 9 insertions(+), 6 deletions(-) [+] |
line wrap: on
line diff
--- a/lisp/vc.el Sat May 03 12:42:54 2008 +0000 +++ b/lisp/vc.el Sat May 03 13:07:18 2008 +0000 @@ -2061,7 +2061,7 @@ (defun vc-default-extra-status-menu (backend) nil) -(defun vc-dir-mode () +(defun vc-dir-mode (entry-printer header-printer updater marker) "Major mode for showing the VC status for a directory. Marking/Unmarking key bindings and actions: m - marks a file/directory or ff the region is active, mark all the files @@ -2092,13 +2092,13 @@ (erase-buffer) (set (make-local-variable 'vc-dir-process-buffer) nil) (set (make-local-variable 'vc-ewoc) - (ewoc-create #'vc-dir-printer - #'vc-dir-header-maker)) - (add-hook 'after-save-hook 'vc-dir-mark-buffer-changed) + (ewoc-create entry-printer + header-printer)) + (add-hook 'after-save-hook marker) ;; Make sure that if the VC status buffer is killed, the update ;; process running in the background is also killed. (add-hook 'kill-buffer-query-functions 'vc-dir-kill-query nil t) - (vc-dir-refresh)) + (eval updater)) (run-hooks 'vc-dir-mode-hook)) (put 'vc-dir-mode 'mode-class 'special) @@ -2110,7 +2110,10 @@ (pop-to-buffer (vc-dir-prepare-status-buffer dir)) (if (eq major-mode 'vc-dir-mode) (vc-dir-refresh) - (vc-dir-mode))) + (vc-dir-mode #'vc-dir-printer + #'vc-dir-header-maker + #'vc-dir-mark-buffer-changed + #'vc-dir-refresh))) ;; This is used to that VC backends could add backend specific menu ;; items to vc-dir-menu-map.