Several improvements to the whazzup command

1. Don't report a branch if it has no commit in common with HEAD.  This
   is for people who keep alternate histories in their repositories.

2. Don't report a branch if another branch with the same basename and
   commit as HEAD has already been reported.  Thus, if a branch "foo"
   with 5 unpulled commits was pushed to origin, don't display both
   "foo" and "origin/foo" in the whazzup buffer, since they reflect the
   same thing.
This commit is contained in:
John Wiegley 2009-02-18 01:28:57 -04:00
parent e9bed9b1e2
commit b991100ce6

View file

@ -2584,8 +2584,16 @@ Prefix arg means justify as well."
(magit-create-buffer-sections (magit-create-buffer-sections
(magit-with-section 'wazzupbuf nil (magit-with-section 'wazzupbuf nil
(insert (format "Wazzup, %s\n\n" head)) (insert (format "Wazzup, %s\n\n" head))
(let ((branches (magit-git-lines "branch -a | cut -c3-"))) (let ((branches (magit-git-lines "branch -a | cut -c3-"))
(reported (make-hash-table :test #'equal)))
(dolist (b branches) (dolist (b branches)
(let* ((hash (magit-git-string "rev-parse %s" b))
(reported-branch (gethash hash reported)))
(unless (or (and reported-branch
(string= (file-name-nondirectory b)
reported-branch))
(not (magit-git-string "merge-base %s %s" head b)))
(puthash hash (file-name-nondirectory b) reported)
(let* ((n (magit-git-string "log --pretty=oneline %s..%s | wc -l" (let* ((n (magit-git-string "log --pretty=oneline %s..%s | wc -l"
head b)) head b))
(section (section
@ -2600,7 +2608,7 @@ Prefix arg means justify as well."
"--pretty=oneline" "--pretty=oneline"
(format "%s..%s" head b) (format "%s..%s" head b)
"--")))) "--"))))
(magit-set-section-info b section))))))) (magit-set-section-info b section)))))))))
(defun magit-wazzup () (defun magit-wazzup ()
(interactive) (interactive)