Declare submodes of buffer, now that all of them are in magit-mode.

* magit.el (magit-mode-init): New.
(magit-status, magit-diff, magit-log): Use it.
(magit-find-buffer, magit-find-status-buffer): Look at magit-submode.
This commit is contained in:
Marius Vollmer 2008-08-17 02:27:00 +03:00
parent 8b481fb716
commit 6a0b8c83e4

View file

@ -327,10 +327,14 @@
(defvar magit-mode-hook nil) (defvar magit-mode-hook nil)
(put 'magit-mode 'mode-class 'special) (put 'magit-mode 'mode-class 'special)
(put 'magit-marked-object 'permanent-local t)
(defvar magit-marked-object nil) (defvar magit-marked-object nil)
(make-variable-buffer-local 'magit-marked-object) (make-variable-buffer-local 'magit-marked-object)
(put 'magit-marked-object 'permanent-local t)
(defvar magit-submode nil)
(make-variable-buffer-local 'magit-submode)
(put 'magit-submode 'permanent-local t)
(defun magit-mode () (defun magit-mode ()
;;; XXX - the formatting is all screwed up because of the \\[...] ;;; XXX - the formatting is all screwed up because of the \\[...]
@ -422,6 +426,11 @@ pushed.
(use-local-map magit-mode-map) (use-local-map magit-mode-map)
(run-mode-hooks 'magit-mode-hook)) (run-mode-hooks 'magit-mode-hook))
(defun magit-mode-init (dir submode)
(setq default-directory dir
magit-submode submode)
(magit-mode))
;;; Status ;;; Status
(defun magit-wash-other-files (status) (defun magit-wash-other-files (status)
@ -540,15 +549,19 @@ pushed.
(magit-goto-section old-section)) (magit-goto-section old-section))
(magit-refresh-marks-in-buffer buf))) (magit-refresh-marks-in-buffer buf)))
(defun magit-find-status-buffer (&optional dir) (defun magit-find-buffer (submode &optional dir)
(let ((topdir (magit-get-top-dir (or dir default-directory)))) (let ((topdir (magit-get-top-dir (or dir default-directory))))
(dolist (buf (buffer-list)) (dolist (buf (buffer-list))
(if (save-excursion (if (save-excursion
(set-buffer buf) (set-buffer buf)
(and (equal default-directory topdir) (and (equal default-directory topdir)
(eq major-mode 'magit-mode))) (eq major-mode 'magit-mode)
(eq magit-submode submode)))
(return buf))))) (return buf)))))
(defun magit-find-status-buffer (&optional dir)
(magit-find-buffer 'status dir))
(defun magit-status (dir) (defun magit-status (dir)
(interactive (list (magit-read-top-dir current-prefix-arg))) (interactive (list (magit-read-top-dir current-prefix-arg)))
(save-some-buffers) (save-some-buffers)
@ -557,8 +570,7 @@ pushed.
(create-file-buffer (file-name-nondirectory (create-file-buffer (file-name-nondirectory
(directory-file-name topdir)))))) (directory-file-name topdir))))))
(switch-to-buffer buf) (switch-to-buffer buf)
(setq default-directory topdir) (magit-mode-init topdir 'status)
(magit-mode)
(magit-update-status buf))) (magit-update-status buf)))
;;; Staging ;;; Staging
@ -879,8 +891,7 @@ pushed.
(let* ((topdir (magit-get-top-dir default-directory)) (let* ((topdir (magit-get-top-dir default-directory))
(args (magit-rev-range-to-git range))) (args (magit-rev-range-to-git range)))
(switch-to-buffer "*magit-log*") (switch-to-buffer "*magit-log*")
(setq default-directory topdir) (magit-mode-init topdir 'log)
(magit-mode)
(let ((inhibit-read-only t)) (let ((inhibit-read-only t))
(save-excursion (save-excursion
(erase-buffer) (erase-buffer)
@ -906,8 +917,7 @@ pushed.
(display-buffer buf) (display-buffer buf)
(save-excursion (save-excursion
(set-buffer buf) (set-buffer buf)
(setq buffer-read-only t) (magit-mode-init dir 'diff)
(setq default-directory dir)
(let ((inhibit-read-only t)) (let ((inhibit-read-only t))
(erase-buffer) (erase-buffer)
(magit-insert-section 'diff (magit-insert-section 'diff