diff options
author | Markus Lehtonen <markus.lehtonen@linux.intel.com> | 2014-02-06 09:17:56 +0200 |
---|---|---|
committer | Markus Lehtonen <markus.lehtonen@linux.intel.com> | 2014-06-05 14:20:03 +0300 |
commit | 3fc2071cc8ef89d26c2b236bb7029df357a05102 (patch) | |
tree | 4c244d024ebb811e7134be140f6b849a80ba3741 /gbp | |
parent | 5065e9ff23752081a0655458aa77667b31dd8356 (diff) | |
download | git-buildpackage-3fc2071cc8ef89d26c2b236bb7029df357a05102.tar.gz git-buildpackage-3fc2071cc8ef89d26c2b236bb7029df357a05102.tar.bz2 git-buildpackage-3fc2071cc8ef89d26c2b236bb7029df357a05102.zip |
GitRepository: allow interactive commands
Make it possible for git commands to output directly to stdout without
redirection (i.e. capturing their stdout stream).
Signed-off-by: Markus Lehtonen <markus.lehtonen@linux.intel.com>
Diffstat (limited to 'gbp')
-rw-r--r-- | gbp/git/repository.py | 29 |
1 files changed, 19 insertions, 10 deletions
diff --git a/gbp/git/repository.py b/gbp/git/repository.py index db863dcc..1db24094 100644 --- a/gbp/git/repository.py +++ b/gbp/git/repository.py @@ -142,7 +142,7 @@ class GitRepository(object): return output, popen.returncode def _git_inout(self, command, args, input=None, extra_env=None, cwd=None, - capture_stderr=False): + capture_stderr=False, capture_stdout=True): """ Run a git command with input and return output @@ -166,7 +166,8 @@ class GitRepository(object): stderr = '' try: for outdata in self.__git_inout(command, args, input, extra_env, - cwd, capture_stderr): + cwd, capture_stderr, + capture_stdout): stdout += outdata[0] stderr += outdata[1] except GitRepositoryError as err: @@ -188,7 +189,7 @@ class GitRepository(object): stderr = '' try: for outdata in self.__git_inout(command, args, stdin, extra_env, - cwd, capture_stderr): + cwd, capture_stderr, True): stderr += outdata[1] yield outdata[0] except GitRepositoryError as err: @@ -196,7 +197,8 @@ class GitRepository(object): raise err @classmethod - def __git_inout(cls, command, args, stdin, extra_env, cwd, capture_stderr): + def __git_inout(cls, command, args, stdin, extra_env, cwd, capture_stderr, + capture_stdout): """ Run a git command without a a GitRepostitory instance. @@ -212,18 +214,21 @@ class GitRepository(object): cmd = ['git', command] + args env = cls.__build_env(extra_env) + stdout_arg = subprocess.PIPE if capture_stdout else None stdin_arg = subprocess.PIPE if stdin else None stderr_arg = subprocess.PIPE if capture_stderr else None log.debug(cmd) popen = subprocess.Popen(cmd, stdin=stdin_arg, - stdout=subprocess.PIPE, + stdout=stdout_arg, stderr=stderr_arg, env=env, close_fds=True, cwd=cwd) - out_fds = [popen.stdout] + ([popen.stderr] if capture_stderr else []) + out_fds = [popen.stdout] if capture_stdout else [] + if capture_stderr: + out_fds.append(popen.stderr) in_fds = [popen.stdin] if stdin else [] w_ind = 0 while out_fds or in_fds: @@ -248,7 +253,7 @@ class GitRepository(object): err.returncode = popen.returncode raise err - def _git_command(self, command, args=[], extra_env=None): + def _git_command(self, command, args=[], extra_env=None, interactive=False): """ Execute git command with arguments args and environment env at path. @@ -260,12 +265,14 @@ class GitRepository(object): @param extra_env: extra environment variables to set when running command @type extra_env: C{dict} """ + capture_stdout = not interactive try: stdout, stderr, ret = self._git_inout(command=command, args=args, input=None, extra_env=extra_env, - capture_stderr=True) + capture_stderr=True, + capture_stdout=capture_stdout) except Exception as excobj: raise GitRepositoryError("Error running git %s: %s" % (command, excobj)) if ret: @@ -1858,7 +1865,8 @@ class GitRepository(object): stdin=None, extra_env=None, cwd=abspath, - capture_stderr=True): + capture_stderr=True, + capture_stdout=True): stderr += out[1] except GitRepositoryError: raise GitRepositoryError("Error running git init: %s" % stderr) @@ -1921,7 +1929,8 @@ class GitRepository(object): stdin=None, extra_env=None, cwd=abspath, - capture_stderr=True): + capture_stderr=True, + capture_stdout=True): stderr += out[1] except GitRepositoryError: raise GitRepositoryError("Error running git clone: %s" % stderr) |