Commit 875bc270 authored by Aarni Koskela's avatar Aarni Koskela

launch.py: Simplify run()

parent 49db24ce
...@@ -88,32 +88,36 @@ def git_tag(): ...@@ -88,32 +88,36 @@ def git_tag():
return stored_git_tag return stored_git_tag
def run(command, desc=None, errdesc=None, custom_env=None, live: bool = default_command_live): def run(command, desc=None, errdesc=None, custom_env=None, live: bool = default_command_live) -> str:
if desc is not None: if desc is not None:
print(desc) print(desc)
if live: run_kwargs = {
result = subprocess.run(command, shell=True, env=os.environ if custom_env is None else custom_env) "args": command,
if result.returncode != 0: "shell": True,
raise RuntimeError(f"""{errdesc or 'Error running command'}. "env": os.environ if custom_env is None else custom_env,
Command: {command} "encoding": 'utf8',
Error code: {result.returncode}""") "errors": 'ignore',
}
return "" if not live:
run_kwargs["stdout"] = run_kwargs["stderr"] = subprocess.PIPE
result = subprocess.run(command, stdout=subprocess.PIPE, stderr=subprocess.PIPE, shell=True, env=os.environ if custom_env is None else custom_env) result = subprocess.run(**run_kwargs)
if result.returncode != 0: if result.returncode != 0:
error_bits = [
message = f"""{errdesc or 'Error running command'}. f"{errdesc or 'Error running command'}.",
Command: {command} f"Command: {command}",
Error code: {result.returncode} f"Error code: {result.returncode}",
stdout: {result.stdout.decode(encoding="utf8", errors="ignore") if len(result.stdout)>0 else '<empty>'} ]
stderr: {result.stderr.decode(encoding="utf8", errors="ignore") if len(result.stderr)>0 else '<empty>'} if result.stdout:
""" error_bits.append(f"stdout: {result.stdout}")
raise RuntimeError(message) if result.stderr:
error_bits.append(f"stderr: {result.stderr}")
return result.stdout.decode(encoding="utf8", errors="ignore") raise RuntimeError("\n".join(error_bits))
return (result.stdout or "")
def check_run(command): def check_run(command):
......
Markdown is supported
0% or
You are about to add 0 people to the discussion. Proceed with caution.
Finish editing this message first!
Please register or to comment