mirror of
https://github.com/lune-org/mlua-luau-scheduler.git
synced 2025-04-03 18:10:55 +01:00
Documentation and tracing improvements after rename
This commit is contained in:
parent
8e8647e061
commit
7c59d0c722
12 changed files with 51 additions and 48 deletions
|
@ -76,16 +76,16 @@ lua.globals().set(
|
||||||
### 3. Set up scheduler, run threads
|
### 3. Set up scheduler, run threads
|
||||||
|
|
||||||
```rs
|
```rs
|
||||||
let rt = Scheduler::new(&lua)?;
|
let sched = Scheduler::new(&lua)?;
|
||||||
|
|
||||||
// We can create multiple lua threads ...
|
// We can create multiple lua threads ...
|
||||||
let sleepThread = lua.load("sleep(0.1)");
|
let sleepThread = lua.load("sleep(0.1)");
|
||||||
let fileThread = lua.load("readFile(\"Cargo.toml\")");
|
let fileThread = lua.load("readFile(\"Cargo.toml\")");
|
||||||
|
|
||||||
// ... spawn them both onto the scheduler ...
|
// ... spawn them both onto the scheduler ...
|
||||||
rt.push_thread_front(sleepThread, ());
|
sched.push_thread_front(sleepThread, ());
|
||||||
rt.push_thread_front(fileThread, ());
|
sched.push_thread_front(fileThread, ());
|
||||||
|
|
||||||
// ... and run until they finish
|
// ... and run until they finish
|
||||||
block_on(rt.run());
|
block_on(sched.run());
|
||||||
```
|
```
|
||||||
|
|
|
@ -28,12 +28,12 @@ pub fn main() -> LuaResult<()> {
|
||||||
)?;
|
)?;
|
||||||
|
|
||||||
// Load the main script into a scheduler
|
// Load the main script into a scheduler
|
||||||
let rt = Scheduler::new(&lua);
|
let sched = Scheduler::new(&lua);
|
||||||
let main = lua.load(MAIN_SCRIPT);
|
let main = lua.load(MAIN_SCRIPT);
|
||||||
rt.push_thread_front(main, ())?;
|
sched.push_thread_front(main, ())?;
|
||||||
|
|
||||||
// Run until completion
|
// Run until completion
|
||||||
block_on(rt.run());
|
block_on(sched.run());
|
||||||
|
|
||||||
Ok(())
|
Ok(())
|
||||||
}
|
}
|
||||||
|
|
|
@ -47,12 +47,12 @@ pub fn main() -> LuaResult<()> {
|
||||||
)?;
|
)?;
|
||||||
|
|
||||||
// Load the main script into a scheduler
|
// Load the main script into a scheduler
|
||||||
let rt = Scheduler::new(&lua);
|
let sched = Scheduler::new(&lua);
|
||||||
let main = lua.load(MAIN_SCRIPT);
|
let main = lua.load(MAIN_SCRIPT);
|
||||||
rt.push_thread_front(main, ())?;
|
sched.push_thread_front(main, ())?;
|
||||||
|
|
||||||
// Run until completion
|
// Run until completion
|
||||||
block_on(rt.run());
|
block_on(sched.run());
|
||||||
|
|
||||||
Ok(())
|
Ok(())
|
||||||
}
|
}
|
||||||
|
|
|
@ -19,8 +19,8 @@ pub fn main() -> LuaResult<()> {
|
||||||
let lua = Lua::new();
|
let lua = Lua::new();
|
||||||
|
|
||||||
// Create a new scheduler with custom callbacks
|
// Create a new scheduler with custom callbacks
|
||||||
let rt = Scheduler::new(&lua);
|
let sched = Scheduler::new(&lua);
|
||||||
rt.set_error_callback(|e| {
|
sched.set_error_callback(|e| {
|
||||||
println!(
|
println!(
|
||||||
"Captured error from Lua!\n{}\n{e}\n{}",
|
"Captured error from Lua!\n{}\n{e}\n{}",
|
||||||
"-".repeat(15),
|
"-".repeat(15),
|
||||||
|
@ -30,13 +30,13 @@ pub fn main() -> LuaResult<()> {
|
||||||
|
|
||||||
// Load the main script into the scheduler, and keep track of the thread we spawn
|
// Load the main script into the scheduler, and keep track of the thread we spawn
|
||||||
let main = lua.load(MAIN_SCRIPT);
|
let main = lua.load(MAIN_SCRIPT);
|
||||||
let id = rt.push_thread_front(main, ())?;
|
let id = sched.push_thread_front(main, ())?;
|
||||||
|
|
||||||
// Run until completion
|
// Run until completion
|
||||||
block_on(rt.run());
|
block_on(sched.run());
|
||||||
|
|
||||||
// We should have gotten the error back from our script
|
// We should have gotten the error back from our script
|
||||||
assert!(rt.get_thread_result(id).unwrap().is_err());
|
assert!(sched.get_thread_result(id).unwrap().is_err());
|
||||||
|
|
||||||
Ok(())
|
Ok(())
|
||||||
}
|
}
|
||||||
|
|
|
@ -17,20 +17,20 @@ pub fn main() -> LuaResult<()> {
|
||||||
|
|
||||||
// Set up persistent Lua environment
|
// Set up persistent Lua environment
|
||||||
let lua = Lua::new();
|
let lua = Lua::new();
|
||||||
let rt = Scheduler::new(&lua);
|
let sched = Scheduler::new(&lua);
|
||||||
let fns = Functions::new(&lua)?;
|
let fns = Functions::new(&lua)?;
|
||||||
|
|
||||||
lua.globals().set("exit", fns.exit)?;
|
lua.globals().set("exit", fns.exit)?;
|
||||||
|
|
||||||
// Load the main script into the scheduler
|
// Load the main script into the scheduler
|
||||||
let main = lua.load(MAIN_SCRIPT);
|
let main = lua.load(MAIN_SCRIPT);
|
||||||
rt.push_thread_front(main, ())?;
|
sched.push_thread_front(main, ())?;
|
||||||
|
|
||||||
// Run until completion
|
// Run until completion
|
||||||
block_on(rt.run());
|
block_on(sched.run());
|
||||||
|
|
||||||
// Verify that we got a correct exit code
|
// Verify that we got a correct exit code
|
||||||
let code = rt.get_exit_code().unwrap_or_default();
|
let code = sched.get_exit_code().unwrap_or_default();
|
||||||
assert!(format!("{code:?}").contains("(1)"));
|
assert!(format!("{code:?}").contains("(1)"));
|
||||||
|
|
||||||
Ok(())
|
Ok(())
|
||||||
|
|
|
@ -20,7 +20,7 @@ pub fn main() -> LuaResult<()> {
|
||||||
|
|
||||||
// Set up persistent Lua environment
|
// Set up persistent Lua environment
|
||||||
let lua = Lua::new();
|
let lua = Lua::new();
|
||||||
let rt = Scheduler::new(&lua);
|
let sched = Scheduler::new(&lua);
|
||||||
let fns = Functions::new(&lua)?;
|
let fns = Functions::new(&lua)?;
|
||||||
|
|
||||||
lua.globals().set("spawn", fns.spawn)?;
|
lua.globals().set("spawn", fns.spawn)?;
|
||||||
|
@ -36,10 +36,10 @@ pub fn main() -> LuaResult<()> {
|
||||||
|
|
||||||
// Load the main script into the scheduler
|
// Load the main script into the scheduler
|
||||||
let main = lua.load(MAIN_SCRIPT);
|
let main = lua.load(MAIN_SCRIPT);
|
||||||
rt.push_thread_front(main, ())?;
|
sched.push_thread_front(main, ())?;
|
||||||
|
|
||||||
// Run until completion
|
// Run until completion
|
||||||
block_on(rt.run());
|
block_on(sched.run());
|
||||||
|
|
||||||
Ok(())
|
Ok(())
|
||||||
}
|
}
|
||||||
|
|
|
@ -19,7 +19,7 @@ pub fn main() -> LuaResult<()> {
|
||||||
|
|
||||||
// Set up persistent Lua environment
|
// Set up persistent Lua environment
|
||||||
let lua = Lua::new();
|
let lua = Lua::new();
|
||||||
let rt = Scheduler::new(&lua);
|
let sched = Scheduler::new(&lua);
|
||||||
let fns = Functions::new(&lua)?;
|
let fns = Functions::new(&lua)?;
|
||||||
|
|
||||||
lua.globals().set("spawn", fns.spawn)?;
|
lua.globals().set("spawn", fns.spawn)?;
|
||||||
|
@ -36,13 +36,13 @@ pub fn main() -> LuaResult<()> {
|
||||||
|
|
||||||
// Load the main script into the scheduler, and keep track of the thread we spawn
|
// Load the main script into the scheduler, and keep track of the thread we spawn
|
||||||
let main = lua.load(MAIN_SCRIPT);
|
let main = lua.load(MAIN_SCRIPT);
|
||||||
let id = rt.push_thread_front(main, ())?;
|
let id = sched.push_thread_front(main, ())?;
|
||||||
|
|
||||||
// Run until completion
|
// Run until completion
|
||||||
block_on(rt.run());
|
block_on(sched.run());
|
||||||
|
|
||||||
// We should have gotten proper values back from our script
|
// We should have gotten proper values back from our script
|
||||||
let res = rt.get_thread_result(id).unwrap().unwrap();
|
let res = sched.get_thread_result(id).unwrap().unwrap();
|
||||||
let nums = Vec::<usize>::from_lua_multi(res, &lua)?;
|
let nums = Vec::<usize>::from_lua_multi(res, &lua)?;
|
||||||
assert_eq!(nums, vec![1, 2, 3, 4, 5, 6]);
|
assert_eq!(nums, vec![1, 2, 3, 4, 5, 6]);
|
||||||
|
|
||||||
|
|
|
@ -35,7 +35,7 @@ pub fn main() -> LuaResult<()> {
|
||||||
|
|
||||||
// Set up persistent Lua environment
|
// Set up persistent Lua environment
|
||||||
let lua = Lua::new();
|
let lua = Lua::new();
|
||||||
let rt = Scheduler::new(&lua);
|
let sched = Scheduler::new(&lua);
|
||||||
let fns = Functions::new(&lua)?;
|
let fns = Functions::new(&lua)?;
|
||||||
|
|
||||||
lua.globals().set("spawn", fns.spawn)?;
|
lua.globals().set("spawn", fns.spawn)?;
|
||||||
|
@ -51,10 +51,10 @@ pub fn main() -> LuaResult<()> {
|
||||||
|
|
||||||
// Load the main script into the scheduler
|
// Load the main script into the scheduler
|
||||||
let main = lua.load(MAIN_SCRIPT);
|
let main = lua.load(MAIN_SCRIPT);
|
||||||
rt.push_thread_front(main, ())?;
|
sched.push_thread_front(main, ())?;
|
||||||
|
|
||||||
// Run until completion
|
// Run until completion
|
||||||
block_on(rt.run());
|
block_on(sched.run());
|
||||||
|
|
||||||
Ok(())
|
Ok(())
|
||||||
}
|
}
|
||||||
|
|
|
@ -40,6 +40,9 @@ end
|
||||||
|
|
||||||
/**
|
/**
|
||||||
A collection of lua functions that may be called to interact with a [`Scheduler`].
|
A collection of lua functions that may be called to interact with a [`Scheduler`].
|
||||||
|
|
||||||
|
Note that these may all be implemented using [`LuaSchedulerExt`], however, this struct
|
||||||
|
is implemented using internal (non-public) APIs, and generally has better performance.
|
||||||
*/
|
*/
|
||||||
pub struct Functions<'lua> {
|
pub struct Functions<'lua> {
|
||||||
/**
|
/**
|
||||||
|
@ -112,7 +115,7 @@ impl<'lua> Functions<'lua> {
|
||||||
let resume_map = result_map.clone();
|
let resume_map = result_map.clone();
|
||||||
let resume =
|
let resume =
|
||||||
lua.create_function(move |lua, (thread, args): (LuaThread, LuaMultiValue)| {
|
lua.create_function(move |lua, (thread, args): (LuaThread, LuaMultiValue)| {
|
||||||
let _span = tracing::trace_span!("lua::resume").entered();
|
let _span = tracing::trace_span!("Scheduler::fn_resume").entered();
|
||||||
match thread.resume::<_, LuaMultiValue>(args.clone()) {
|
match thread.resume::<_, LuaMultiValue>(args.clone()) {
|
||||||
Ok(v) => {
|
Ok(v) => {
|
||||||
if v.get(0).map(is_poll_pending).unwrap_or_default() {
|
if v.get(0).map(is_poll_pending).unwrap_or_default() {
|
||||||
|
@ -164,7 +167,7 @@ impl<'lua> Functions<'lua> {
|
||||||
let spawn_map = result_map.clone();
|
let spawn_map = result_map.clone();
|
||||||
let spawn = lua.create_function(
|
let spawn = lua.create_function(
|
||||||
move |lua, (tof, args): (LuaThreadOrFunction, LuaMultiValue)| {
|
move |lua, (tof, args): (LuaThreadOrFunction, LuaMultiValue)| {
|
||||||
let _span = tracing::trace_span!("lua::spawn").entered();
|
let _span = tracing::trace_span!("Scheduler::fn_spawn").entered();
|
||||||
let thread = tof.into_thread(lua)?;
|
let thread = tof.into_thread(lua)?;
|
||||||
if thread.status() == LuaThreadStatus::Resumable {
|
if thread.status() == LuaThreadStatus::Resumable {
|
||||||
// NOTE: We need to resume the thread once instantly for correct behavior,
|
// NOTE: We need to resume the thread once instantly for correct behavior,
|
||||||
|
@ -201,7 +204,7 @@ impl<'lua> Functions<'lua> {
|
||||||
|
|
||||||
let defer = lua.create_function(
|
let defer = lua.create_function(
|
||||||
move |lua, (tof, args): (LuaThreadOrFunction, LuaMultiValue)| {
|
move |lua, (tof, args): (LuaThreadOrFunction, LuaMultiValue)| {
|
||||||
let _span = tracing::trace_span!("lua::defer").entered();
|
let _span = tracing::trace_span!("Scheduler::fn_defer").entered();
|
||||||
let thread = tof.into_thread(lua)?;
|
let thread = tof.into_thread(lua)?;
|
||||||
if thread.status() == LuaThreadStatus::Resumable {
|
if thread.status() == LuaThreadStatus::Resumable {
|
||||||
defer_queue.push_item(lua, &thread, args)?;
|
defer_queue.push_item(lua, &thread, args)?;
|
||||||
|
@ -216,7 +219,7 @@ impl<'lua> Functions<'lua> {
|
||||||
.get::<_, LuaFunction>("close")?;
|
.get::<_, LuaFunction>("close")?;
|
||||||
let close_key = lua.create_registry_value(close)?;
|
let close_key = lua.create_registry_value(close)?;
|
||||||
let cancel = lua.create_function(move |lua, thread: LuaThread| {
|
let cancel = lua.create_function(move |lua, thread: LuaThread| {
|
||||||
let _span = tracing::trace_span!("lua::cancel").entered();
|
let _span = tracing::trace_span!("Scheduler::fn_cancel").entered();
|
||||||
let close: LuaFunction = lua.registry_value(&close_key)?;
|
let close: LuaFunction = lua.registry_value(&close_key)?;
|
||||||
match close.call(thread) {
|
match close.call(thread) {
|
||||||
Err(LuaError::CoroutineInactive) | Ok(()) => Ok(()),
|
Err(LuaError::CoroutineInactive) | Ok(()) => Ok(()),
|
||||||
|
@ -228,7 +231,7 @@ impl<'lua> Functions<'lua> {
|
||||||
(
|
(
|
||||||
"exit",
|
"exit",
|
||||||
lua.create_function(|lua, code: Option<u8>| {
|
lua.create_function(|lua, code: Option<u8>| {
|
||||||
let _span = tracing::trace_span!("lua::exit").entered();
|
let _span = tracing::trace_span!("Scheduler::fn_exit").entered();
|
||||||
let code = code.map(ExitCode::from).unwrap_or_default();
|
let code = code.map(ExitCode::from).unwrap_or_default();
|
||||||
lua.set_exit_code(code);
|
lua.set_exit_code(code);
|
||||||
Ok(())
|
Ok(())
|
||||||
|
|
|
@ -369,7 +369,7 @@ impl<'lua> Scheduler<'lua> {
|
||||||
|
|
||||||
// 5
|
// 5
|
||||||
let mut num_processed = 0;
|
let mut num_processed = 0;
|
||||||
let span_tick = trace_span!("scheduler::tick");
|
let span_tick = trace_span!("Scheduler::tick");
|
||||||
let fut_tick = async {
|
let fut_tick = async {
|
||||||
local_exec.tick().await;
|
local_exec.tick().await;
|
||||||
// NOTE: Try to do as much work as possible instead of just a single tick()
|
// NOTE: Try to do as much work as possible instead of just a single tick()
|
||||||
|
@ -398,21 +398,21 @@ impl<'lua> Scheduler<'lua> {
|
||||||
let mut num_deferred = 0;
|
let mut num_deferred = 0;
|
||||||
let mut num_futures = 0;
|
let mut num_futures = 0;
|
||||||
{
|
{
|
||||||
let _span = trace_span!("scheduler::drain_spawned").entered();
|
let _span = trace_span!("Scheduler::drain_spawned").entered();
|
||||||
for (thread, args) in self.queue_spawn.drain_items(self.lua) {
|
for (thread, args) in self.queue_spawn.drain_items(self.lua) {
|
||||||
process_thread(thread, args);
|
process_thread(thread, args);
|
||||||
num_spawned += 1;
|
num_spawned += 1;
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
{
|
{
|
||||||
let _span = trace_span!("scheduler::drain_deferred").entered();
|
let _span = trace_span!("Scheduler::drain_deferred").entered();
|
||||||
for (thread, args) in self.queue_defer.drain_items(self.lua) {
|
for (thread, args) in self.queue_defer.drain_items(self.lua) {
|
||||||
process_thread(thread, args);
|
process_thread(thread, args);
|
||||||
num_deferred += 1;
|
num_deferred += 1;
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
{
|
{
|
||||||
let _span = trace_span!("scheduler::drain_futures").entered();
|
let _span = trace_span!("Scheduler::drain_futures").entered();
|
||||||
for fut in fut_queue.drain_items() {
|
for fut in fut_queue.drain_items() {
|
||||||
local_exec.spawn(fut).detach();
|
local_exec.spawn(fut).detach();
|
||||||
num_futures += 1;
|
num_futures += 1;
|
||||||
|
|
|
@ -182,9 +182,9 @@ pub trait LuaSpawnExt<'lua> {
|
||||||
})?
|
})?
|
||||||
)?;
|
)?;
|
||||||
|
|
||||||
let rt = Scheduler::new(&lua);
|
let sched = Scheduler::new(&lua);
|
||||||
rt.push_thread_front(lua.load("spawnBackgroundTask()"), ());
|
sched.push_thread_front(lua.load("spawnBackgroundTask()"), ());
|
||||||
block_on(rt.run());
|
block_on(sched.run());
|
||||||
|
|
||||||
Ok(())
|
Ok(())
|
||||||
}
|
}
|
||||||
|
@ -226,9 +226,9 @@ pub trait LuaSpawnExt<'lua> {
|
||||||
})?
|
})?
|
||||||
)?;
|
)?;
|
||||||
|
|
||||||
let rt = Scheduler::new(&lua);
|
let sched = Scheduler::new(&lua);
|
||||||
rt.push_thread_front(lua.load("spawnLocalTask()"), ());
|
sched.push_thread_front(lua.load("spawnLocalTask()"), ());
|
||||||
block_on(rt.run());
|
block_on(sched.run());
|
||||||
|
|
||||||
Ok(())
|
Ok(())
|
||||||
}
|
}
|
||||||
|
@ -268,9 +268,9 @@ pub trait LuaSpawnExt<'lua> {
|
||||||
})?
|
})?
|
||||||
)?;
|
)?;
|
||||||
|
|
||||||
let rt = Scheduler::new(&lua);
|
let sched = Scheduler::new(&lua);
|
||||||
rt.push_thread_front(lua.load("spawnBlockingTask()"), ());
|
sched.push_thread_front(lua.load("spawnBlockingTask()"), ());
|
||||||
block_on(rt.run());
|
block_on(sched.run());
|
||||||
|
|
||||||
Ok(())
|
Ok(())
|
||||||
}
|
}
|
||||||
|
|
|
@ -9,7 +9,7 @@ use tracing::instrument;
|
||||||
|
|
||||||
Otherwise returns the values yielded by the thread, or the error that caused it to stop.
|
Otherwise returns the values yielded by the thread, or the error that caused it to stop.
|
||||||
*/
|
*/
|
||||||
#[instrument(level = "trace", name = "scheduler::run_until_yield", skip_all)]
|
#[instrument(level = "trace", name = "Scheduler::run_until_yield", skip_all)]
|
||||||
pub(crate) async fn run_until_yield<'lua>(
|
pub(crate) async fn run_until_yield<'lua>(
|
||||||
thread: LuaThread<'lua>,
|
thread: LuaThread<'lua>,
|
||||||
args: LuaMultiValue<'lua>,
|
args: LuaMultiValue<'lua>,
|
||||||
|
|
Loading…
Add table
Reference in a new issue