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

Unified Diff: scm.py

Issue 11098064: Fix safesync_url handling for git. (Closed) Base URL: svn://svn.chromium.org/chrome/trunk/tools/depot_tools/
Patch Set: Created 8 years, 2 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
« no previous file with comments | « gclient_scm.py ('k') | no next file » | no next file with comments »
Expand Comments ('e') | Collapse Comments ('c') | Show Comments Hide Comments ('s')
Index: scm.py
===================================================================
--- scm.py (revision 161386)
+++ scm.py (working copy)
@@ -402,8 +402,23 @@
if not GIT.IsGitSvn(cwd=cwd):
return None
try:
- output = GIT.Capture(['svn', 'find-rev', 'r' + str(rev)], cwd=cwd)
- return GIT.ParseGitSvnSha1(output)
+ git_svn_rev = GIT.Capture(
+ ['svn', 'find-rev', 'r' + str(rev)], cwd=cwd).rstrip()
+ if not git_svn_rev:
+ return None
+ output = GIT.Capture(
+ ['rev-list', '--ancestry-path', '--reverse',
+ '--grep', 'SVN changes up to revision [0-9]*',
+ '%s..refs/remotes/origin/master' % git_svn_rev], cwd=cwd)
+ if not output:
+ return None
+ sha1 = output.splitlines()[0]
+ if not sha1:
+ return None
+ output = GIT.Capture(['rev-list', '-n', '1', '%s^1' % sha1], cwd=cwd)
+ if git_svn_rev != output.rstrip():
+ raise gclient_utils.Error(sha1)
+ return sha1
except subprocess2.CalledProcessError:
return None
« no previous file with comments | « gclient_scm.py ('k') | no next file » | no next file with comments »

Powered by Google App Engine
This is Rietveld 408576698