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:
parent
8b481fb716
commit
6a0b8c83e4
1 changed files with 19 additions and 9 deletions
28
magit.el
28
magit.el
|
@ -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
|
||||||
|
|
Loading…
Reference in a new issue