Use pending commit properties when applying, cherrypicking, and reverting.

This commit is contained in:
Marius Vollmer 2008-09-09 00:41:36 +03:00
parent ff65089041
commit e4031528aa

View file

@ -1560,30 +1560,45 @@ 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-apply-commit (commit)
(magit-log-edit-append
(magit-format-commit info "%s%n%n%b"))
(magit-log-edit-set-field
'author
(magit-format-commit info "%an <%ae>, %ai"))
(magit-run-shell "git diff %s^ %s | git apply -" info info))
(defun magit-apply-item () (defun magit-apply-item ()
(interactive) (interactive)
(magit-section-case (item info "apply") (magit-section-case (item info "apply")
((pending commit)
(magit-rewrite-set-commit-property info 'used t)
(magit-apply-commit info))
((commit) ((commit)
(magit-log-edit-append (magit-apply-commit info))))
(magit-format-commit info "%s%n%n%b"))
(magit-log-edit-set-field
'author
(magit-format-commit info "%an <%ae>, %ai"))
(magit-run-shell "git diff %s^ %s | git apply -" info info))))
(defun magit-cherry-pick () (defun magit-cherry-pick ()
(interactive) (interactive)
(magit-section-case (item info "apply") (magit-section-case (item info "apply")
((pending commit)
(magit-rewrite-set-commit-property info 'used t)
(magit-run "git" "cherry-pick" info))
((commit) ((commit)
(magit-run "git" "cherry-pick" info)))) (magit-run "git" "cherry-pick" info))))
(defun magit-revert-commit (commit)
(magit-log-edit-append
(magit-format-commit info "Reverting \"%s\""))
(magit-run-shell "git diff %s^ %s | git apply --reverse -" info info))
(defun magit-revert-item () (defun magit-revert-item ()
(interactive) (interactive)
(magit-section-case (item info "revert") (magit-section-case (item info "revert")
((pending commit)
(magit-rewrite-set-commit-property info 'used nil)
(magit-revert-commit info))
((commit) ((commit)
(magit-log-edit-append (magit-revert-commit info))))
(magit-format-commit info "Reverting \"%s\""))
(magit-run-shell "git diff %s^ %s | git apply --reverse -" info info))))
(defun magit-log (range) (defun magit-log (range)
(interactive (list (magit-read-rev-range "Log" (magit-get-current-branch)))) (interactive (list (magit-read-rev-range "Log" (magit-get-current-branch))))