From 8ab7da51b1533eff39940c128642e76dae09296e Mon Sep 17 00:00:00 2001 From: atsushi yano <55824710+atsushi421@users.noreply.github.com> Date: Thu, 19 Oct 2023 16:24:09 +0900 Subject: [PATCH] fix: change the way the process is killed --- ros2caret/verb/record.py | 5 +++-- 1 file changed, 3 insertions(+), 2 deletions(-) diff --git a/ros2caret/verb/record.py b/ros2caret/verb/record.py index 7c9d56d9..78356a85 100644 --- a/ros2caret/verb/record.py +++ b/ros2caret/verb/record.py @@ -14,6 +14,7 @@ import os import subprocess +import signal from typing import Optional @@ -222,12 +223,12 @@ def _fini(): node.stop_progress() node.end() if clock_recorder: - clock_recorder.terminate() + os.killpg(os.getpgid(clock_recorder.pid), signal.SIGTERM) print('stopping & destroying tracing session') lttng.lttng_fini(session_name=args.session_name) if args.record_clock: - clock_recorder = subprocess.Popen(['ros2', 'run', 'caret_trace', 'clock_recorder']) + clock_recorder = subprocess.Popen(['ros2', 'run', 'caret_trace', 'clock_recorder'], preexec_fn=os.setpgrp) else: clock_recorder = None execute_and_handle_sigint(_run, _fini)