mirror of
https://github.com/servo/servo.git
synced 2025-08-03 20:50:07 +01:00
Pass Ctr+C to underlying process when invoking commands through mach.
This commit is contained in:
parent
4f1837e9ab
commit
342ccafe92
1 changed files with 14 additions and 1 deletions
|
@ -102,7 +102,20 @@ def check_call(*args, **kwargs):
|
||||||
print(' '.join(args[0]))
|
print(' '.join(args[0]))
|
||||||
# we have to use shell=True in order to get PATH handling
|
# we have to use shell=True in order to get PATH handling
|
||||||
# when looking for the binary on Windows
|
# when looking for the binary on Windows
|
||||||
return subprocess.check_call(*args, shell=sys.platform == 'win32', **kwargs)
|
proc = subprocess.Popen(*args, shell=sys.platform == 'win32', **kwargs)
|
||||||
|
status = None
|
||||||
|
# Leave it to the subprocess to handle Ctrl+C. If it terminates as
|
||||||
|
# a result of Ctrl+C, proc.wait() will return a status code, and,
|
||||||
|
# we get out of the loop. If it doesn't, like e.g. gdb, we continue
|
||||||
|
# waiting.
|
||||||
|
while status is None:
|
||||||
|
try:
|
||||||
|
status = proc.wait()
|
||||||
|
except KeyboardInterrupt:
|
||||||
|
pass
|
||||||
|
|
||||||
|
if status:
|
||||||
|
raise subprocess.CalledProcessError(status, ' '.join(*args))
|
||||||
|
|
||||||
|
|
||||||
def is_windows():
|
def is_windows():
|
||||||
|
|
Loading…
Add table
Add a link
Reference in a new issue