diff options
author | Dmitry Gutov <dgutov@yandex.ru> | 2015-04-19 22:24:39 +0300 |
---|---|---|
committer | Dmitry Gutov <dgutov@yandex.ru> | 2015-04-19 22:24:39 +0300 |
commit | b5b0e0500eb6fac1b0b2e9ca4da08826225b010b (patch) | |
tree | 4160097f23b194704a6fc7efdaceb238837ef155 | |
parent | f5076daca0c640cd53b2fb71ab693db3c83ad020 (diff) | |
download | emacs-b5b0e0500eb6fac1b0b2e9ca4da08826225b010b.tar.gz |
Call `smerge-start-session' even when dealing with a stash conflict
* lisp/vc/vc-git.el (vc-git-find-file-hook):
Call `smerge-start-session' even when dealing with a stash
conflict (bug#20292).
-rw-r--r-- | lisp/vc/vc-git.el | 35 |
1 files changed, 20 insertions, 15 deletions
diff --git a/lisp/vc/vc-git.el b/lisp/vc/vc-git.el index 8f7015e0c5f..bec36fd3e98 100644 --- a/lisp/vc/vc-git.el +++ b/lisp/vc/vc-git.el @@ -792,21 +792,26 @@ This prompts for a branch to merge from." (defun vc-git-find-file-hook () "Activate `smerge-mode' if there is a conflict." - (when (and buffer-file-name - ;; FIXME - ;; 1) the net result is to call git twice per file. - ;; 2) v-g-c-f is documented to take a directory. - ;; http://lists.gnu.org/archive/html/emacs-devel/2014-01/msg01126.html - (vc-git-conflicted-files buffer-file-name) - (save-excursion - (goto-char (point-min)) - (and (re-search-forward "^>>>>>>> " nil 'noerror) - ;; Stashes are tricky (bug#20292). - (not (looking-at "Stashed changes"))))) - (vc-file-setprop buffer-file-name 'vc-state 'conflict) - (smerge-start-session) - (add-hook 'after-save-hook 'vc-git-resolve-when-done nil 'local) - (message "There are unresolved conflicts in this file"))) + (let (stashed) + (when (and buffer-file-name + ;; FIXME + ;; 1) the net result is to call git twice per file. + ;; 2) v-g-c-f is documented to take a directory. + ;; http://lists.gnu.org/archive/html/emacs-devel/2014-01/msg01126.html + ;; XXX: Should we first look for the markers, and only + ;; call this function when see some? + (vc-git-conflicted-files buffer-file-name) + (save-excursion + (goto-char (point-min)) + (when (re-search-forward "^>>>>>>> " nil 'noerror) + (setq stashed (looking-at "Stashed changes")) + t))) + (vc-file-setprop buffer-file-name 'vc-state 'conflict) + (smerge-start-session) + (unless stashed + ;; Stashes are tricky (bug#20292). + (add-hook 'after-save-hook 'vc-git-resolve-when-done nil 'local)) + (message "There are unresolved conflicts in this file")))) ;;; HISTORY FUNCTIONS |