Merge branch 'better-checkout-in-branch-view'

This commit is contained in:
Phil Jackson 2010-06-09 22:52:58 +01:00
commit bcdfc155ae

View file

@ -2581,15 +2581,30 @@ With prefix argument, add remaining untracked files as well.
;;; Branches ;;; Branches
(defun magit-get-tracking-name (remote branch)
"Given a REMOTE and a BRANCH name, ask the user for a local
tracking brach name suggesting a sensible default."
(when (yes-or-no-p
(format "Create local tracking branch for %s? " branch))
(let* ((default-name (concat remote "-" branch))
(chosen-name (read-string (format "Call local branch (%s): " default-name)
nil
nil
default-name)))
(when (magit-ref-exists-p (concat "refs/heads/" chosen-name))
(error "'%s' already exists." chosen-name))
chosen-name)))
(defun magit-maybe-create-local-tracking-branch (rev) (defun magit-maybe-create-local-tracking-branch (rev)
(if (string-match "^refs/remotes/\\([^/]+\\)/\\(.+\\)" rev) "Depending on the users wishes, create a tracking branch for
(let ((remote (match-string 1 rev)) rev... maybe."
(branch (match-string 2 rev))) (if (string-match "^\\(?:refs/\\)?remotes/\\([^/]+\\)/\\(.+\\)" rev)
(when (and (not (magit-ref-exists-p (concat "refs/heads/" branch))) (let* ((remote (match-string 1 rev))
(yes-or-no-p (branch (match-string 2 rev))
(format "Create local tracking branch for %s? " branch))) (tracker-name (magit-get-tracking-name remote branch)))
(magit-run-git "checkout" "-b" branch rev) (when tracker-name
t)) (magit-run-git "checkout" "-b" tracker-name rev)
t))
nil)) nil))
(defun magit-checkout (revision) (defun magit-checkout (revision)
@ -4003,7 +4018,7 @@ Return values:
(defun magit-branches-window-checkout () (defun magit-branches-window-checkout ()
"Check out the branch in the line at point." "Check out the branch in the line at point."
(interactive) (interactive)
(magit-run-git "checkout" (magit--branch-name-at-point)) (magit-checkout (magit--branch-name-at-point))
(save-excursion (save-excursion
(magit-show-branches))) (magit-show-branches)))
@ -4041,7 +4056,7 @@ With prefix force the removal even it it hasn't been merged."
"Extract details from branch -va output." "Extract details from branch -va output."
(string-match (concat (string-match (concat
"^\\(\\*? \\{1,2\\}\\)" ; current branch marker (maybe) "^\\(\\*? \\{1,2\\}\\)" ; current branch marker (maybe)
"\\(remotes/\\)?\\(.+?\\) +" ; is it remote, branch name "\\(.+?\\) +" ; branch name
"\\(?:" "\\(?:"
"\\([0-9a-fA-F]\\{7\\}\\) " ; sha1 "\\([0-9a-fA-F]\\{7\\}\\) " ; sha1
@ -4052,14 +4067,13 @@ With prefix force the removal even it it hasn't been merged."
) )
branch-line) branch-line)
(let ((res (list (cons 'current (match-string 1 branch-line)) (let ((res (list (cons 'current (match-string 1 branch-line))
(cons 'remote (not (not (match-string 2 branch-line)))) (cons 'branch (match-string 2 branch-line)))))
(cons 'branch (match-string 3 branch-line))))) (if (match-string 4 branch-line)
(if (match-string 5 branch-line)
(cons (cons 'other-ref (match-string 6 branch-line)) res) (cons (cons 'other-ref (match-string 6 branch-line)) res)
(append (append
(list (list
(cons 'sha1 (match-string 4 branch-line)) (cons 'sha1 (match-string 3 branch-line))
(cons 'msg (match-string 6 branch-line))) (cons 'msg (match-string 5 branch-line)))
res)))) res))))
(defun magit-show-branches () (defun magit-show-branches ()