Description
Blinker provides a fast dispatching system that allows any number of
interested parties to subscribe to events, or "signals".
Signal receivers can subscribe to specific senders or receive signals
sent by any sender.
blinker alternatives and similar packages
Based on the "Miscellaneous" category.
Alternatively, view blinker alternatives based on common mentions on social networks and blogs.
-
boltons
๐ฉ Like builtins, but boltons. 250+ constructs, recipes, and snippets which extend (and rely on nothing but) the Python standard library. Nothing like Michael Bolton. -
transitions
A lightweight, object-oriented finite state machine implementation in Python with many extensions -
itsdangerous
Safely pass trusted data to untrusted environments and back. -
PythonMonkey
A Mozilla SpiderMonkey JavaScript engine embedded into the Python VM, using the Python engine to provide the JS host environment. -
riprova
Versatile async-friendly library to retry failed operations with configurable backoff strategies -
Blinker Herald
The Blinker Herald includes helpers to easily emit signals using the excellent blinker library. -
Roundup Issue Tracker
Mirror of http://hg.code.sf.net/p/roundup/code -- used for CI. Please visit https://issues.roundup-tracker.org to find starter issues or log new issues. -
import_string
Imports an object based on a string import_string('package.module:function_name')() - Based on werkzeug.utils
Updating dependencies is time-consuming.
* Code Quality Rankings and insights are calculated and provided by Lumnify.
They vary from L1 to L5 with "L5" being the highest.
Do you think we are missing an alternative of blinker or a related project?
README
Blinker
Blinker provides a fast dispatching system that allows any number of interested parties to subscribe to events, or "signals".
Signal receivers can subscribe to specific senders or receive signals sent by any sender.
It supports dispatching to an arbitrary mix of connected coroutines and receiver functions.
>>> from blinker import signal
>>> started = signal('round-started')
>>> def each(round):
... print "Round %s!" % round
...
>>> started.connect(each)
>>> def round_two(round):
... print "This is round two."
...
>>> started.connect(round_two, sender=2)
>>> for round in range(1, 4):
... started.send(round)
...
Round 1!
Round 2!
This is round two.
Round 3!
See the Blinker documentation for more information.
Requirements
Blinker requires Python 2.7, Python 3.4 or higher, or Jython 2.7 or higher.
Changelog Summary
1.3 (July 3, 2013)
- The global signal stash behind blinker.signal() is now backed by a
regular name-to-Signal dictionary. Previously, weak references were
held in the mapping and ephemeral usage in code like
signal('foo').connect(...)
could have surprising program behavior depending on import order of modules. - blinker.Namespace is now built on a regular dict. Use blinker.WeakNamespace for the older, weak-referencing behavior.
- Signal.connect('text-sender') uses an alternate hashing strategy to avoid sharp edges in text identity.
1.2 (October 26, 2011)
- Added Signal.receiver_connected and Signal.receiver_disconnected per-Signal signals.
- Deprecated the global 'receiver_connected' signal.
- Verified Python 3.2 support (no changes needed!)
1.1 (July 21, 2010)
- Added
@signal.connect_via(sender)
decorator - Added
signal.connected_to
shorthand name for thetemporarily_connected_to
context manager.
1.0 (March 28, 2010)
- Python 3.x compatibility
0.9 (February 26, 2010)
- Sphinx docs, project website
- Added
with a_signal.temporarily_connected_to(receiver): ...
support