Actor model for Python
Project description
splut
Actor model for Python.
This README is auto-generated, see project wiki for details.
API
splut.actor
ActorHandle Objects
class ActorHandle(Parabject)
__getattr__
def __getattr__(name)
Return a function to add a message to the mailbox, for execution by a capable worker when one becomes free.
__getitem__
def __getitem__(key)
Index or slice workers by the given key and return an actor handle backed by the resulting workers.
__iter__
def __iter__()
For each worker, yield an actor handle backed by that worker specifically.
Spawn Objects
class Spawn()
__init__
def __init__(executor)
Spawned actors will use threads from the given executor.
__call__
def __call__(*objs)
Create an actor backed by the given worker object(s), each of which is used in a single-threaded way.
Calling a method on the returned actor returns a Future immediately, which eventually becomes done with the result of a worker method of the same name (or never if the worker method hangs).
A worker method may be async, in which case it can await futures returned by other actors, releasing the worker in the meantime.
Join Objects
class Join()
Make multiple futures awaitable as a unit. In the zero futures case this resolves (to an empty list) without suspending execution. Otherwise if any future hangs, so does this. Otherwise if any future failed, all such exceptions are raised as a chain. Otherwise all results are returned as a list.
ManualExecutor Objects
class ManualExecutor()
Utilise the main (or any other) thread directly.
run
def run()
Execute tasks until interrupted. Typical usage is for the main thread to call this after setting up the system.
putinterrupt
def putinterrupt()
Cause exactly one thread to exit the run method soon.
splut.actor.future
Future Objects
class Future()
wait
def wait()
Block until there is an outcome, then return/raise it.
For use outside actors, or within one if you know the future is done and don't want to suspend execution with await in that case.
andforget
def andforget(log)
Send any exception to the given log.
splut.bg
Sleeper Objects
class Sleeper()
interrupt
def interrupt()
If a sleep is in progress that sleep returns now, otherwise the next sleep will return immediately. This is similar behaviour to interrupting a maybe-sleeping thread in Java.
splut.bg.delay
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
Filter files by name, interpreter, ABI, and platform.
If you're not sure about the file name format, learn more about wheel file names.
Copy a direct link to the current filters
File details
Details for the file splut-25.tar.gz.
File metadata
- Download URL: splut-25.tar.gz
- Upload date:
- Size: 7.2 kB
- Tags: Source
- Uploaded using Trusted Publishing? No
- Uploaded via: twine/6.1.0 CPython/3.10.12
File hashes
| Algorithm | Hash digest | |
|---|---|---|
| SHA256 |
8acb65ceb35a1626416a27c1adbdd1cb68ea047249775bd7c0f3174f615a9caa
|
|
| MD5 |
f24e9657ed5641c0ee5084c0c11ebbf5
|
|
| BLAKE2b-256 |
b1d99fdca19446cb24c665ac8424cf3ad5f46684e01441e5cce880f075c722a6
|
File details
Details for the file splut-25-py3-none-any.whl.
File metadata
- Download URL: splut-25-py3-none-any.whl
- Upload date:
- Size: 8.1 kB
- Tags: Python 3
- Uploaded using Trusted Publishing? No
- Uploaded via: twine/6.1.0 CPython/3.10.12
File hashes
| Algorithm | Hash digest | |
|---|---|---|
| SHA256 |
142aea137a560f8a0439b41ccf1a1e5e873c516cb109630c4001ec28b1049fcb
|
|
| MD5 |
9d9c1af8da1962fd126961edd0366979
|
|
| BLAKE2b-256 |
f9ec8e72d44f668f12982f6afdb68ae3a57923d306a4fedc3373caaec5532792
|