summary | shortlog | log | commit | commitdiff | tree
raw | patch | inline | side by side (parent: c375e9d)
raw | patch | inline | side by side (parent: c375e9d)
author | Alexandre Julliard <julliard@winehq.org> | |
Sun, 23 Nov 2008 13:25:50 +0000 (14:25 +0100) | ||
committer | Alexandre Julliard <julliard@winehq.org> | |
Sat, 7 Feb 2009 12:48:54 +0000 (13:48 +0100) |
Prompts for a branch name, create a new branch at HEAD and switch to
it. Bound to C-c C-b by default.
Based on a patch by RĂ©mi Vanicat <vanicat@debian.org>.
Signed-off-by: Alexandre Julliard <julliard@winehq.org>
it. Bound to C-c C-b by default.
Based on a patch by RĂ©mi Vanicat <vanicat@debian.org>.
Signed-off-by: Alexandre Julliard <julliard@winehq.org>
contrib/emacs/git.el | patch | blob | history |
diff --git a/contrib/emacs/git.el b/contrib/emacs/git.el
index 5ce9bf19a7c5bedb4ca32a44f1dec6d1a468ce12..6727ff54bee7babd3a432cacee5d7f7523df2dec 100644 (file)
--- a/contrib/emacs/git.el
+++ b/contrib/emacs/git.el
(when (apply #'git-call-process-display-error "checkout" args)
(git-update-status-files))))
+(defun git-branch (branch)
+ "Create a branch from the current HEAD and switch to it."
+ (interactive (list (git-read-commit-name "Branch: ")))
+ (unless git-status (error "Not in git-status buffer."))
+ (if (git-rev-parse (concat "refs/heads/" branch))
+ (if (yes-or-no-p (format "Branch %s already exists, replace it? " branch))
+ (and (git-call-process-display-error "branch" "-f" branch)
+ (git-call-process-display-error "checkout" branch))
+ (message "Canceled."))
+ (git-call-process-display-error "checkout" "-b" branch))
+ (git-refresh-ewoc-hf git-status))
+
(defun git-amend-commit ()
"Undo the last commit on HEAD, and set things up to commit an
amended version of it."
(define-key map "\M-\C-?" 'git-unmark-all)
; the commit submap
(define-key commit-map "\C-a" 'git-amend-commit)
+ (define-key commit-map "\C-b" 'git-branch)
(define-key commit-map "\C-o" 'git-checkout)
; the diff submap
(define-key diff-map "b" 'git-diff-file-base)
["Refresh" git-refresh-status t]
["Commit" git-commit-file t]
["Checkout..." git-checkout t]
+ ["New Branch..." git-branch t]
("Merge"
["Next Unmerged File" git-next-unmerged-file t]
["Prev Unmerged File" git-prev-unmerged-file t]