From 74642c5901b3b65424573fe84fcdd4f07c9a94a0 Mon Sep 17 00:00:00 2001 From: Marcel Martin Date: Tue, 4 Jun 2024 16:37:48 +0200 Subject: [PATCH] Shutdown process before feeder thread --- src/xopen/__init__.py | 12 +++++++++--- 1 file changed, 9 insertions(+), 3 deletions(-) diff --git a/src/xopen/__init__.py b/src/xopen/__init__.py index 9cc7c69..89f5137 100644 --- a/src/xopen/__init__.py +++ b/src/xopen/__init__.py @@ -267,6 +267,7 @@ def _open_process(self): # data continuously to the process stdin on another thread. self.in_thread = threading.Thread(target=self._feed_pipe) self.in_thread.start() + self._process_explicitly_terminated = False self._file: BinaryIO = self.process.stdout # type: ignore self._wait_for_output_or_process_exit() self._raise_if_error() @@ -290,7 +291,11 @@ def _feed_pipe(self): if chunk == b"": self.in_pipe.close() return - self.in_pipe.write(chunk) + try: + self.in_pipe.write(chunk) + except BrokenPipeError: + if not self._process_explicitly_terminated: + raise finally: self.in_pipe.close() @@ -329,14 +334,15 @@ def close(self) -> None: return check_allowed_code_and_message = False if "r" in self._mode: - self._feeding = False - self._file.read() retcode = self.process.poll() if retcode is None: # still running + self._process_explicitly_terminated = True self.process.terminate() check_allowed_code_and_message = True self.process.wait() + self._feeding = False + self._file.read() if self.in_thread: self.in_thread.join() self._file.close()