summary | shortlog | log | commit | commitdiff | tree
raw | patch | inline | side by side (parent: 76127b3)
raw | patch | inline | side by side (parent: 76127b3)
author | Alexandre Julliard <julliard@winehq.org> | |
Thu, 7 Feb 2008 12:51:20 +0000 (13:51 +0100) | ||
committer | Junio C Hamano <gitster@pobox.com> | |
Fri, 8 Feb 2008 08:13:18 +0000 (00:13 -0800) |
Refuse to revert a file if it is modified in an existing buffer but
not saved. On success, revert the buffers that contains the files that
have been reverted.
Signed-off-by: Alexandre Julliard <julliard@winehq.org>
Signed-off-by: Junio C Hamano <gitster@pobox.com>
not saved. On success, revert the buffers that contains the files that
have been reverted.
Signed-off-by: Alexandre Julliard <julliard@winehq.org>
Signed-off-by: Junio C Hamano <gitster@pobox.com>
contrib/emacs/git.el | patch | blob | history |
diff --git a/contrib/emacs/git.el b/contrib/emacs/git.el
index 5519ed107a31e24ab38496e244f3667efd83d53f..e1058b9a99287e620629e0f51af5bd87767caa59 100644 (file)
--- a/contrib/emacs/git.el
+++ b/contrib/emacs/git.el
('deleted (push (git-fileinfo->name info) modified))
('unmerged (push (git-fileinfo->name info) modified))
('modified (push (git-fileinfo->name info) modified))))
+ ;; check if a buffer contains one of the files and isn't saved
+ (dolist (file (append added modified))
+ (let ((buffer (get-file-buffer file)))
+ (when (and buffer (buffer-modified-p buffer))
+ (error "Buffer %s is modified. Please kill or save modified buffers before reverting." (buffer-name buffer)))))
(when added
(apply #'git-call-process-env nil nil "update-index" "--force-remove" "--" added))
(when modified
(apply #'git-call-process-env nil nil "checkout" "HEAD" modified))
(git-update-status-files (append added modified) 'uptodate)
+ (dolist (file (append added modified))
+ (let ((buffer (get-file-buffer file)))
+ (when buffer (with-current-buffer buffer (revert-buffer t t t)))))
(git-success-message "Reverted" (git-get-filenames files)))))
(defun git-resolve-file ()