Commit 059cc450 authored by mmoss@chromium.org's avatar mmoss@chromium.org

Separate git 'clone' and 'config' commands.

Some versions of git don't support 'clone --config'.
Review URL: https://codereview.chromium.org/12688005

git-svn-id: svn://svn.chromium.org/chrome/trunk/tools/depot_tools@187296 0039d316-1c4b-4281-b951-d872f2087c98
parent a78e553b
...@@ -655,11 +655,6 @@ class GitWrapper(SCMWrapper): ...@@ -655,11 +655,6 @@ class GitWrapper(SCMWrapper):
detach_head = True detach_head = True
if options.verbose: if options.verbose:
clone_cmd.append('--verbose') clone_cmd.append('--verbose')
# Don't assume 'with_branch_heads' is added by 'gclient sync' setup, since
# _Clone() can by reached in roundabout ways (e.g. 'gclient revert').
if hasattr(options, 'with_branch_heads') and options.with_branch_heads:
clone_cmd.extend(['--config', 'remote.origin.fetch=+refs/branch-heads/*:'
'refs/remotes/branch-heads/*'])
clone_cmd.extend([url, self.checkout_path]) clone_cmd.extend([url, self.checkout_path])
# If the parent directory does not exist, Git clone on Windows will not # If the parent directory does not exist, Git clone on Windows will not
...@@ -682,15 +677,6 @@ class GitWrapper(SCMWrapper): ...@@ -682,15 +677,6 @@ class GitWrapper(SCMWrapper):
try: try:
self._Run(clone_cmd, options, cwd=self._root_dir, filter_fn=_GitFilter, self._Run(clone_cmd, options, cwd=self._root_dir, filter_fn=_GitFilter,
print_stdout=False) print_stdout=False)
# Update the "branch-heads" remote-tracking branches, since clone
# doesn't automatically fetch those, and we might need it to checkout a
# specific revision below.
if (hasattr(options, 'with_branch_heads') and
options.with_branch_heads):
fetch_cmd = ['fetch', 'origin']
if options.verbose:
fetch_cmd.append('--verbose')
self._Run(fetch_cmd, options)
break break
except subprocess2.CalledProcessError, e: except subprocess2.CalledProcessError, e:
# Too bad we don't have access to the actual output yet. # Too bad we don't have access to the actual output yet.
...@@ -703,6 +689,31 @@ class GitWrapper(SCMWrapper): ...@@ -703,6 +689,31 @@ class GitWrapper(SCMWrapper):
continue continue
raise e raise e
for _ in range(3):
try:
# Add the "branch-heads" refspecs. Do this separately from the clone
# command since apparently some versions of git don't support 'clone
# --config'.
# Don't assume 'with_branch_heads' is added by 'gclient sync' setup,
# since _Clone() can by reached in roundabout ways (e.g. 'gclient
# revert').
if hasattr(options, 'with_branch_heads') and options.with_branch_heads:
config_cmd = ['config', 'remote.origin.fetch',
'+refs/branch-heads/*:refs/remotes/branch-heads/*']
self._Run(config_cmd, options)
# Update the "branch-heads" remote-tracking branches, since we might
# need it to checkout a specific revision below.
fetch_cmd = ['fetch', 'origin']
if options.verbose:
fetch_cmd.append('--verbose')
self._Run(fetch_cmd, options)
break
except subprocess2.CalledProcessError, e:
print(str(e))
print('Retrying...')
continue
if detach_head: if detach_head:
# Squelch git's very verbose detached HEAD warning and use our own # Squelch git's very verbose detached HEAD warning and use our own
self._Capture(['checkout', '--quiet', '%s' % revision]) self._Capture(['checkout', '--quiet', '%s' % revision])
......
Markdown is supported
0% or
You are about to add 0 people to the discussion. Proceed with caution.
Finish editing this message first!
Please register or to comment