-
Notifications
You must be signed in to change notification settings - Fork 1
/
Copy pathGBQueue.py
85 lines (63 loc) · 2.38 KB
/
GBQueue.py
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
"""
Copyright (C) 2020 Eili Klein
This program is free software: you can redistribute it and/or modify
it under the terms of the GNU General Public License as published by
the Free Software Foundation, either version 3 of the License, or
(at your option) any later version.
This program is distributed in the hope that it will be useful,
but WITHOUT ANY WARRANTY; without even the implied warranty of
MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
GNU General Public License for more details.
You should have received a copy of the GNU General Public License
along with this program. If not, see <http://www.gnu.org/licenses/>.
"""
import multiprocessing as mp
import multiprocessing.queues as mpq
from queue import Empty, Full
import time
class MPQueue(mpq.Queue):
DEFAULT_POLLING_TIMEOUT = 0.02
# -- See StackOverflow Article :
# https://stackoverflow.com/questions/39496554/cannot-subclass-multiprocessing-queue-in-python-3-5
#
# -- tldr; mp.Queue is a _method_ that returns an mpq.Queue object. That object
# requires a context for proper operation, so this __init__ does that work as well.
def __init__(self, *args, **kwargs):
ctx = mp.get_context()
super().__init__(*args, **kwargs, ctx=ctx)
def safe_get(self, timeout=DEFAULT_POLLING_TIMEOUT):
try:
if timeout is None:
return self.get(block=False)
else:
return self.get(block=True, timeout=timeout)
except Empty:
return None
def safe_put(self, item, timeout=DEFAULT_POLLING_TIMEOUT):
try:
self.put(item, block=False, timeout=timeout)
return True
except Full:
return False
def drain(self):
item = self.safe_get()
while item:
yield item
item = self.safe_get()
def safe_close(self):
try:
#num_left = sum(1 for __ in self.drain())
self.close()
self.join_thread()
except:
print("error closing Queue")
pass
#return num_left
class EventMessage:
def __init__(self, msg_src, msg_type, msg):
self.id = time.time()
self.msg_src = msg_src
self.msg_type = msg_type
self.msg = msg
def __str__(self):
return f"{self.msg_src:10} - {self.msg_type:10} : {self.msg}"