GLib event loop for tulip (PEP 3156)
Project description
Gbulb is a Python library that implements a PEP 3156 interface for the GLib main event loop under UNIX-like systems.
As much as possible, except where noted below, it mimics asyncio’s interface. If you notice any differences, please report them.
Requirements
python 3.6+
pygobject
glib
gtk+3 (optional)
Usage
GLib event loop
Example usage:
import asyncio, gbulb gbulb.install() asyncio.get_event_loop().run_forever()
Gtk+ event loop (suitable for GTK+ applications)
Example usage:
import asyncio, gbulb gbulb.install(gtk=True) asyncio.get_event_loop().run_forever()
GApplication/GtkApplication event loop
Example usage:
import asyncio, gbulb gbulb.install(gtk=True) # only necessary if you're using GtkApplication loop = asyncio.get_event_loop() loop.run_forever(application=my_gapplication_object)
Waiting on a signal asynchronously
See examples/wait_signal.py
Known issues
Windows is not supported, sorry. If you are interested in this, please help me get it working! I don’t have Windows so I can’t test it.
Divergences with PEP 3156
In GLib, the concept of event loop is split in two classes: GLib.MainContext and GLib.MainLoop.
The event loop is mostly implemented by MainContext. MainLoop is just a wrapper that implements the run() and quit() functions. MainLoop.run() atomically acquires a MainContext and repeatedly calls MainContext.iteration() until MainLoop.quit() is called.
A MainContext is not bound to a particular thread, however it cannot be used by multiple threads concurrently. If the context is owned by another thread, then MainLoop.run() will block until the context is released by the other thread.
MainLoop.run() may be called recursively by the same thread (this is mainly used for implementing modal dialogs in Gtk).
The issue: given a context, GLib provides no ways to know if there is an existing event loop running for that context. It implies the following divergences with PEP 3156:
.run_forever() and .run_until_complete() are not guaranteed to run immediately. If the context is owned by another thread, then they will block until the context is released by the other thread.
.stop() is relevant only when the currently running Glib.MainLoop object was created by this asyncio object (i.e. by calling .run_forever() or .run_until_complete()). The event loop will quit only when it regains control of the context. This can happen in two cases:
when multiple event loop are enclosed (by creating new MainLoop objects and calling .run() recursively)
when the event loop has not even yet started because it is still trying to acquire the context
It would be wiser not to use any recursion at all. GLibEventLoop will actually prevent you from doing that (in accordance with PEP 3156), however GtkEventLoop will allow you to call run() recursively. You should also keep in mind that enclosed loops may be started at any time by third-party code calling GLib’s primitives.
Community
gblub is part of the BeeWare suite. You can talk to the community through:
We foster a welcoming and respectful community as described in our BeeWare Community Code of Conduct.
Contributing
If you experience problems with gbulb, log them on GitHub. If you want to contribute code, please fork the code and submit a pull request.
Project details
Release history Release notifications | RSS feed
Download files
Download the file for your platform. If you're not sure which to choose, learn more about installing packages.
Source Distribution
Built Distribution
Hashes for gbulb-0.6.2-py2.py3-none-any.whl
Algorithm | Hash digest | |
---|---|---|
SHA256 | 0e79e7e614a69a728cf9c2d8f2d802c9b71bf9b2c49bad5b19b322dd33c8ec5e |
|
MD5 | fb5c2e521a6b8a8d88ac726069fb02a6 |
|
BLAKE2b-256 | f8a66a185b9831fc1616ec9858358c61646f9a0c2af06a58fccc0b7c933889e8 |