Merge pull request #999 from smaarn/fix/term-signal-should-be-caught

Propagate TERM signal to latest forked child process
pull/1247/head
morpheus65535 5 years ago committed by GitHub
commit 514d549934
No known key found for this signature in database
GPG Key ID: 4AEE18F83AFDEB23

@ -2,6 +2,7 @@
import os import os
import platform import platform
import signal
import subprocess import subprocess
import sys import sys
import time import time
@ -37,11 +38,18 @@ def end_child_process(ep):
except: except:
pass pass
def terminate_child_process(ep):
try:
ep.terminate()
except:
pass
def start_bazarr(): def start_bazarr():
script = [sys.executable, "-u", os.path.normcase(os.path.join(dir_name, 'bazarr', 'main.py'))] + sys.argv[1:] script = [sys.executable, "-u", os.path.normcase(os.path.join(dir_name, 'bazarr', 'main.py'))] + sys.argv[1:]
ep = subprocess.Popen(script, stdout=None, stderr=None, stdin=subprocess.DEVNULL) ep = subprocess.Popen(script, stdout=None, stderr=None, stdin=subprocess.DEVNULL)
atexit.register(end_child_process, ep=ep) atexit.register(end_child_process, ep=ep)
signal.signal(signal.SIGTERM, lambda signal_no, frame: terminate_child_process(ep))
def check_status(): def check_status():
@ -92,6 +100,6 @@ if __name__ == '__main__':
else: else:
os.wait() os.wait()
time.sleep(1) time.sleep(1)
except (KeyboardInterrupt, SystemExit): except (KeyboardInterrupt, SystemExit, ChildProcessError):
print('Bazarr exited.') print('Bazarr exited.')
sys.exit(0) sys.exit(0)

Loading…
Cancel
Save