Lightweight Event Handling
Project description
python-dispatch
Lightweight event handling for Python
Description
This is an implementation of the "Observer Pattern" with inspiration from the Kivy framework. Many of the features though are intentionally stripped down and more generalized. The goal is to have a simple drop-in library with no dependencies that stays out of the programmer's way.
Installation
"python-dispatch" is available on PyPI and can be installed using pip:
pip install python-dispatch
Python Requirements
After version 0.1
of this project, only Python 3.6 and above will be supported.
If using an older Python version, the older releases should still be available
on PyPI and the correct package should be chosen automatically by pip
.
If not, either upgrade pip
and setuptools
:
pip install -U pip setuptools
Or specify the version manually:
pip install python-dispatch<0.2
Links
Project Home | https://github.com/nocarryr/python-dispatch |
PyPI | https://pypi.python.org/pypi/python-dispatch |
Documentation | https://python-dispatch.readthedocs.io |
Usage
Events
>>> from pydispatch import Dispatcher
>>> class MyEmitter(Dispatcher):
... # Events are defined in classes and subclasses with the '_events_' attribute
... _events_ = ['on_state', 'new_data']
... def do_some_stuff(self):
... # do stuff that makes new data
... data = {'foo':'bar'}
... # Then emit the change with optional positional and keyword arguments
... self.emit('new_data', data=data)
>>> # An observer - could inherit from Dispatcher or any other class
>>> class MyListener(object):
... def on_new_data(self, *args, **kwargs):
... data = kwargs.get('data')
... print('I got data: {}'.format(data))
... def on_emitter_state(self, *args, **kwargs):
... print('emitter state changed')
>>> emitter = MyEmitter()
>>> listener = MyListener()
>>> # Bind to the "on_state" and "new_data" events of emitter
>>> emitter.bind(on_state=listener.on_emitter_state)
>>> emitter.bind(new_data=listener.on_new_data)
>>> emitter.do_some_stuff()
I got data: {'foo': 'bar'}
>>> emitter.emit('on_state')
emitter state changed
Properties
>>> from pydispatch import Dispatcher, Property
>>> class MyEmitter(Dispatcher):
... # Property objects are defined and named at the class level.
... # They will become instance attributes that will emit events when their values change
... name = Property()
... value = Property()
>>> class MyListener(object):
... def on_name(self, instance, value, **kwargs):
... print('emitter name is {}'.format(value))
... def on_value(self, instance, value, **kwargs):
... print('emitter value is {}'.format(value))
>>> emitter = MyEmitter()
>>> listener = MyListener()
>>> # Bind to the "name" and "value" properties of emitter
>>> emitter.bind(name=listener.on_name, value=listener.on_value)
>>> # Set emitter.name property (triggering the on_name callback)
>>> emitter.name = 'foo'
emitter name is foo
>>> # Set emitter.value (triggering the on_value callback)
>>> emitter.value = 42
emitter value is 42
Contributing
Contributions are welcome!
If you want to contribute through code or documentation, please see the Contributing Guide for information.
License
This project is released under the MIT License. See the LICENSE file for more information.
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
File details
Details for the file python-dispatch-0.2.2.tar.gz
.
File metadata
- Download URL: python-dispatch-0.2.2.tar.gz
- Upload date:
- Size: 25.0 kB
- Tags: Source
- Uploaded using Trusted Publishing? No
- Uploaded via: twine/4.0.2 CPython/3.8.17
File hashes
Algorithm | Hash digest | |
---|---|---|
SHA256 | d05278ff76625a53865c92ca6b5069e82c27b5741999f7ec737c64180f0123e6 |
|
MD5 | 1192b4e4ab1f746ff01e96599303dcb3 |
|
BLAKE2b-256 | 03443cf80a3931741fb97dbfaff1b2a8bf0174b18610d2bbc89ee12b19c3220b |
File details
Details for the file python_dispatch-0.2.2-py3-none-any.whl
.
File metadata
- Download URL: python_dispatch-0.2.2-py3-none-any.whl
- Upload date:
- Size: 17.2 kB
- Tags: Python 3
- Uploaded using Trusted Publishing? No
- Uploaded via: twine/4.0.2 CPython/3.8.17
File hashes
Algorithm | Hash digest | |
---|---|---|
SHA256 | 0305898bf011fb164bb21e0f48809cf21faee6d8ea311177bd9a43f86201b9cd |
|
MD5 | c1efa95b7f4a607e31fa9a897fac6feb |
|
BLAKE2b-256 | ccd58776e1bdd008c093e68f0a78dbc0c0d52f602c539eb218fe3e10661c9195 |