Atmos is a programming library for Lua that reconciles Structured Concurrency with Event-Driven Programming

$ luarocks install atmos

Atmos is a programming library for Lua that reconciles Structured Concurrency and Event-Driven Programming, extending classical structured programming with two main functionalities:

* Structured Deterministic Concurrency:
- A `task` primitive with deterministic scheduling provides predictable behavior and safe abortion.
- Structured primitives compose concurrent tasks with lexical scope (e.g., `watching`, `every`, `par_or`).
- A `tasks` container primitive holds attached tasks and control their lifecycle.

* Event Signaling Mechanisms:
- An `await` primitive suspends a task and wait for events.
- An `emit` primitive signals events and awake awaiting tasks.

Atmos is inspired by synchronous programming languages like Céu and Esterel.

Versions

0.6-25 days ago13 downloads
0.5-15 days ago34 downloads
0.4-25 days ago9 downloads
0.4-15 days ago2 downloads
0.3-35 days ago11 downloads
0.3-25 days ago4 downloads
0.3-15 days ago1 download
0.2.1-15 days ago15 downloads
0.2-35 days ago(revision: 2)1 download
0.2-25 days ago2 downloads
0.1-15 days ago(revision: 12)18 downloads

Dependencies

f-streams ~> 0.2
lua >= 5.4

Dependency for

atmos-env-iup, atmos-env-pico, atmos-env-sdl, atmos-env-socket, atmos-lang

Manifests