Refactor PipeIOServer implementation into several files

This commit is contained in:
Kristóf Tóth 2018-12-14 17:36:53 +01:00
parent fddf7d9dba
commit 86662b14d8
4 changed files with 58 additions and 52 deletions

View File

@ -0,0 +1 @@
from .pipe_io_server import PipeIOServer

View File

@ -1,60 +1,11 @@
from threading import Thread from os import mkfifo, remove
from queue import Queue
from os import mkfifo, remove, getpid, kill
from os.path import exists, join from os.path import exists, join
from signal import SIGTERM
from secrets import token_urlsafe from secrets import token_urlsafe
from collections import namedtuple from collections import namedtuple
from abc import ABC, abstractmethod from abc import ABC, abstractmethod
from traceback import print_exc
from .pipe_reader_thread import PipeReaderThread
class PipeWriterThread(Thread): from .pipe_writer_thread import PipeWriterThread
def __init__(self, pipe_path):
super().__init__()
self._pipe_path = pipe_path
self._write_queue = Queue()
def write(self, message):
self._write_queue.put(message, block=True)
def run(self):
while True:
message = self._write_queue.get(block=True)
if message is None:
break
with open(self._pipe_path, 'wb') as pipe:
pipe.write(message)
def stop(self):
self._write_queue.put(None)
self.join()
class PipeReaderThread(Thread):
_stop_sequence = b'stop_reading'
def __init__(self, pipe_path, message_handler):
super().__init__()
self._message_handler = message_handler
self._pipe_path = pipe_path
def run(self):
while True:
with open(self._pipe_path, 'rb') as pipe:
message = pipe.read()
if message == self._stop_sequence:
break
try:
self._message_handler(message)
except: # pylint: disable=bare-except
print_exc()
kill(getpid(), SIGTERM)
def stop(self):
with open(self._pipe_path, 'wb') as pipe:
pipe.write(self._stop_sequence)
self.join()
class PipeHandler: class PipeHandler:

View File

@ -0,0 +1,30 @@
from threading import Thread
from os import kill, getpid
from signal import SIGTERM
from traceback import print_exc
class PipeReaderThread(Thread):
_stop_sequence = b'stop_reading'
def __init__(self, pipe_path, message_handler):
super().__init__()
self._message_handler = message_handler
self._pipe_path = pipe_path
def run(self):
while True:
with open(self._pipe_path, 'rb') as pipe:
message = pipe.read()
if message == self._stop_sequence:
break
try:
self._message_handler(message)
except: # pylint: disable=bare-except
print_exc()
kill(getpid(), SIGTERM)
def stop(self):
with open(self._pipe_path, 'wb') as pipe:
pipe.write(self._stop_sequence)
self.join()

View File

@ -0,0 +1,24 @@
from threading import Thread
from queue import Queue
class PipeWriterThread(Thread):
def __init__(self, pipe_path):
super().__init__()
self._pipe_path = pipe_path
self._write_queue = Queue()
def write(self, message):
self._write_queue.put(message, block=True)
def run(self):
while True:
message = self._write_queue.get(block=True)
if message is None:
break
with open(self._pipe_path, 'wb') as pipe:
pipe.write(message)
def stop(self):
self._write_queue.put(None)
self.join()