diff options
author | 2021-07-07 21:03:56 +0200 | |
---|---|---|
committer | 2021-07-07 21:04:31 +0200 | |
commit | d7393c5b27fc95f3569d12137ee0c4d03ff7e2ba (patch) | |
tree | b90e094920cb859bb9e401f3acdddcadf675c834 /macros/src/codegen/software_tasks.rs | |
parent | ef5307d83a1d62df0569d78db75d4006147c927d (diff) | |
download | rtic-d7393c5b27fc95f3569d12137ee0c4d03ff7e2ba.tar.gz rtic-d7393c5b27fc95f3569d12137ee0c4d03ff7e2ba.tar.zst rtic-d7393c5b27fc95f3569d12137ee0c4d03ff7e2ba.zip |
Full local resource syntax working
Diffstat (limited to 'macros/src/codegen/software_tasks.rs')
-rw-r--r-- | macros/src/codegen/software_tasks.rs | 22 |
1 files changed, 14 insertions, 8 deletions
diff --git a/macros/src/codegen/software_tasks.rs b/macros/src/codegen/software_tasks.rs index da594e7d..6941d9a0 100644 --- a/macros/src/codegen/software_tasks.rs +++ b/macros/src/codegen/software_tasks.rs @@ -90,13 +90,16 @@ pub fn codegen( )); // `${task}Resources` - let mut needs_lt = false; + let mut shared_needs_lt = false; + let mut local_needs_lt = false; - // TODO: Fix locals // `${task}Locals` if !task.args.local_resources.is_empty() { - let (item, constructor) = - local_resources_struct::codegen(Context::SoftwareTask(name), &mut needs_lt, app); + let (item, constructor) = local_resources_struct::codegen( + Context::SoftwareTask(name), + &mut local_needs_lt, + app, + ); root.push(item); @@ -104,15 +107,17 @@ pub fn codegen( } if !task.args.shared_resources.is_empty() { - let (item, constructor) = - shared_resources_struct::codegen(Context::SoftwareTask(name), &mut needs_lt, app); + let (item, constructor) = shared_resources_struct::codegen( + Context::SoftwareTask(name), + &mut shared_needs_lt, + app, + ); root.push(item); mod_app.push(constructor); } - if !&task.is_extern { let context = &task.context; let attrs = &task.attrs; @@ -133,7 +138,8 @@ pub fn codegen( root.push(module::codegen( Context::SoftwareTask(name), - needs_lt, + shared_needs_lt, + local_needs_lt, app, analysis, extra, |