diff options
| author | Nirbheek Chauhan <nirbheek@centricular.com> | 2018-04-15 14:44:41 +0530 | 
|---|---|---|
| committer | Nirbheek Chauhan <nirbheek.chauhan@gmail.com> | 2018-06-18 10:51:46 +0000 | 
| commit | c9a89027accff8385028a2b5e93465d28c63be36 (patch) | |
| tree | 2dbfe29f7e1363de6054f20d377418492ca0b1f8 /mesonbuild/interpreter.py | |
| parent | cbe18e01e49613f0db30c563c80767b30325bf39 (diff) | |
| download | meson-c9a89027accff8385028a2b5e93465d28c63be36.tar.gz | |
run_command: Add new kwarg 'capture'
capture: false means we won't try to read the stdout at all.
Closes https://github.com/mesonbuild/meson/issues/3364
Diffstat (limited to 'mesonbuild/interpreter.py')
| -rw-r--r-- | mesonbuild/interpreter.py | 25 | 
1 files changed, 17 insertions, 8 deletions
| diff --git a/mesonbuild/interpreter.py b/mesonbuild/interpreter.py index eb09f3a89..d68c47dc7 100644 --- a/mesonbuild/interpreter.py +++ b/mesonbuild/interpreter.py @@ -33,6 +33,7 @@ from .modules import ModuleReturnValue  import os, sys, shutil, uuid  import re, shlex +import subprocess  from collections import namedtuple  from pathlib import PurePath @@ -144,10 +145,11 @@ class TryRunResultHolder(InterpreterObject):  class RunProcess(InterpreterObject): -    def __init__(self, cmd, args, source_dir, build_dir, subdir, mesonintrospect, in_builddir=False, check=False): +    def __init__(self, cmd, args, source_dir, build_dir, subdir, mesonintrospect, in_builddir=False, check=False, capture=True):          super().__init__()          if not isinstance(cmd, ExternalProgram):              raise AssertionError('BUG: RunProcess must be passed an ExternalProgram') +        self.capture = capture          pc, self.stdout, self.stderr = self.run_command(cmd, args, source_dir, build_dir, subdir, mesonintrospect, in_builddir, check)          self.returncode = pc.returncode          self.methods.update({'returncode': self.returncode_method, @@ -168,12 +170,17 @@ class RunProcess(InterpreterObject):              cwd = os.path.join(source_dir, subdir)          child_env = os.environ.copy()          child_env.update(env) +        stdout = subprocess.PIPE if self.capture else subprocess.DEVNULL          mlog.debug('Running command:', ' '.join(command_array))          try: -            p, o, e = Popen_safe(command_array, env=child_env, cwd=cwd) -            mlog.debug('--- stdout----') -            mlog.debug(o) -            mlog.debug('----stderr----') +            p, o, e = Popen_safe(command_array, stdout=stdout, env=child_env, cwd=cwd) +            if self.capture: +                mlog.debug('--- stdout ---') +                mlog.debug(o) +            else: +                o = '' +                mlog.debug('--- stdout disabled ---') +            mlog.debug('--- stderr ---')              mlog.debug(e)              mlog.debug('') @@ -1796,7 +1803,7 @@ permitted_kwargs = {'add_global_arguments': {'language'},                      'install_subdir': {'exclude_files', 'exclude_directories', 'install_dir', 'install_mode', 'strip_directory'},                      'jar': build.known_jar_kwargs,                      'project': {'version', 'meson_version', 'default_options', 'license', 'subproject_dir'}, -                    'run_command': {'check'}, +                    'run_command': {'check', 'capture'},                      'run_target': {'command', 'depends'},                      'shared_library': build.known_shlib_kwargs,                      'shared_module': build.known_shmod_kwargs, @@ -2080,7 +2087,7 @@ external dependencies (including libraries) must go to "dependencies".''')                  if not isinstance(actual, wanted):                      raise InvalidArguments('Incorrect argument type.') -    @FeatureNewKwargs('run_command', '0.47.0', ['check']) +    @FeatureNewKwargs('run_command', '0.47.0', ['check', 'capture'])      @permittedKwargs(permitted_kwargs['run_command'])      def func_run_command(self, node, args, kwargs):          return self.run_command_impl(node, args, kwargs) @@ -2090,6 +2097,7 @@ external dependencies (including libraries) must go to "dependencies".''')              raise InterpreterException('Not enough arguments')          cmd = args[0]          cargs = args[1:] +        capture = kwargs.get('capture', True)          srcdir = self.environment.get_source_dir()          builddir = self.environment.get_build_dir() @@ -2149,7 +2157,8 @@ external dependencies (including libraries) must go to "dependencies".''')                      if a not in self.build_def_files:                          self.build_def_files.append(a)          return RunProcess(cmd, expanded_args, srcdir, builddir, self.subdir, -                          self.environment.get_build_command() + ['introspect'], in_builddir, check) +                          self.environment.get_build_command() + ['introspect'], +                          in_builddir=in_builddir, check=check, capture=capture)      @stringArgs      def func_gettext(self, nodes, args, kwargs): | 
