diff options
| author | Ed Bartosh <ed.bartosh@linux.intel.com> | 2017-06-16 16:19:27 +0300 | 
|---|---|---|
| committer | Richard Purdie <richard.purdie@linuxfoundation.org> | 2017-06-23 11:43:37 +0100 | 
| commit | 327e340a29d330f24117e24d0649fa156017208f (patch) | |
| tree | d4429e6abbde0c451f7fecac7a5f822bc6f3cb0f /scripts/lib | |
| parent | 29f7735030d383f9614bdb148b52a47c79f05eea (diff) | |
| download | openembedded-core-327e340a29d330f24117e24d0649fa156017208f.tar.gz openembedded-core-327e340a29d330f24117e24d0649fa156017208f.tar.bz2 openembedded-core-327e340a29d330f24117e24d0649fa156017208f.zip | |
wic/runner.py: move runtool API to misc.py
Moved remaining API to misc.py.
Removed runner.py.
Now misc.py is ready to be moved to the scripts/lib/wic and
utils directory can be removed.
Signed-off-by: Ed Bartosh <ed.bartosh@linux.intel.com>
Signed-off-by: Ross Burton <ross.burton@intel.com>
Diffstat (limited to 'scripts/lib')
| -rw-r--r-- | scripts/lib/wic/misc.py | 39 | ||||
| -rw-r--r-- | scripts/lib/wic/utils/runner.py | 52 | 
2 files changed, 36 insertions, 55 deletions
| diff --git a/scripts/lib/wic/misc.py b/scripts/lib/wic/misc.py index 8a38f2f479..3ebae0a6e0 100644 --- a/scripts/lib/wic/misc.py +++ b/scripts/lib/wic/misc.py @@ -29,12 +29,12 @@  import logging  import os  import re +import subprocess  from collections import defaultdict  from distutils import spawn  from wic import WicError -from wic.utils import runner  logger = logging.getLogger('wic') @@ -59,6 +59,39 @@ NATIVE_RECIPES = {"bmaptool": "bmap-tools",                    "syslinux": "syslinux"                   } +def runtool(cmdln_or_args): +    """ wrapper for most of the subprocess calls +    input: +        cmdln_or_args: can be both args and cmdln str (shell=True) +    return: +        rc, output +    """ +    if isinstance(cmdln_or_args, list): +        cmd = cmdln_or_args[0] +        shell = False +    else: +        import shlex +        cmd = shlex.split(cmdln_or_args)[0] +        shell = True + +    sout = subprocess.PIPE +    serr = subprocess.STDOUT + +    try: +        process = subprocess.Popen(cmdln_or_args, stdout=sout, +                                   stderr=serr, shell=shell) +        sout, serr = process.communicate() +        # combine stdout and stderr, filter None out and decode +        out = ''.join([out.decode('utf-8') for out in [sout, serr] if out]) +    except OSError as err: +        if err.errno == 2: +            # [Errno 2] No such file or directory +            raise WicError('Cannot run command: %s, lost dependency?' % cmd) +        else: +            raise # relay + +    return process.returncode, out +  def _exec_cmd(cmd_and_args, as_shell=False):      """      Execute command, catching stderr, stdout @@ -70,9 +103,9 @@ def _exec_cmd(cmd_and_args, as_shell=False):      logger.debug(args)      if as_shell: -        ret, out = runner.runtool(cmd_and_args) +        ret, out = runtool(cmd_and_args)      else: -        ret, out = runner.runtool(args) +        ret, out = runtool(args)      out = out.strip()      if ret != 0:          raise WicError("_exec_cmd: %s returned '%s' instead of 0\noutput: %s" % \ diff --git a/scripts/lib/wic/utils/runner.py b/scripts/lib/wic/utils/runner.py deleted file mode 100644 index 4aa00fbe20..0000000000 --- a/scripts/lib/wic/utils/runner.py +++ /dev/null @@ -1,52 +0,0 @@ -#!/usr/bin/env python -tt -# -# Copyright (c) 2011 Intel, Inc. -# -# This program is free software; you can redistribute it and/or modify it -# under the terms of the GNU General Public License as published by the Free -# Software Foundation; version 2 of the License -# -# This program is distributed in the hope that it will be useful, but -# WITHOUT ANY WARRANTY; without even the implied warranty of MERCHANTABILITY -# or FITNESS FOR A PARTICULAR PURPOSE.  See the GNU General Public License -# for more details. -# -# You should have received a copy of the GNU General Public License along -# with this program; if not, write to the Free Software Foundation, Inc., 59 -# Temple Place - Suite 330, Boston, MA 02111-1307, USA. -import subprocess - -from wic import WicError - -def runtool(cmdln_or_args): -    """ wrapper for most of the subprocess calls -    input: -        cmdln_or_args: can be both args and cmdln str (shell=True) -    return: -        rc, output -    """ -    if isinstance(cmdln_or_args, list): -        cmd = cmdln_or_args[0] -        shell = False -    else: -        import shlex -        cmd = shlex.split(cmdln_or_args)[0] -        shell = True - -    sout = subprocess.PIPE -    serr = subprocess.STDOUT - -    try: -        process = subprocess.Popen(cmdln_or_args, stdout=sout, -                                   stderr=serr, shell=shell) -        sout, serr = process.communicate() -        # combine stdout and stderr, filter None out and decode -        out = ''.join([out.decode('utf-8') for out in [sout, serr] if out]) -    except OSError as err: -        if err.errno == 2: -            # [Errno 2] No such file or directory -            raise WicError('Cannot run command: %s, lost dependency?' % cmd) -        else: -            raise # relay - -    return process.returncode, out | 
