A collection of possibly useful scraps so far containing a few PyGObject scripts.
Very simple asynchronous desktop notifications with hint and actions support...
see the wiki for documentation.
A decorator that can be used on free functions so they will be called asynchronously, Both to the main thread and to themselves.
A single worker thread that runs asynchronous to the main thread that uses a hybrid FIFO/Priority based queue. Tasks can be asigned a Priority via the optional priority kwarg. (GLib.PRIORITY_DEFAULT_IDLE is the deafult priority) Tasks will be excuted in the order of priority, tasks with the same priority will be excuted FIFO.
An example output of GLib_async_queue_test.py
High priority: Call order 1, return order 1.
High priority: Call order 6, return order 2.
High priority: Call order 10, return order 3.
High priority: Call order 11, return order 4.
Default priority: Call order 3, return order 5.
Default priority: Call order 5, return order 6.
Default priority: Call order 7, return order 7.
Default priority: Call order 9, return order 8.
Low priority: Call order 2, return order 9.
Low priority: Call order 4, return order 10.
Low priority: Call order 8, return order 11.
Low priority: Call order 12, return order 12.
GLib.idle_add decorator.
Turns:
def called_from_an_outside_thread(self, arg1, arg2, kwarg1=1, kwarg2=2):
GLib.idle_add(lambda: self.do_in_main_thread(arg1, arg2, kwarg1=1, kwarg2=2)))
Into:
@GLib_idle()
def do_in_main_thread(self, arg1, arg2, kwarg1=1, kwarg2=2):
#do awesome stuff
Stops a signal handler from recursively calling it's self.
Example:
self.my_signal_handler = self.obj.connect('my-signal', self.on_my_signal)
@GObject_block_signal('my-signal')
def on_my_signal(self, obj, signal):
#do stuff that would cause obj to emit 'my-signal' again