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

Unified Diff: git_auto_svn.py

Issue 2360143002: Delete git-auto-svn and its docs (Closed)
Patch Set: Created 4 years, 3 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 | « git-auto-svn ('k') | git_cl.py » ('j') | no next file with comments »
Expand Comments ('e') | Collapse Comments ('c') | Show Comments Hide Comments ('s')
Index: git_auto_svn.py
diff --git a/git_auto_svn.py b/git_auto_svn.py
deleted file mode 100755
index ed7062a85d931a8f8f0e4ba02b30e1408619667f..0000000000000000000000000000000000000000
--- a/git_auto_svn.py
+++ /dev/null
@@ -1,122 +0,0 @@
-#!/usr/bin/env python
-# Copyright 2014 The Chromium Authors. All rights reserved.
-# Use of this source code is governed by a BSD-style license that can be
-# found in the LICENSE file.
-
-"""Performs all git-svn setup steps necessary for 'git svn dcommit' to work.
-
-Assumes that trunk of the svn remote maps to master of the git remote.
-
-Example:
-git clone https://chromium.googlesource.com/chromium/tools/depot_tools
-cd depot_tools
-git auto-svn
-"""
-
-import argparse
-import os
-import sys
-import urlparse
-
-import subprocess2
-
-from git_common import run as run_git
-from git_common import run_stream_with_retcode as run_git_stream_with_retcode
-from git_common import set_config, root, ROOT, current_branch
-from git_common import upstream as get_upstream
-from git_footers import get_footer_svn_id
-
-
-SVN_EXE = ROOT+'\\svn.bat' if sys.platform.startswith('win') else 'svn'
-
-
-def run_svn(*cmd, **kwargs):
- """Runs an svn command.
-
- Returns (stdout, stderr) as a pair of strings.
-
- Raises subprocess2.CalledProcessError on nonzero return code.
- """
- kwargs.setdefault('stdin', subprocess2.PIPE)
- kwargs.setdefault('stdout', subprocess2.PIPE)
- kwargs.setdefault('stderr', subprocess2.PIPE)
-
- cmd = (SVN_EXE,) + cmd
- proc = subprocess2.Popen(cmd, **kwargs)
- ret, err = proc.communicate()
- retcode = proc.wait()
- if retcode != 0:
- raise subprocess2.CalledProcessError(retcode, cmd, os.getcwd(), ret, err)
-
- return ret, err
-
-
-def main(argv):
- # No command line flags. Just use the parser to prevent people from trying
- # to pass flags that don't do anything, and to provide 'usage'.
- parser = argparse.ArgumentParser(
- description='Automatically set up git-svn for a repo mirrored from svn.')
- parser.parse_args(argv)
-
- upstreams = []
- # Always configure the upstream trunk.
- upstreams.append(root())
- # Optionally configure whatever upstream branch might be currently checked
- # out. This is needed for work on svn-based branches, otherwise git-svn gets
- # very confused and tries to relate branch commits back to trunk, making a big
- # mess of the codereview patches, and generating all kinds of spurious errors
- # about the repo being in some sort of bad state.
- curr_upstream = get_upstream(current_branch())
- # There will be no upstream if the checkout is in detached HEAD.
- if curr_upstream:
- upstreams.append(curr_upstream)
- for upstream in upstreams:
- config_svn(upstream)
- return 0
-
-
-def config_svn(upstream):
- svn_id = get_footer_svn_id(upstream)
- assert svn_id, 'No valid git-svn-id footer found on %s.' % upstream
- print 'Found git-svn-id footer %s on %s' % (svn_id, upstream)
-
- parsed_svn = urlparse.urlparse(svn_id)
- path_components = parsed_svn.path.split('/')
- svn_repo = None
- svn_path = None
- for i in xrange(len(path_components)):
- try:
- maybe_repo = '%s://%s%s' % (
- parsed_svn.scheme, parsed_svn.netloc, '/'.join(path_components[:i+1]))
- print 'Checking ', maybe_repo
- run_svn('info', maybe_repo)
- svn_repo = maybe_repo
- svn_path = '/'.join(path_components[i+1:])
- break
- except subprocess2.CalledProcessError, e:
- if 'E170001' in str(e):
- print 'Authentication failed:'
- print e
- print ('Try running "svn ls %s" with the password'
- ' from https://chromium-access.appspot.com' % maybe_repo)
- print
- continue
- assert svn_repo is not None, 'Unable to find svn repo for %s' % svn_id
- print 'Found upstream svn repo %s and path %s' % (svn_repo, svn_path)
-
- run_git('config', '--local', '--replace-all', 'svn-remote.svn.url', svn_repo)
- run_git('config', '--local', '--replace-all', 'svn-remote.svn.fetch',
- '%s:refs/remotes/%s' % (svn_path, upstream),
- 'refs/remotes/%s$' % upstream)
- print 'Configured metadata, running "git svn fetch". This may take some time.'
- with run_git_stream_with_retcode('svn', 'fetch') as stdout:
- for line in stdout.xreadlines():
- print line.strip()
-
-
-if __name__ == '__main__':
- try:
- sys.exit(main(sys.argv[1:]))
- except KeyboardInterrupt:
- sys.stderr.write('interrupted\n')
- sys.exit(1)
« no previous file with comments | « git-auto-svn ('k') | git_cl.py » ('j') | no next file with comments »

Powered by Google App Engine
This is Rietveld 408576698