Tardy (def: delaying or delayed beyond the right or expected time; late.) is an asynchronous runtime for writing applications and services in Zig. Most of the code for this project originated in zzz, a performance oriented networking framework.
- Performant: Tardy utilizes the latest Asynchronous APIs while minimizing allocations.
- Portable: Tardy natively supports Linux, Mac and Windows. Easy to port through the custom Async I/O system.
- Scalable: Tardy uses very little memory initially and can be tuned using various configuration options.
Tracking Latest Zig Stable: 0.13.0
zig fetch --save git+https://github.com/mookums/tardy#main
You can then add the dependency in your build.zig
file:
const tardy = b.dependency("tardy", .{
.target = target,
.optimize = optimize,
}).module("tardy");
exe.root_module.addImport(tardy);
Important
Tardy is currently alpha software. It's fast and it works but is still experimental!
- Modular Asynchronous Implementation
io_uring
for Linux (>= 5.1.0).epoll
for Linux (>= 2.5.45).busy_loop
for Linux, Mac and Windows.
- Single and Multi-threaded Support
- Callbacks on Async I/O events (through
runtime.[net/fs]
) - Green Threads (through
runtime.spawn
)
- zzz: a framework for writing performant and reliable networked services.
Unless you explicitly state otherwise, any contribution intentionally submitted for inclusion in Tardy by you, shall be licensed as MPL2.0, without any additional terms or conditions.