summaryrefslogtreecommitdiff
diff options
context:
space:
mode:
authorMichael Schwarz <michi.schwarz@gmail.com>2015-09-14 15:03:36 +0200
committerMichael Schwarz <michi.schwarz@gmail.com>2015-09-16 01:50:24 +0200
commita1f09b7f86c0d20941562f5b1254f9c0a2b9a535 (patch)
tree6b8707b18d893b7948a297879b460fa7cbbc5548
parent2bd7e1e3d72da6b78f1946d508fa8f50f7e9ef67 (diff)
downloadpogojig-a1f09b7f86c0d20941562f5b1254f9c0a2b9a535.tar.gz
pogojig-a1f09b7f86c0d20941562f5b1254f9c0a2b9a535.tar.bz2
pogojig-a1f09b7f86c0d20941562f5b1254f9c0a2b9a535.zip
Abstraction which allows a running process to be used as a context manager.
-rw-r--r--support/lib/util.py17
1 files changed, 16 insertions, 1 deletions
diff --git a/support/lib/util.py b/support/lib/util.py
index d14b342..48bfd46 100644
--- a/support/lib/util.py
+++ b/support/lib/util.py
@@ -56,7 +56,8 @@ def TemporaryDirectory():
shutil.rmtree(dir)
-def command(args, remove_env = [], set_env = { }, working_dir = None):
+@contextlib.contextmanager
+def command_context(args, remove_env = [], set_env = { }, working_dir = None, use_stderr = False):
env = dict(os.environ)
for i in remove_env:
@@ -71,10 +72,24 @@ def command(args, remove_env = [], set_env = { }, working_dir = None):
except OSError as e:
raise UserError('Error running {}: {}', args[0], e)
+ try:
+ yield process
+ except:
+ process.kill()
+
+ raise
+ finally:
+ process.wait()
+
if process.returncode:
raise UserError('Command failed: {}', ' '.join(args))
+def command(args, remove_env = [], set_env = { }, working_dir = None):
+ with command_context(args, remove_env, set_env, working_dir) as process:
+ process.wait()
+
+
def bash_escape_string(string):
return "'{}'".format(re.sub("'", "'\"'\"'", string))