Pre-fill the log-edit buffer for reverts and cherry-picks.

* magit.el (magit-append-to-log-edit, magit-escape-for-shell,
magit-format-commit): New.
(magit-apply-item, magit-revert-item): Use them.
This commit is contained in:
Marius Vollmer 2008-08-30 21:15:02 +03:00
parent 226ad5a956
commit 45bff9c642

View file

@ -1019,16 +1019,34 @@ Please see the manual for a complete description of Magit.
(or commit (or commit
(error "No commit at point."))))) (error "No commit at point.")))))
(defun magit-append-to-log-edit (str)
(save-excursion
(set-buffer (get-buffer-create "*magit-log-edit*"))
(goto-char (point-max))
(insert str "\n")))
(defun magit-escape-for-shell (str)
(concat "'" (replace-regexp-in-string "'" "'\\''" str) "'"))
(defun magit-format-commit (commit format)
(magit-shell "git log --max-count=1 --pretty=format:%s %s"
(magit-escape-for-shell format)
commit))
(defun magit-apply-item () (defun magit-apply-item ()
(interactive) (interactive)
(magit-item-case (item info "apply") (magit-item-case (item info "apply")
((commit) ((commit)
(magit-append-to-log-edit
(magit-format-commit info "%s%n%n%b%n(Cherrypicked from %H)"))
(magit-run "git" "cherry-pick" "--no-commit" info)))) (magit-run "git" "cherry-pick" "--no-commit" info))))
(defun magit-revert-item () (defun magit-revert-item ()
(interactive) (interactive)
(magit-item-case (item info "revert") (magit-item-case (item info "revert")
((commit) ((commit)
(magit-append-to-log-edit
(magit-format-commit info "Reverting %h, %s"))
(magit-run "git" "revert" "--no-commit" info)))) (magit-run "git" "revert" "--no-commit" info))))
(defvar magit-currently-shown-commit nil) (defvar magit-currently-shown-commit nil)