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-219 days ago12 downloads
0.5-177 days ago33 downloads
0.4-2142 days ago8 downloads
0.4-1142 days ago1 download
0.3-3182 days ago10 downloads
0.3-2190 days ago3 downloads
0.3-1195 days ago0 downloads
0.2.1-1241 days ago14 downloads
0.2-3252 days ago(revision: 2)0 downloads
0.2-2255 days ago1 download
0.1-1284 days ago(revision: 12)17 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