mirror of
https://github.com/lune-org/mlua-luau-scheduler.git
synced 2025-04-03 01:50:57 +01:00
An async scheduler for Luau
.github/workflows | ||
.vscode | ||
examples | ||
lib | ||
.editorconfig | ||
.gitattributes | ||
.gitignore | ||
Cargo.lock | ||
Cargo.toml | ||
LICENSE.txt | ||
README.md | ||
stylua.toml |
smol-mlua
Integration between smol and mlua that provides a fully functional and asynchronous Luau runtime using smol executor(s).
Example Usage
1. Import dependencies
use std::time::{Duration, Instant};
use smol_mlua::{
mlua::prelude::*,
smol::{Timer, io, fs::read_to_string},
Runtime,
};
2. Set up lua environment
let lua = Lua::new();
lua.globals().set(
"sleep",
lua.create_async_function(|_, duration: f64| async move {
let before = Instant::now();
let after = Timer::after(Duration::from_secs_f64(duration)).await;
Ok((after - before).as_secs_f64())
})?,
)?;
lua.globals().set(
"readFile",
lua.create_async_function(|lua, path: String| async move {
// Spawn background task that does not take up resources on the lua thread
// Normally, futures in mlua can not be shared across threads, but this can
let task = lua.spawn(async move {
match read_to_string(path).await {
Ok(s) => Ok(Some(s)),
Err(e) if e.kind() == io::ErrorKind::NotFound => Ok(None),
Err(e) => Err(e),
}
});
task.await.into_lua_err()
})?,
)?;
3. Run
let rt = Runtime::new(&lua)?;
// We can create multiple lua threads
let sleepThread = lua.load("sleep(0.1)");
let fileThread = lua.load("readFile(\"Cargo.toml\")");
// Put them all into the runtime
rt.push_thread(sleepThread, ());
rt.push_thread(fileThread, ());
// And run either async or blocking, until above threads finish
rt.run_async().await;
rt.run_blocking();