Checkout should ask to save some buffers if magit-save-some-buffers is

non-nil. And since this functionality is now used in three places I
also created a helper function to do it.
This commit is contained in:
Aaron Culich 2010-09-20 20:46:41 -07:00
parent dd44a02e93
commit 7cec299029

View file

@ -2658,14 +2658,35 @@ insert a line to tell how to insert more of them"
:lighter () :lighter ()
:keymap magit-status-mode-map) :keymap magit-status-mode-map)
(defun magit-save-some-buffers (&optional msg pred)
"Save some buffers if variable `magit-save-some-buffers' is non-nil.
If variable `magit-save-some-buffers' is set to 'dontask then
don't ask the user before saving the buffers, just go ahead and
do it.
Optional argument MSG is displayed in the minibuffer if variable
`magit-save-some-buffers' is nil.
Optional second argument PRED determines which buffers are considered:
If PRED is nil, all the file-visiting buffers are considered.
If PRED is t, then certain non-file buffers will also be considered.
If PRED is a zero-argument function, it indicates for each buffer whether
to consider it or not when called with that buffer current."
(interactive)
(if magit-save-some-buffers
(save-some-buffers
(eq magit-save-some-buffers 'dontask)
pred)
(when msg
(message msg))))
;;;###autoload ;;;###autoload
(defun magit-status (dir) (defun magit-status (dir)
(interactive (list (or (and (not current-prefix-arg) (interactive (list (or (and (not current-prefix-arg)
(magit-get-top-dir default-directory)) (magit-get-top-dir default-directory))
(magit-read-top-dir (and (consp current-prefix-arg) (magit-read-top-dir (and (consp current-prefix-arg)
(> (car current-prefix-arg) 4)))))) (> (car current-prefix-arg) 4))))))
(if magit-save-some-buffers (magit-save-some-buffers)
(save-some-buffers (eq magit-save-some-buffers 'dontask)))
(let ((topdir (magit-get-top-dir dir))) (let ((topdir (magit-get-top-dir dir)))
(unless topdir (unless topdir
(when (y-or-n-p (format "There is no Git repository in %S. Create one? " (when (y-or-n-p (format "There is no Git repository in %S. Create one? "
@ -2785,6 +2806,7 @@ If REVISION is a remote branch, offer to create a local tracking branch.
(if revision (if revision
(if (not (magit-maybe-create-local-tracking-branch revision)) (if (not (magit-maybe-create-local-tracking-branch revision))
(progn (progn
(magit-save-some-buffers)
(magit-run-git "checkout" (magit-rev-to-git revision)) (magit-run-git "checkout" (magit-rev-to-git revision))
(magit-update-vc-modeline default-directory))))) (magit-update-vc-modeline default-directory)))))
@ -4260,12 +4282,9 @@ With prefix force the removal even it it hasn't been merged."
(kill-buffer buffer-C) (kill-buffer buffer-C)
(when (bufferp buffer-Ancestor) (kill-buffer buffer-Ancestor)) (when (bufferp buffer-Ancestor) (kill-buffer buffer-Ancestor))
(set-window-configuration windows) (set-window-configuration windows)
(if magit-save-some-buffers (magit-save-some-buffers
(save-some-buffers "Conflict resolution finished; you may save the buffer"
(eq magit-save-some-buffers 'dontask) (lambda () (eq (current-buffer) file-buffer)))))))))
(lambda ()
(eq (current-buffer) file-buffer)))
(message "Conflict resolution finished; you may save the buffer"))))))))
(defun magit-interactive-resolve-item () (defun magit-interactive-resolve-item ()
(interactive) (interactive)