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

Side by Side Diff: gclient_scm.py

Issue 16763004: Repair broken git checkouts caused by aborting git clone. (Closed) Base URL: https://chromium.googlesource.com/chromium/tools/depot_tools.git@master
Patch Set: Whitespace fix. Created 7 years, 6 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 unified diff | Download patch
« no previous file with comments | « no previous file | no next file » | no next file with comments »
Toggle Intra-line Diffs ('i') | Expand Comments ('e') | Collapse Comments ('c') | Show Comments Hide Comments ('s')
OLDNEW
1 # Copyright (c) 2012 The Chromium Authors. All rights reserved. 1 # Copyright (c) 2012 The Chromium Authors. All rights reserved.
2 # Use of this source code is governed by a BSD-style license that can be 2 # Use of this source code is governed by a BSD-style license that can be
3 # found in the LICENSE file. 3 # found in the LICENSE file.
4 4
5 """Gclient-specific SCM-specific operations.""" 5 """Gclient-specific SCM-specific operations."""
6 6
7 import logging 7 import logging
8 import os 8 import os
9 import posixpath 9 import posixpath
10 import re 10 import re
(...skipping 219 matching lines...) Expand 10 before | Expand all | Expand 10 after
230 # Not a fatal error, or even very interesting in a non-git-submodule 230 # Not a fatal error, or even very interesting in a non-git-submodule
231 # world. So just keep it quiet. 231 # world. So just keep it quiet.
232 pass 232 pass
233 try: 233 try:
234 gclient_utils.CheckCallAndFilter(cmd3, **kwargs) 234 gclient_utils.CheckCallAndFilter(cmd3, **kwargs)
235 except subprocess2.CalledProcessError: 235 except subprocess2.CalledProcessError:
236 gclient_utils.CheckCallAndFilter(cmd3 + ['always'], **kwargs) 236 gclient_utils.CheckCallAndFilter(cmd3 + ['always'], **kwargs)
237 237
238 gclient_utils.CheckCallAndFilter(cmd4, **kwargs) 238 gclient_utils.CheckCallAndFilter(cmd4, **kwargs)
239 239
240 def _FetchAndReset(self, revision, file_list, options):
M-A Ruel 2013/06/11 19:01:36 """Equivalent of git fetch; git reset."""
Mike Stip (use stip instead) 2013/06/11 20:38:54 Done.
241 quiet = []
242 if not options.verbose:
243 quiet = ['--quiet']
244 self._UpdateBranchHeads(options, fetch=False)
245 self._Run(['fetch', 'origin', '--prune'] + quiet, options)
246 self._Run(['reset', '--hard', revision] + quiet, options)
247 self.UpdateSubmoduleConfig()
248 files = self._Capture(['ls-files']).splitlines()
249 file_list.extend([os.path.join(self.checkout_path, f) for f in files])
250
240 def update(self, options, args, file_list): 251 def update(self, options, args, file_list):
241 """Runs git to update or transparently checkout the working copy. 252 """Runs git to update or transparently checkout the working copy.
242 253
243 All updated files will be appended to file_list. 254 All updated files will be appended to file_list.
244 255
245 Raises: 256 Raises:
246 Error: if can't get URL for relative path. 257 Error: if can't get URL for relative path.
247 """ 258 """
248 if args: 259 if args:
249 raise gclient_utils.Error("Unsupported argument(s): %s" % ",".join(args)) 260 raise gclient_utils.Error("Unsupported argument(s): %s" % ",".join(args))
(...skipping 81 matching lines...) Expand 10 before | Expand all | Expand 10 after
331 if (current_url != url and 342 if (current_url != url and
332 url != 'git://foo' and 343 url != 'git://foo' and
333 subprocess2.capture( 344 subprocess2.capture(
334 ['git', 'config', 'remote.origin.gclient-auto-fix-url'], 345 ['git', 'config', 'remote.origin.gclient-auto-fix-url'],
335 cwd=self.checkout_path).strip() != 'False'): 346 cwd=self.checkout_path).strip() != 'False'):
336 print('_____ switching %s to a new upstream' % self.relpath) 347 print('_____ switching %s to a new upstream' % self.relpath)
337 # Make sure it's clean 348 # Make sure it's clean
338 self._CheckClean(rev_str) 349 self._CheckClean(rev_str)
339 # Switch over to the new upstream 350 # Switch over to the new upstream
340 self._Run(['remote', 'set-url', 'origin', url], options) 351 self._Run(['remote', 'set-url', 'origin', url], options)
341 quiet = [] 352 self._FetchAndReset(revision, file_list, options)
342 if not options.verbose:
343 quiet = ['--quiet']
344 self._UpdateBranchHeads(options, fetch=False)
345 self._Run(['fetch', 'origin', '--prune'] + quiet, options)
346 self._Run(['reset', '--hard', revision] + quiet, options)
347 self.UpdateSubmoduleConfig()
348 files = self._Capture(['ls-files']).splitlines()
349 file_list.extend([os.path.join(self.checkout_path, f) for f in files])
350 return 353 return
351 354
355 if not self._IsValidGitRepo(options):
356 # .git directory is hosed for some reason, set it back up.
357 print('_____ %s/.git is corrupted, rebuilding' % self.relpath)
358 self._Run(['init'], options)
359 self._Run(['remote', 'set-url', 'origin', url], options)
360
361 if not self._HasHead():
362 # Previous checkout was aborted before branches could be created in repo,
363 # so we need to reconstruct them here.
364 self._Run(['pull', 'origin', 'master'], options)
M-A Ruel 2013/06/11 19:01:36 Why pull when you're about to fetch right after?
Mike Stip (use stip instead) 2013/06/11 20:38:54 Pull sets up the remote tracking branches (includi
M-A Ruel 2013/06/11 22:43:50 ORLY? Wow.
365 self._FetchAndReset(revision, file_list, options)
366
352 cur_branch = self._GetCurrentBranch() 367 cur_branch = self._GetCurrentBranch()
353 368
354 # Cases: 369 # Cases:
355 # 0) HEAD is detached. Probably from our initial clone. 370 # 0) HEAD is detached. Probably from our initial clone.
356 # - make sure HEAD is contained by a named ref, then update. 371 # - make sure HEAD is contained by a named ref, then update.
357 # Cases 1-4. HEAD is a branch. 372 # Cases 1-4. HEAD is a branch.
358 # 1) current branch is not tracking a remote branch (could be git-svn) 373 # 1) current branch is not tracking a remote branch (could be git-svn)
359 # - try to rebase onto the new hash or branch 374 # - try to rebase onto the new hash or branch
360 # 2) current branch is tracking a remote branch with local committed 375 # 2) current branch is tracking a remote branch with local committed
361 # changes, but the DEPS file switched to point to a hash 376 # changes, but the DEPS file switched to point to a hash
(...skipping 432 matching lines...) Expand 10 before | Expand all | Expand 10 after
794 "manually.\ncd %s && git " % 809 "manually.\ncd %s && git " %
795 self.checkout_path 810 self.checkout_path
796 + "%s" % ' '.join(rebase_cmd)) 811 + "%s" % ' '.join(rebase_cmd))
797 812
798 print(rebase_output.strip()) 813 print(rebase_output.strip())
799 if not options.verbose: 814 if not options.verbose:
800 # Make the output a little prettier. It's nice to have some 815 # Make the output a little prettier. It's nice to have some
801 # whitespace between projects when syncing. 816 # whitespace between projects when syncing.
802 print('') 817 print('')
803 818
819 def _IsValidGitRepo(self, options):
820 """Check if git status works in the current repository."""
M-A Ruel 2013/06/11 19:01:36 """Returns if the directory is a valid git reposit
Mike Stip (use stip instead) 2013/06/11 20:38:54 Done.
821 try:
822 self._Run(['status'], options)
823 return True
824 except subprocess2.CalledProcessError:
825 return False
826
827 def _HasHead(self):
828 """Check if rev-parse HEAD works in the current repository."""
M-A Ruel 2013/06/11 19:01:36 """Returns True if any commit is checked out. Thi
829 try:
830 self._GetCurrentBranch()
831 return True
832 except subprocess2.CalledProcessError:
833 return False
834
804 @staticmethod 835 @staticmethod
805 def _CheckMinVersion(min_version): 836 def _CheckMinVersion(min_version):
806 (ok, current_version) = scm.GIT.AssertVersion(min_version) 837 (ok, current_version) = scm.GIT.AssertVersion(min_version)
807 if not ok: 838 if not ok:
808 raise gclient_utils.Error('git version %s < minimum required %s' % 839 raise gclient_utils.Error('git version %s < minimum required %s' %
809 (current_version, min_version)) 840 (current_version, min_version))
810 841
811 def _IsRebasing(self): 842 def _IsRebasing(self):
812 # Check for any of REBASE-i/REBASE-m/REBASE/AM. Unfortunately git doesn't 843 # Check for any of REBASE-i/REBASE-m/REBASE/AM. Unfortunately git doesn't
813 # have a plumbing command to determine whether a rebase is in progress, so 844 # have a plumbing command to determine whether a rebase is in progress, so
(...skipping 477 matching lines...) Expand 10 before | Expand all | Expand 10 after
1291 new_command.append('--force') 1322 new_command.append('--force')
1292 if command[0] != 'checkout' and scm.SVN.AssertVersion('1.6')[0]: 1323 if command[0] != 'checkout' and scm.SVN.AssertVersion('1.6')[0]:
1293 new_command.extend(('--accept', 'theirs-conflict')) 1324 new_command.extend(('--accept', 'theirs-conflict'))
1294 elif options.manually_grab_svn_rev: 1325 elif options.manually_grab_svn_rev:
1295 new_command.append('--force') 1326 new_command.append('--force')
1296 if command[0] != 'checkout' and scm.SVN.AssertVersion('1.6')[0]: 1327 if command[0] != 'checkout' and scm.SVN.AssertVersion('1.6')[0]:
1297 new_command.extend(('--accept', 'postpone')) 1328 new_command.extend(('--accept', 'postpone'))
1298 elif command[0] != 'checkout' and scm.SVN.AssertVersion('1.6')[0]: 1329 elif command[0] != 'checkout' and scm.SVN.AssertVersion('1.6')[0]:
1299 new_command.extend(('--accept', 'postpone')) 1330 new_command.extend(('--accept', 'postpone'))
1300 return new_command 1331 return new_command
OLDNEW
« no previous file with comments | « no previous file | no next file » | no next file with comments »

Powered by Google App Engine
This is Rietveld 408576698