mirror of
https://github.com/lune-org/lune.git
synced 2024-12-13 13:30:38 +00:00
Some work on async functions for new scheduler
This commit is contained in:
parent
0a5305b947
commit
7c8af9730f
4 changed files with 111 additions and 4 deletions
40
Cargo.lock
generated
40
Cargo.lock
generated
|
@ -1140,6 +1140,7 @@ dependencies = [
|
||||||
"bstr",
|
"bstr",
|
||||||
"erased-serde",
|
"erased-serde",
|
||||||
"mlua-sys",
|
"mlua-sys",
|
||||||
|
"mlua_derive",
|
||||||
"num-traits",
|
"num-traits",
|
||||||
"once_cell",
|
"once_cell",
|
||||||
"rustc-hash",
|
"rustc-hash",
|
||||||
|
@ -1159,6 +1160,21 @@ dependencies = [
|
||||||
"pkg-config",
|
"pkg-config",
|
||||||
]
|
]
|
||||||
|
|
||||||
|
[[package]]
|
||||||
|
name = "mlua_derive"
|
||||||
|
version = "0.9.0-rc.2"
|
||||||
|
source = "registry+https://github.com/rust-lang/crates.io-index"
|
||||||
|
checksum = "4b900bf5619cdf327722cb39424409856a46f3a516628117a896cdbeecc0a9b1"
|
||||||
|
dependencies = [
|
||||||
|
"itertools",
|
||||||
|
"once_cell",
|
||||||
|
"proc-macro-error",
|
||||||
|
"proc-macro2",
|
||||||
|
"quote",
|
||||||
|
"regex",
|
||||||
|
"syn 2.0.28",
|
||||||
|
]
|
||||||
|
|
||||||
[[package]]
|
[[package]]
|
||||||
name = "nibble_vec"
|
name = "nibble_vec"
|
||||||
version = "0.1.0"
|
version = "0.1.0"
|
||||||
|
@ -1331,6 +1347,30 @@ version = "0.2.17"
|
||||||
source = "registry+https://github.com/rust-lang/crates.io-index"
|
source = "registry+https://github.com/rust-lang/crates.io-index"
|
||||||
checksum = "5b40af805b3121feab8a3c29f04d8ad262fa8e0561883e7653e024ae4479e6de"
|
checksum = "5b40af805b3121feab8a3c29f04d8ad262fa8e0561883e7653e024ae4479e6de"
|
||||||
|
|
||||||
|
[[package]]
|
||||||
|
name = "proc-macro-error"
|
||||||
|
version = "1.0.4"
|
||||||
|
source = "registry+https://github.com/rust-lang/crates.io-index"
|
||||||
|
checksum = "da25490ff9892aab3fcf7c36f08cfb902dd3e71ca0f9f9517bea02a73a5ce38c"
|
||||||
|
dependencies = [
|
||||||
|
"proc-macro-error-attr",
|
||||||
|
"proc-macro2",
|
||||||
|
"quote",
|
||||||
|
"syn 1.0.109",
|
||||||
|
"version_check",
|
||||||
|
]
|
||||||
|
|
||||||
|
[[package]]
|
||||||
|
name = "proc-macro-error-attr"
|
||||||
|
version = "1.0.4"
|
||||||
|
source = "registry+https://github.com/rust-lang/crates.io-index"
|
||||||
|
checksum = "a1be40180e52ecc98ad80b184934baf3d0d29f979574e439af5a55274b35f869"
|
||||||
|
dependencies = [
|
||||||
|
"proc-macro2",
|
||||||
|
"quote",
|
||||||
|
"version_check",
|
||||||
|
]
|
||||||
|
|
||||||
[[package]]
|
[[package]]
|
||||||
name = "proc-macro-hack"
|
name = "proc-macro-hack"
|
||||||
version = "0.5.20+deprecated"
|
version = "0.5.20+deprecated"
|
||||||
|
|
|
@ -78,6 +78,7 @@ urlencoding = "2.1"
|
||||||
### RUNTIME
|
### RUNTIME
|
||||||
|
|
||||||
mlua = { version = "0.9.0-beta.3", features = [
|
mlua = { version = "0.9.0-beta.3", features = [
|
||||||
|
"macros",
|
||||||
"luau",
|
"luau",
|
||||||
"luau-jit",
|
"luau-jit",
|
||||||
"serialize",
|
"serialize",
|
||||||
|
|
|
@ -1,18 +1,41 @@
|
||||||
use futures_util::Future;
|
use futures_util::Future;
|
||||||
|
use mlua::prelude::*;
|
||||||
|
|
||||||
use super::SchedulerImpl;
|
use super::{traits::IntoLuaThread, SchedulerImpl};
|
||||||
|
|
||||||
impl SchedulerImpl {
|
impl<'lua> SchedulerImpl {
|
||||||
/**
|
/**
|
||||||
Schedules a plain future to run whenever the scheduler is available.
|
Schedules a plain future to run whenever the scheduler is available.
|
||||||
*/
|
*/
|
||||||
pub fn schedule_future<F>(&self, fut: F)
|
pub fn schedule_future<F>(&self, fut: F)
|
||||||
where
|
where
|
||||||
F: Future<Output = ()> + 'static,
|
F: 'static + Future<Output = ()>,
|
||||||
{
|
{
|
||||||
self.futures
|
self.futures
|
||||||
.try_lock()
|
.try_lock()
|
||||||
.expect("Failed to lock futures queue")
|
.expect("Failed to lock futures queue")
|
||||||
.push(Box::pin(fut))
|
.push(Box::pin(fut))
|
||||||
}
|
}
|
||||||
|
/**
|
||||||
|
Schedules the given `thread` to run when the given `fut` completes.
|
||||||
|
*/
|
||||||
|
pub fn schedule_thread<T, R, F>(&'lua self, thread: T, fut: F) -> LuaResult<()>
|
||||||
|
where
|
||||||
|
T: IntoLuaThread<'lua>,
|
||||||
|
R: IntoLuaMulti<'lua>,
|
||||||
|
F: 'static + Future<Output = LuaResult<R>>,
|
||||||
|
{
|
||||||
|
let thread = thread.into_lua_thread(&self.lua)?;
|
||||||
|
|
||||||
|
let fut = async move {
|
||||||
|
let rets = fut.await.expect("Failed to receive result");
|
||||||
|
self.push_back(thread, rets)
|
||||||
|
.expect("Failed to schedule future thread");
|
||||||
|
};
|
||||||
|
|
||||||
|
// TODO: Lifetime issues
|
||||||
|
// self.schedule_future(fut);
|
||||||
|
|
||||||
|
Ok(())
|
||||||
|
}
|
||||||
}
|
}
|
||||||
|
|
|
@ -1,4 +1,5 @@
|
||||||
use mlua::prelude::*;
|
use futures_util::Future;
|
||||||
|
use mlua::{chunk, prelude::*};
|
||||||
|
|
||||||
use super::Scheduler;
|
use super::Scheduler;
|
||||||
|
|
||||||
|
@ -15,6 +16,20 @@ pub trait LuaSchedulerExt {
|
||||||
not be dropped either because of the strong reference.
|
not be dropped either because of the strong reference.
|
||||||
*/
|
*/
|
||||||
fn scheduler(&self) -> Scheduler;
|
fn scheduler(&self) -> Scheduler;
|
||||||
|
|
||||||
|
/**
|
||||||
|
Creates a function callable from Lua that runs an async
|
||||||
|
closure and returns the results of it to the call site.
|
||||||
|
*/
|
||||||
|
fn create_async_function<'lua, A, R, F, FR>(
|
||||||
|
&'lua self,
|
||||||
|
func: F,
|
||||||
|
) -> LuaResult<LuaFunction<'lua>>
|
||||||
|
where
|
||||||
|
A: FromLuaMulti<'lua>,
|
||||||
|
R: IntoLuaMulti<'lua>,
|
||||||
|
F: 'static + Fn(&'lua Lua, A) -> FR,
|
||||||
|
FR: 'static + Future<Output = LuaResult<R>>;
|
||||||
}
|
}
|
||||||
|
|
||||||
impl LuaSchedulerExt for Lua {
|
impl LuaSchedulerExt for Lua {
|
||||||
|
@ -23,6 +38,34 @@ impl LuaSchedulerExt for Lua {
|
||||||
.expect("Lua struct is missing scheduler")
|
.expect("Lua struct is missing scheduler")
|
||||||
.clone()
|
.clone()
|
||||||
}
|
}
|
||||||
|
|
||||||
|
fn create_async_function<'lua, A, R, F, FR>(&'lua self, func: F) -> LuaResult<LuaFunction<'lua>>
|
||||||
|
where
|
||||||
|
A: FromLuaMulti<'lua>,
|
||||||
|
R: IntoLuaMulti<'lua>,
|
||||||
|
F: 'static + Fn(&'lua Lua, A) -> FR,
|
||||||
|
FR: 'static + Future<Output = LuaResult<R>>,
|
||||||
|
{
|
||||||
|
let async_yield = self
|
||||||
|
.globals()
|
||||||
|
.get::<_, LuaTable>("coroutine")?
|
||||||
|
.get::<_, LuaFunction>("yield")?;
|
||||||
|
let async_schedule = self.create_function(move |lua: &Lua, args: A| {
|
||||||
|
let thread = lua.current_thread();
|
||||||
|
let future = func(lua, args);
|
||||||
|
// TODO: Add to scheduler
|
||||||
|
Ok(())
|
||||||
|
})?;
|
||||||
|
|
||||||
|
let async_func = self
|
||||||
|
.load(chunk!({
|
||||||
|
$async_schedule(...)
|
||||||
|
return $async_yield()
|
||||||
|
}))
|
||||||
|
.set_name("async")
|
||||||
|
.into_function()?;
|
||||||
|
Ok(async_func)
|
||||||
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
/**
|
/**
|
||||||
|
|
Loading…
Reference in a new issue