summaryrefslogtreecommitdiffstats
path: root/waflib/processor.py
diff options
context:
space:
mode:
authorDavid Robillard <d@drobilla.net>2018-11-24 13:44:03 +0100
committerDavid Robillard <d@drobilla.net>2018-11-24 13:44:03 +0100
commita7d83f19b08eb4c6f79a82fe60c2b86db13f4420 (patch)
treed9b620bfba1e7462df4ddb3f6225cc5216c0ca81 /waflib/processor.py
parentd63edc742cebd685f8a05936682210aa5c1e69a9 (diff)
downloadingen-a7d83f19b08eb4c6f79a82fe60c2b86db13f4420.tar.gz
ingen-a7d83f19b08eb4c6f79a82fe60c2b86db13f4420.tar.bz2
ingen-a7d83f19b08eb4c6f79a82fe60c2b86db13f4420.zip
Squashed 'waflib/' changes from 6e726eb1..5ea8f99f
5ea8f99f Improve test output spacing 0e23b29f Raise exception when test suite fails to ensure non-zero exit status d6de073b Show run time of unit tests 5b655541 Add short configure option for ultra-strict flags 4687ba6d Use gtest-like test output 258903d9 Fix failure count in test group summaries da07e738 Fix verbose tests with Python 3 git-subtree-dir: waflib git-subtree-split: 5ea8f99f6e1246079c1fe6bb590c38a53aadd40d
Diffstat (limited to 'waflib/processor.py')
-rwxr-xr-xwaflib/processor.py64
1 files changed, 0 insertions, 64 deletions
diff --git a/waflib/processor.py b/waflib/processor.py
deleted file mode 100755
index 2eecf3bd..00000000
--- a/waflib/processor.py
+++ /dev/null
@@ -1,64 +0,0 @@
-#! /usr/bin/env python
-# encoding: utf-8
-# Thomas Nagy, 2016-2018 (ita)
-
-import os, sys, traceback, base64, signal
-try:
- import cPickle
-except ImportError:
- import pickle as cPickle
-
-try:
- import subprocess32 as subprocess
-except ImportError:
- import subprocess
-
-try:
- TimeoutExpired = subprocess.TimeoutExpired
-except AttributeError:
- class TimeoutExpired(Exception):
- pass
-
-def run():
- txt = sys.stdin.readline().strip()
- if not txt:
- # parent process probably ended
- sys.exit(1)
- [cmd, kwargs, cargs] = cPickle.loads(base64.b64decode(txt))
- cargs = cargs or {}
-
- ret = 1
- out, err, ex, trace = (None, None, None, None)
- try:
- proc = subprocess.Popen(cmd, **kwargs)
- try:
- out, err = proc.communicate(**cargs)
- except TimeoutExpired:
- if kwargs.get('start_new_session') and hasattr(os, 'killpg'):
- os.killpg(proc.pid, signal.SIGKILL)
- else:
- proc.kill()
- out, err = proc.communicate()
- exc = TimeoutExpired(proc.args, timeout=cargs['timeout'], output=out)
- exc.stderr = err
- raise exc
- ret = proc.returncode
- except Exception as e:
- exc_type, exc_value, tb = sys.exc_info()
- exc_lines = traceback.format_exception(exc_type, exc_value, tb)
- trace = str(cmd) + '\n' + ''.join(exc_lines)
- ex = e.__class__.__name__
-
- # it is just text so maybe we do not need to pickle()
- tmp = [ret, out, err, ex, trace]
- obj = base64.b64encode(cPickle.dumps(tmp))
- sys.stdout.write(obj.decode())
- sys.stdout.write('\n')
- sys.stdout.flush()
-
-while 1:
- try:
- run()
- except KeyboardInterrupt:
- break
-