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-210 days ago9 downloads
0.5-168 days ago32 downloads
0.4-2133 days ago8 downloads
0.4-1134 days ago1 download
0.3-3173 days ago10 downloads
0.3-2181 days ago3 downloads
0.3-1186 days ago0 downloads
0.2.1-1232 days ago14 downloads
0.2-3243 days ago(revision: 2)0 downloads
0.2-2246 days ago1 download
0.1-1275 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