mirror of
https://github.com/embassy-rs/embassy.git
synced 2024-11-22 23:02:30 +00:00
task codegen: use local items instead of non-locals with prefixed names.
This commit is contained in:
parent
53eb594878
commit
57abd7064d
@ -85,29 +85,15 @@ pub fn task(args: TokenStream, item: TokenStream) -> TokenStream {
|
|||||||
|
|
||||||
let name = task_fn.sig.ident.clone();
|
let name = task_fn.sig.ident.clone();
|
||||||
|
|
||||||
let type_name = format_ident!("__embassy_executor_type_{}", name);
|
|
||||||
let pool_name = format_ident!("__embassy_executor_pool_{}", name);
|
|
||||||
let task_fn_name = format_ident!("__embassy_executor_task_{}", name);
|
|
||||||
let create_fn_name = format_ident!("__embassy_executor_create_{}", name);
|
|
||||||
|
|
||||||
let visibility = &task_fn.vis;
|
let visibility = &task_fn.vis;
|
||||||
|
task_fn.sig.ident = format_ident!("task");
|
||||||
task_fn.sig.ident = task_fn_name.clone();
|
|
||||||
|
|
||||||
let result = quote! {
|
let result = quote! {
|
||||||
#task_fn
|
|
||||||
#[allow(non_camel_case_types)]
|
|
||||||
type #type_name = impl ::core::future::Future + 'static;
|
|
||||||
|
|
||||||
fn #create_fn_name(#args) -> #type_name {
|
|
||||||
#task_fn_name(#arg_names)
|
|
||||||
}
|
|
||||||
|
|
||||||
#[allow(non_upper_case_globals)]
|
|
||||||
static #pool_name: [::embassy::executor::Task<#type_name>; #pool_size] = [::embassy::executor::Task::new(); #pool_size];
|
|
||||||
|
|
||||||
#visibility fn #name(#args) -> ::embassy::executor::SpawnToken {
|
#visibility fn #name(#args) -> ::embassy::executor::SpawnToken {
|
||||||
unsafe { ::embassy::executor::Task::spawn(&#pool_name, || #create_fn_name(#arg_names)) }
|
#task_fn
|
||||||
|
type F = impl ::core::future::Future + 'static;
|
||||||
|
static POOL: [::embassy::executor::Task<F>; #pool_size] = [::embassy::executor::Task::new(); #pool_size];
|
||||||
|
unsafe { ::embassy::executor::Task::spawn(&POOL, || task(#arg_names)) }
|
||||||
}
|
}
|
||||||
};
|
};
|
||||||
result.into()
|
result.into()
|
||||||
|
Loading…
Reference in New Issue
Block a user