Updated ticker_gtk.py

This commit is contained in:
2018-05-24 21:48:04 +02:00
parent f528b2cbab
commit 8fa5db1da1
2 changed files with 60 additions and 38 deletions

View File

@@ -25,22 +25,18 @@ gobject.threads_init()
class Listener(gobject.GObject):
__gsignals__ = {
'ticker_update' : (gobject.SIGNAL_RUN_LAST,
gobject.TYPE_NONE,
(gobject.TYPE_FLOAT,
gobject.TYPE_FLOAT,
gobject.TYPE_FLOAT)),
'ticker_finished' : (gobject.SIGNAL_RUN_LAST,
'handlers_update' : (gobject.SIGNAL_RUN_LAST,
gobject.TYPE_NONE,
()),
(gobject.TYPE_FLOAT,
gobject.TYPE_FLOAT,
gobject.TYPE_FLOAT)),
'handlers_finished' : (gobject.SIGNAL_RUN_LAST,
gobject.TYPE_NONE,
()),
'workers_update' : (gobject.SIGNAL_RUN_LAST,
gobject.TYPE_NONE,
(gobject.TYPE_FLOAT,
gobject.TYPE_FLOAT,
gobject.TYPE_FLOAT)),
(gobject.TYPE_STRING,
gobject.TYPE_PYOBJECT)),
'workers_finished' : (gobject.SIGNAL_RUN_LAST,
gobject.TYPE_NONE,
())
@@ -61,13 +57,13 @@ class Listener(gobject.GObject):
print("Ticker is finishing.")
self.emit("ticker_finished", data[0])
return
elif data[0]=="ticker_update":
print("Ticker is working.")
self.emit("update_ticker")
elif data[0]=="handler_update":
print("Handlers are working.")
self.emit("handlers_update")
return
elif data[0]=="work_update":
print("Workers are working.")
self.emit("update_workers", data[0], data[1], data[2])
self.emit("workers_update", data[1])
return
else:
self.emit('update_ticker', data[0], data[1], data[2])
@@ -75,25 +71,36 @@ class Listener(gobject.GObject):
gobject.type_register(Listener)
class Worker():
def __init__(self, sq, wq, i):
def __init__(self, l, sq, wq, i):
self.lock = l
self.signal_queue = sq
self.work_queue = wq
self.iterations = i
self.fractions = []
def go(self):
while True:
print("Working")
task = self.work_queue.get(2)
lock = multiprocessing.Lock().acquire()
tasks = self.work_queue.qsize()
lock.release()
self.fractions.append(task)
print(task)
self.lock.acquire()
try:
tasks = self.work_queue.qsize()
self.fractions.append(tasks)
print(tasks)
finally:
self.lock.release()
with self.iterations.get_lock():
if task is None:
break
self.iterations.value += 1
tasks = tasks/1000
self.fractions.append(self.iterations.value)
print(self.iterations.value)
#tasks = tasks/1000
time.sleep(0.001)
self.work_queue.task_done()
self.signal_queue.put("work_update", tasks, self.iterations)
self.signal_queue.put("work_update", self.fractions)
self.work_queue.task_done()
self.signal_queue.put("work_finished")
@@ -105,11 +112,15 @@ class Handler():
self.iterations = i
def go(self):
while self.ticker_queue.empty() is not True:
ticker = self.ticker_queue.get(0.1)
self.work_queue.put(ticker-1000)
time.sleep(0.01)
self.ticker_queue.task_done()
while True:
if self.ticker_queue.empty() is not True:
ticker = self.ticker_queue.get(0.1)
self.work_queue.put(ticker-1000)
time.sleep(0.01)
self.ticker_queue.task_done()
self.ticker_queue.task_done()
self.signal_queue.put("")
#def looprun(n):
#for i in tickers:
@@ -156,7 +167,7 @@ class ticker:
self.work_current_count = 0
self.work_processed_count = 0
self.ticker_num = globvar.ticker_num
self.fraction = 0
self.fraction = 1/1000
self.process = None
self.signal_queue = multiprocessing.JoinableQueue()
self.ticker_queue = multiprocessing.JoinableQueue()
@@ -166,6 +177,7 @@ class ticker:
self.work_num = 0
self.processes = []
self.threads = []
self.lock = multiprocessing.Lock()
self.app = Gtk.Application.new("org.ticker", Gio.ApplicationFlags(0))
self.app.connect("activate", self.on_app_activate)
self.app.connect("shutdown", self.on_app_shutdown)
@@ -180,7 +192,7 @@ class ticker:
self.obj = builder.get_object
self.obj("window").set_application(app)
self.obj("window").set_wmclass("ticker","ticker")
self.obj("window").set_title("ticker - v.0.0.1")
self.obj("window").set_title("ticker - v.0.1.15")
self.obj("window").show_all()
self.obj("ticker_put_count_label").set_text(str(self.ticker_put_count))
self.obj("ticker_items_count_label").set_text(str(self.ticker_current_count))
@@ -206,15 +218,15 @@ class ticker:
self.obj("ticker_processed_count_label").set_text(index3)
self.obj("ticker_processed_progressbar").set_fraction(self.val_3)
def update_work(self, obj, index1, index2, index3, data=None):
self.val_1 = index1*self.fraction
self.val_2 = index2*self.fraction
self.val_3 = index3*self.fraction
self.obj("work_put_count_label").set_text(index1)
def update_work(self, obj, index):
self.val_1 = index[0]*self.fraction
self.val_2 = index[1]*self.fraction
self.val_3 = index[2]*self.fraction
self.obj("work_put_count_label").set_text(index[0])
self.obj("work_put_progressbar").set_fraction(self.val_1)
self.obj("work_items_count_label").set_text(index2)
self.obj("work_items_count_label").set_text(index[1])
self.obj("work_items_progressbar").set_fraction(self.val_2)
self.obj("work_processed_count_label").set_text(index3)
self.obj("work_processed_count_label").set_text(index[2])
self.obj("work_processed_progressbar").set_fraction(self.val_3)
def ticker_Finished(self, obj, data=None):
@@ -251,8 +263,8 @@ class ticker:
def on_execute_clicked(self,widget):
print("Creating Listener")
listener = Listener(self.signal_queue)
listener.connect("ticker_update",self.update_ticker)
listener.connect("ticker_finished",self.ticker_Finished)
listener.connect("handlers_update",self.update_ticker)
listener.connect("handlers_finished",self.ticker_Finished)
listener.connect("workers_update",self.update_work)
listener.connect("workers_finished",self.workers_Finished)
@@ -260,11 +272,21 @@ class ticker:
thread = threading.Thread(target=listener.go, args=())
thread.start()
print("Creating ticker queue")
for i in self.tickers:
self.ticker_queue.put(i)
print(self.ticker_queue.qsize())
for i in range(20):
h = Handler(self.signal_queue, self.ticker_queue, self.work_queue, self.iterations)
t = threading.Thread(target = h.go, args = ())
t.deamon = True
t.start()
self.threads.append(t)
for i in range(8):
p = multiprocessing.Process(target = Worker.go, args = (self.work_queue, self.iterations, ))
w = Worker(self.lock, self.signal_queue, self.work_queue, self.iterations)
p = multiprocessing.Process(target = w.go, args=())
p.deamon = True
p.start()
self.processes.append(p)

View File

@@ -59,7 +59,7 @@ def looprun(n):
return
if __name__=='__main__:
for n in range(100):
looprun(n+1)