diff options
| author | bors[bot] <26634292+bors[bot]@users.noreply.github.com> | 2021-09-25 17:09:54 +0000 |
|---|---|---|
| committer | GitHub <noreply@github.com> | 2021-09-25 17:09:54 +0000 |
| commit | f0c319982524988fa67cac3c59a4a4a863c409c9 (patch) | |
| tree | de4cbe4b43d399d4dcf2021c33225ccd00627434 /examples/declared_locals.rs | |
| parent | c8621d78b9b1c0c67dff31404ade873a9d7b426e (diff) | |
| parent | b71df58f2fb4ed85d4c8cf806d5837ce63c73f31 (diff) | |
Merge #528
528: The great 0.6 docs update r=AfoHT a=korken89
Closes #530
Closes #527
Closes #487
Closes #461
Closes #448
Closes #440
Closes #422
Co-authored-by: Emil Fresk <emil.fresk@gmail.com>
Diffstat (limited to 'examples/declared_locals.rs')
| -rw-r--r-- | examples/declared_locals.rs | 46 |
1 files changed, 46 insertions, 0 deletions
diff --git a/examples/declared_locals.rs b/examples/declared_locals.rs new file mode 100644 index 0000000..52d354b --- /dev/null +++ b/examples/declared_locals.rs @@ -0,0 +1,46 @@ +//! examples/declared_locals.rs + +#![deny(unsafe_code)] +#![deny(warnings)] +#![no_main] +#![no_std] + +use panic_semihosting as _; + +#[rtic::app(device = lm3s6965, dispatchers = [UART0])] +mod app { + use cortex_m_semihosting::debug; + + #[shared] + struct Shared {} + + #[local] + struct Local {} + + #[init(local = [a: u32 = 0])] + fn init(cx: init::Context) -> (Shared, Local, init::Monotonics) { + // Locals in `#[init]` have 'static lifetime + let _a: &'static mut u32 = cx.local.a; + + debug::exit(debug::EXIT_SUCCESS); // Exit QEMU simulator + + (Shared {}, Local {}, init::Monotonics()) + } + + #[idle(local = [a: u32 = 0])] + fn idle(cx: idle::Context) -> ! { + // Locals in `#[idle]` have 'static lifetime + let _a: &'static mut u32 = cx.local.a; + + loop {} + } + + #[task(local = [a: u32 = 0])] + fn foo(cx: foo::Context) { + // Locals in `#[task]`s have a local lifetime + let _a: &mut u32 = cx.local.a; + + // error: explicit lifetime required in the type of `cx` + // let _a: &'static mut u32 = cx.local.a; + } +} |
