aboutsummaryrefslogtreecommitdiff
path: root/macros/src/syntax/parse/hardware_task.rs
diff options
context:
space:
mode:
authorGravatar Emil Fresk <emil.fresk@gmail.com> 2023-01-23 20:05:47 +0100
committerGravatar Henrik Tjäder <henrik@tjaders.com> 2023-03-01 00:33:31 +0100
commit306aa47170fd59369b7a184924e287dc3706d64d (patch)
tree75a331a63a4021f078e330bf2ce4edb1228e2ecf /macros/src/syntax/parse/hardware_task.rs
parentb8b881f446a226d6f3c4a7db7c9174590b47dbf6 (diff)
downloadrtic-306aa47170fd59369b7a184924e287dc3706d64d.tar.gz
rtic-306aa47170fd59369b7a184924e287dc3706d64d.tar.zst
rtic-306aa47170fd59369b7a184924e287dc3706d64d.zip
Add rtic-timer (timerqueue + monotonic) and rtic-monotonics (systick-monotonic)
Diffstat (limited to 'macros/src/syntax/parse/hardware_task.rs')
-rw-r--r--macros/src/syntax/parse/hardware_task.rs76
1 files changed, 0 insertions, 76 deletions
diff --git a/macros/src/syntax/parse/hardware_task.rs b/macros/src/syntax/parse/hardware_task.rs
deleted file mode 100644
index 7f6dfbe4..00000000
--- a/macros/src/syntax/parse/hardware_task.rs
+++ /dev/null
@@ -1,76 +0,0 @@
-use syn::{parse, ForeignItemFn, ItemFn, Stmt};
-
-use crate::syntax::parse::util::FilterAttrs;
-use crate::syntax::{
- ast::{HardwareTask, HardwareTaskArgs},
- parse::util,
-};
-
-impl HardwareTask {
- pub(crate) fn parse(args: HardwareTaskArgs, item: ItemFn) -> parse::Result<Self> {
- let span = item.sig.ident.span();
- let valid_signature = util::check_fn_signature(&item, false)
- && item.sig.inputs.len() == 1
- && util::type_is_unit(&item.sig.output);
-
- let name = item.sig.ident.to_string();
-
- if valid_signature {
- if let Some((context, Ok(rest))) = util::parse_inputs(item.sig.inputs, &name) {
- if rest.is_empty() {
- let FilterAttrs { cfgs, attrs, .. } = util::filter_attributes(item.attrs);
-
- return Ok(HardwareTask {
- args,
- cfgs,
- attrs,
- context,
- stmts: item.block.stmts,
- is_extern: false,
- });
- }
- }
- }
-
- Err(parse::Error::new(
- span,
- format!("this task handler must have type signature `fn({name}::Context)`"),
- ))
- }
-}
-
-impl HardwareTask {
- pub(crate) fn parse_foreign(
- args: HardwareTaskArgs,
- item: ForeignItemFn,
- ) -> parse::Result<Self> {
- let span = item.sig.ident.span();
- let valid_signature = util::check_foreign_fn_signature(&item, false)
- && item.sig.inputs.len() == 1
- && util::type_is_unit(&item.sig.output);
-
- let name = item.sig.ident.to_string();
-
- if valid_signature {
- if let Some((context, Ok(rest))) = util::parse_inputs(item.sig.inputs, &name) {
- if rest.is_empty() {
- let FilterAttrs { cfgs, attrs, .. } = util::filter_attributes(item.attrs);
-
- return Ok(HardwareTask {
- args,
- cfgs,
- attrs,
- context,
- stmts: Vec::<Stmt>::new(),
- is_extern: true,
- });
- }
- }
- }
-
- Err(parse::Error::new(
- span,
- format!("this task handler must have type signature `fn({name}::Context)`"),
- ))
- }
-}