From d3fd537ea59272e2141ccee839400a93c0196e36 Mon Sep 17 00:00:00 2001 From: Trond Norbye Date: Mon, 3 Jan 2011 11:35:15 +0100 Subject: [PATCH 1/2] Exit with statuscode 0 for repo help init The complete help text is printed, so the program executed successfully. Some tools (like OpenGrok) detects the availibility of a program by running it with a known set of options and check the return code. It is an easy and portable way of checking for the existence of a program instead of searching the path (and handle extensions) ourselves. Change-Id: Ic13428c77be4a36d599ccb8c86d893308818eae3 --- repo | 1 + 1 file changed, 1 insertion(+) diff --git a/repo b/repo index bdc05c3b..6f2067ea 100755 --- a/repo +++ b/repo @@ -479,6 +479,7 @@ def _Help(args): if args: if args[0] == 'init': init_optparse.print_help() + sys.exit(0) else: print >>sys.stderr,\ "error: '%s' is not a bootstrap command.\n"\ From f18cb761731a791bf1b9ee8c6308bfce5c9d3e62 Mon Sep 17 00:00:00 2001 From: "Shawn O. Pearce" Date: Tue, 7 Dec 2010 11:41:05 -0800 Subject: [PATCH 2/2] Encode the environment variables passed to git Windows allows the environment to have unicode values. This will cause Python to fail to execute the command. Change-Id: I37d922c3d7ced0d5b4883f0220346ac42defc5e9 Signed-off-by: Shawn O. Pearce --- git_command.py | 11 +++++++---- repo | 8 ++++---- subcmds/forall.py | 4 ++-- subcmds/sync.py | 8 ++++---- 4 files changed, 17 insertions(+), 14 deletions(-) diff --git a/git_command.py b/git_command.py index 4ad908f6..4aeacd57 100644 --- a/git_command.py +++ b/git_command.py @@ -112,6 +112,9 @@ def git_require(min_version, fail=False): sys.exit(1) return False +def _setenv(env, name, value): + env[name] = value.encode() + class GitCommand(object): def __init__(self, project, @@ -137,10 +140,10 @@ class GitCommand(object): del env[e] if disable_editor: - env['GIT_EDITOR'] = ':' + _setenv(env, 'GIT_EDITOR', ':') if ssh_proxy: - env['REPO_SSH_SOCK'] = ssh_sock() - env['GIT_SSH'] = _ssh_proxy() + _setenv(env, 'REPO_SSH_SOCK', ssh_sock()) + _setenv(env, 'GIT_SSH', _ssh_proxy()) if project: if not cwd: @@ -151,7 +154,7 @@ class GitCommand(object): command = [GIT] if bare: if gitdir: - env[GIT_DIR] = gitdir + _setenv(env, GIT_DIR, gitdir) cwd = None command.extend(cmdv) diff --git a/repo b/repo index 6f2067ea..02858ec2 100755 --- a/repo +++ b/repo @@ -259,8 +259,8 @@ def _SetupGnuPG(quiet): gpg_dir, e.strerror) sys.exit(1) - env = dict(os.environ) - env['GNUPGHOME'] = gpg_dir + env = os.environ.copy() + env['GNUPGHOME'] = gpg_dir.encode() cmd = ['gpg', '--import'] try: @@ -378,8 +378,8 @@ def _Verify(cwd, branch, quiet): % (branch, cur) print >>sys.stderr - env = dict(os.environ) - env['GNUPGHOME'] = gpg_dir + env = os.environ.copy() + env['GNUPGHOME'] = gpg_dir.encode() cmd = [GIT, 'tag', '-v', cur] proc = subprocess.Popen(cmd, diff --git a/subcmds/forall.py b/subcmds/forall.py index b66313d7..8209c806 100644 --- a/subcmds/forall.py +++ b/subcmds/forall.py @@ -151,11 +151,11 @@ terminal and are not redirected. first = True for project in self.GetProjects(args): - env = dict(os.environ.iteritems()) + env = os.environ.copy() def setenv(name, val): if val is None: val = '' - env[name] = val + env[name] = val.encode() setenv('REPO_PROJECT', project.name) setenv('REPO_PATH', project.relpath) diff --git a/subcmds/sync.py b/subcmds/sync.py index d6ea442a..80bba1aa 100644 --- a/subcmds/sync.py +++ b/subcmds/sync.py @@ -269,7 +269,7 @@ uncommitted changes are present' % project.relpath if branch.startswith(R_HEADS): branch = branch[len(R_HEADS):] - env = dict(os.environ) + env = os.environ.copy() if (env.has_key('TARGET_PRODUCT') and env.has_key('TARGET_BUILD_VARIANT')): target = '%s-%s' % (env['TARGET_PRODUCT'], @@ -413,9 +413,9 @@ warning: Cannot automatically authenticate repo.""" % (project.name, rev) return False - env = dict(os.environ) - env['GIT_DIR'] = project.gitdir - env['GNUPGHOME'] = gpg_dir + env = os.environ.copy() + env['GIT_DIR'] = project.gitdir.encode() + env['GNUPGHOME'] = gpg_dir.encode() cmd = [GIT, 'tag', '-v', cur] proc = subprocess.Popen(cmd,