diff options
| author | Oleksandr Babak <alexanderbabak@proton.me> | 2025-03-23 09:48:13 +0100 |
|---|---|---|
| committer | Emil Fresk <emil.fresk@gmail.com> | 2025-03-27 14:47:11 +0000 |
| commit | 22ba6bac0679acb0ff61495eee5044bfdd01fac3 (patch) | |
| tree | 0b75a2bee25822358cb4bcbfe2b1efd621135c04 /rtic-macros/src/codegen | |
| parent | 0593a7290bcc5f134a7c3a33f0431979cf4f0121 (diff) | |
refactor: remove minor code duplication
Diffstat (limited to 'rtic-macros/src/codegen')
| -rw-r--r-- | rtic-macros/src/codegen/software_tasks.rs | 36 |
1 files changed, 12 insertions, 24 deletions
diff --git a/rtic-macros/src/codegen/software_tasks.rs b/rtic-macros/src/codegen/software_tasks.rs index 71caec0..a3f70c3 100644 --- a/rtic-macros/src/codegen/software_tasks.rs +++ b/rtic-macros/src/codegen/software_tasks.rs @@ -37,32 +37,20 @@ pub fn codegen(app: &App, analysis: &Analysis) -> TokenStream2 { let cfgs = &task.cfgs; let stmts = &task.stmts; let inputs = &task.inputs; + let lifetime = if task.is_bottom { quote!('static) } else { quote!('a) }; + let generics = if task.is_bottom { quote!() } else { quote!(<'a>) }; - user_tasks.push(if task.is_bottom { - quote!( - #(#attrs)* - #(#cfgs)* - #[allow(non_snake_case)] - async fn #name(#context: #name::Context<'static> #(,#inputs)*) { - use rtic::Mutex as _; - use rtic::mutex::prelude::*; + user_tasks.push(quote!( + #(#attrs)* + #(#cfgs)* + #[allow(non_snake_case)] + async fn #name#generics(#context: #name::Context<#lifetime> #(,#inputs)*) { + use rtic::Mutex as _; + use rtic::mutex::prelude::*; - #(#stmts)* - } - ) - } else { - quote!( - #(#attrs)* - #(#cfgs)* - #[allow(non_snake_case)] - async fn #name<'a>(#context: #name::Context<'a> #(,#inputs)*) { - use rtic::Mutex as _; - use rtic::mutex::prelude::*; - - #(#stmts)* - } - ) - }); + #(#stmts)* + } + )); } root.push(module::codegen(Context::SoftwareTask(name), app, analysis)); |
