Allow branches without upstream.

Clean up formatting a bit.

Review URL: https://chromiumcodereview.appspot.com/14602017

git-svn-id: svn://svn.chromium.org/chrome/trunk/tools/depot_tools@197773 0039d316-1c4b-4281-b951-d872f2087c98
experimental/szager/collated-output
groby@chromium.org 12 years ago
parent b054ebc8f3
commit a3800b2db5

@ -30,7 +30,7 @@ def get_change_count(start, end):
class Branch(git_cl.Changelist): class Branch(git_cl.Changelist):
def __init__(self, name, upstream): def __init__(self, name, upstream=None):
git_cl.Changelist.__init__(self, branchref=name) git_cl.Changelist.__init__(self, branchref=name)
self._upstream = upstream self._upstream = upstream
self._distance = None self._distance = None
@ -52,23 +52,36 @@ class Branch(git_cl.Changelist):
else: else:
self._issue_status = 'no-issue' self._issue_status = 'no-issue'
if (self._issue_status != 'pending' if (self._issue_status != 'pending'
and self._upstream
and not self.GetDistance()[0] and not self.GetDistance()[0]
and not self._upstream.startswith("origin/")): and not self._upstream.startswith("origin/")):
self._issue_status = 'empty' self._issue_status = 'empty'
return self._issue_status return self._issue_status
def GetDistance(self): def GetDistance(self):
if self._upstream is None:
return None;
if not self._distance: if not self._distance:
self._distance = [get_change_count(self._upstream, self.GetBranch()), self._distance = [get_change_count(self._upstream, self.GetBranch()),
get_change_count(self.GetBranch(), self._upstream)] get_change_count(self.GetBranch(), self._upstream)]
return self._distance return self._distance
def GetDistanceInfo(self): def GetDistanceInfo(self):
if not self._upstream:
return "<No upstream branch>"
formatted_dist = ", ".join(["%s %d" % (x,y) formatted_dist = ", ".join(["%s %d" % (x,y)
for (x,y) in zip(["ahead","behind"], self.GetDistance()) if y]) for (x,y) in zip(["ahead","behind"], self.GetDistance()) if y])
return "[%s%s]" % ( return "[%s%s]" % (
self._upstream, ": " + formatted_dist if formatted_dist else "") self._upstream, ": " + formatted_dist if formatted_dist else "")
def print_branches(title, fmt, branches):
if branches:
print title
for branch in branches:
print fmt.format(branch=branch.GetBranch(),
issue=branch.GetIssue(),
distance=branch.GetDistanceInfo())
def main(): def main():
parser = optparse.OptionParser(usage=sys.modules['__main__'].__doc__) parser = optparse.OptionParser(usage=sys.modules['__main__'].__doc__)
options, args = parser.parse_args() options, args = parser.parse_args()
@ -85,28 +98,22 @@ def main():
for branch in branches: for branch in branches:
filtered[branch.GetStatus()].append(branch) filtered[branch.GetStatus()].append(branch)
print "# Branches with closed issues" print_branches("# Branches with closed issues",
for branch in filtered['closed']: "git branch -D {branch} # Issue {issue} is closed.",
print "git branch -D %s # Issue %s is closed." % (branch.GetBranch(), filtered['closed'])
branch.GetIssue()) print_branches("\n# Empty branches",
"git branch -D {branch} # Empty.",
print "# Empty branches" filtered['empty'])
for branch in filtered['empty']: print_branches("\n# Pending Branches",
print "git branch -D %s # Empty." % (branch.GetBranch()) "# Branch {branch} - Issue {issue} - {distance}",
filtered['pending']);
print "\n# Pending Branches" print_branches("\n# Branches with abandoned issues",
for branch in filtered['pending']: "# Branch {branch} - was issue {issue} - {distance}",
print "# Branch %s - Issue %s - %s" % ( filtered['abandoned'])
branch.GetBranch(), branch.GetIssue(), branch.GetDistanceInfo())
print_branches("\n# Branches without associated issues",
print "\n# Branches with abandoned issues" "# Branch {branch} - {distance}",
for branch in filtered['abandoned']: filtered['no-issue'])
print "# Branch %s - was issue %s - %s" % (
branch.GetBranch(), branch.GetIssue(), branch.GetDistanceInfo())
print "\n# Branches without associated issues"
for branch in filtered['no-issue']:
print "# Branch %s - %s" % (branch.GetBranch(), branch.GetDistanceInfo())
return 0 return 0

Loading…
Cancel
Save