Skip to main content

Actor model for Python

Project description

splut

Actor model for Python.

This README is auto-generated, see project wiki for details.

API

splut.actor

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


Download files

Download the file for your platform. If you're not sure which to choose, learn more about installing packages.

Source Distribution

splut-22.tar.gz (6.7 kB view details)

Uploaded Source

Built Distribution

If you're not sure about the file name format, learn more about wheel file names.

splut-22-py3-none-any.whl (7.5 kB view details)

Uploaded Python 3

File details

Details for the file splut-22.tar.gz.

File metadata

  • Download URL: splut-22.tar.gz
  • Upload date:
  • Size: 6.7 kB
  • Tags: Source
  • Uploaded using Trusted Publishing? No
  • Uploaded via: twine/6.1.0 CPython/3.10.12

File hashes

Hashes for splut-22.tar.gz
Algorithm Hash digest
SHA256 81cd761f261dd0b719bdeabb1283f1843464d14363bfa66bbad85a9a8ca81435
MD5 3c79298008502432ebf0ab037aaaf002
BLAKE2b-256 c18647f8deb18059f7d083531a970b643b2dc1698f3848d68033b4dbc0b54685

See more details on using hashes here.

File details

Details for the file splut-22-py3-none-any.whl.

File metadata

  • Download URL: splut-22-py3-none-any.whl
  • Upload date:
  • Size: 7.5 kB
  • Tags: Python 3
  • Uploaded using Trusted Publishing? No
  • Uploaded via: twine/6.1.0 CPython/3.10.12

File hashes

Hashes for splut-22-py3-none-any.whl
Algorithm Hash digest
SHA256 3a6c1680db9a847ceb609a34b93d4cf95f77d29f0755da965046bb1baec95a61
MD5 7aea60619a2565be3d5fe5c0cb0871d9
BLAKE2b-256 8fd6d05c05ea3c215ff0b208e715d0988459852802eb8284ca1bfb56741dcb4f

See more details on using hashes here.

Supported by

AWS Cloud computing and Security Sponsor Datadog Monitoring Depot Continuous Integration Fastly CDN Google Download Analytics Pingdom Monitoring Sentry Error logging StatusPage Status page