Chromium Code Reviews
chromiumcodereview-hr@appspot.gserviceaccount.com (chromiumcodereview-hr) | Please choose your nickname with Settings | Help | Chromium Project | Gerrit Changes | Sign out
(110)

Unified Diff: git_common.py

Issue 184113002: Add git-map and git-short-map to depot_tools. (Closed) Base URL: https://chromium.googlesource.com/chromium/tools/depot_tools.git@new_branch
Patch Set: rebase and add better way to run python git extensions Created 6 years, 10 months ago
Use n/p to move between diff chunks; N/P to move between comments. Draft comments are only viewable by you.
Jump to:
View side-by-side diff with in-line comments
Download patch
Index: git_common.py
diff --git a/git_common.py b/git_common.py
index 1215d9cd41d44385f98583c884188b006b8561f1..fa6d3fc75556b1e4a9a61724315eee4ab4fd9f7c 100644
--- a/git_common.py
+++ b/git_common.py
@@ -27,8 +27,22 @@ import threading
import subprocess2
+class DEFAULT(object):
agable 2014/02/28 19:54:58 Why? This is so completely unnecessary. Maybe kind
iannucci 2014/03/06 00:18:39 *sigh* going back to useless-mode. lcd for the win
+ def __init__(self, constructor):
+ self.constructor = constructor
+
+ @staticmethod
+ def get_from(inst_or_obj):
+ if isinstance(inst_or_obj, DEFAULT):
+ return inst_or_obj.constructor()
+ else:
+ return inst_or_obj
+
+
GIT_EXE = 'git.bat' if sys.platform.startswith('win') else 'git'
+NO_BRANCH = ('* (no branch)', '* (detached from ')
+
class BadCommitRefException(Exception):
def __init__(self, refs):
@@ -199,6 +213,28 @@ class ProgressPrinter(object):
del self._thread
+def abbrev(ref):
+ return run('rev-parse', '--abbrev-ref', ref)
+
+
+def branches(*args):
+ for line in run('branch', *args).splitlines():
+ if line.startswith(NO_BRANCH):
+ continue
+ yield line.split()[-1]
+
+
+def config_list(option, default=DEFAULT(list)):
agable 2014/02/28 19:54:58 default=None if default is None: default=[] Let's
iannucci 2014/03/06 00:18:39 sometimes I hate python. The =None idiom is so uni
agable 2014/03/06 18:09:07 I know, and I totally agree. But I don't think thi
+ try:
+ return run('config', '--get-all', option).split()
+ except subprocess2.CalledProcessError:
+ return DEFAULT.get_from(default)
+
+
+def current_branch():
+ return abbrev('HEAD')
+
+
def parse_commitrefs(*commitrefs):
"""Returns binary encoded commit hashes for one or more commitrefs.
@@ -208,7 +244,7 @@ def parse_commitrefs(*commitrefs):
* 'cool_branch~2'
"""
try:
- return map(binascii.unhexlify, hashes(*commitrefs))
+ return map(binascii.unhexlify, hash_multi(*commitrefs))
except subprocess2.CalledProcessError:
raise BadCommitRefException(commitrefs)
@@ -231,7 +267,11 @@ def run(*cmd, **kwargs):
return ret
-def hashes(*reflike):
+def hash_one(reflike):
+ return run('rev-parse', reflike)
+
+
+def hash_multi(*reflike):
agable 2014/02/28 19:54:58 This should be "*reflikes" (cf. "*args").
iannucci 2014/03/06 00:18:39 Done.
return run('rev-parse', *reflike).splitlines()
@@ -249,6 +289,13 @@ def intern_f(f, kind='blob'):
return ret
+def tags(*args):
+ for line in run('tag', *args).splitlines():
+ if line.startswith(NO_BRANCH):
+ continue
+ yield line.split()[-1]
+
+
def tree(treeref, recurse=False):
"""Returns a dict representation of a git tree object.
@@ -286,6 +333,14 @@ def tree(treeref, recurse=False):
return ret
+def upstream(branch):
+ try:
+ return run('rev-parse', '--abbrev-ref', '--symbolic-full-name',
+ branch+'@{upstream}')
+ except subprocess2.CalledProcessError:
+ return None
+
+
def mktree(treedict):
"""Makes a git tree object and returns its hash.

Powered by Google App Engine
This is Rietveld 408576698