aboutsummaryrefslogtreecommitdiff
path: root/macros/src/codegen/spawn.rs
blob: da2815160bbcee53d975d38c41b98a53b5582858 (plain) (blame)
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
98
99
100
101
102
103
104
105
106
107
108
109
110
111
112
113
114
115
116
117
118
119
120
121
use std::collections::HashSet;

use proc_macro2::TokenStream as TokenStream2;
use quote::quote;
use rtic_syntax::ast::App;

use crate::{
    analyze::Analysis,
    check::Extra,
    codegen::{spawn_body, util},
};

/// Generates all `${ctxt}::Spawn` methods
pub fn codegen(app: &App, analysis: &Analysis, extra: &Extra) -> Vec<TokenStream2> {
    let mut items = vec![];

    let mut seen = HashSet::<_>::new();
    for (spawner, spawnees) in app.spawn_callers() {
        let mut methods = vec![];

        for name in spawnees {
            let spawnee = &app.software_tasks[name];
            let cfgs = &spawnee.cfgs;
            let (args, _, untupled, ty) = util::regroup_inputs(&spawnee.inputs);
            let args = &args;

            if spawner.is_init() {
                // `init` uses a special spawn implementation; it doesn't use the `spawn_${name}`
                // functions which are shared by other contexts

                let body = spawn_body::codegen(spawner, &name, app, analysis, extra);

                let let_instant = if app.uses_schedule() {
                    let m = extra.monotonic();

                    Some(quote!(let instant = unsafe { <#m as rtic::Monotonic>::zero() };))
                } else {
                    None
                };

                methods.push(quote!(
                    #(#cfgs)*
                    pub fn #name(&self #(,#args)*) -> Result<(), #ty> {
                        #let_instant
                        #body
                    }
                ));
            } else {
                let spawn = util::spawn_ident(name);

                if !seen.contains(name) {
                    // Generate a `spawn_${name}_S${sender}` function
                    seen.insert(name);

                    let instant = if app.uses_schedule() {
                        let m = extra.monotonic();

                        Some(quote!(, instant: <#m as rtic::Monotonic>::Instant))
                    } else {
                        None
                    };

                    let body = spawn_body::codegen(spawner, &name, app, analysis, extra);

                    items.push(quote!(
                        #(#cfgs)*
                        unsafe fn #spawn(
                            priority: &rtic::export::Priority
                            #instant
                            #(,#args)*
                        ) -> Result<(), #ty> {
                            #body
                        }
                    ));
                }

                let (let_instant, instant) = if app.uses_schedule() {
                    let m = extra.monotonic();

                    (
                        Some(if spawner.is_idle() {
                            quote!(let instant = <#m as rtic::Monotonic>::now();)
                        } else {
                            quote!(let instant = self.instant();)
                        }),
                        Some(quote!(, instant)),
                    )
                } else {
                    (None, None)
                };

                methods.push(quote!(
                    #(#cfgs)*
                    #[inline(always)]
                    pub fn #name(&self #(,#args)*) -> Result<(), #ty> {
                        unsafe {
                            #let_instant
                            #spawn(self.priority() #instant #(,#untupled)*)
                        }
                    }
                ));
            }
        }

        let lt = if spawner.is_init() {
            None
        } else {
            Some(quote!('a))
        };

        let spawner = spawner.ident(app);
        debug_assert!(!methods.is_empty());
        items.push(quote!(
            impl<#lt> #spawner::Spawn<#lt> {
                #(#methods)*
            }
        ));
    }

    items
}
red/add-git&id=92e489760d8a6e303d929f881d293c2e7fa6abff&follow=1'>Linux build fixesGravatar Jarred SUmner 11-1377/+154 2021-10-15Update MakefileGravatar Jarred Sumner 1-1/+2 2021-10-15Cleanup makefile to get libiconv setup for linuxGravatar Jarred Sumner 4-2416/+9 2021-10-15Update MakefileGravatar Jarred Sumner 1-5/+5 2021-10-15Update MakefileGravatar Jarred Sumner 1-1/+1 2021-10-15update makefilejarred/genGravatar Jarred Sumner 3-16/+23 2021-10-15PolishGravatar Jarred Sumner 13-208/+2907 2021-10-14:sparkle:Gravatar Jarred Sumner 11-18245/+296 2021-10-14Update README.mdGravatar Jarred Sumner 1-2/+2 2021-10-14Update README.mdGravatar Jarred Sumner 1-2/+9 2021-10-14Update README.mdGravatar Jarred Sumner 1-9/+8 2021-10-14Update README.mdGravatar Jarred Sumner 1-0/+3 2021-10-14Update README.mdGravatar Jarred Sumner 1-1/+2 2021-10-14Update README.mdGravatar Jarred Sumner 1-107/+107 2021-10-14Support local templatesGravatar Jarred Sumner 8-145/+558 2021-10-14Update router.zigGravatar Jarred Sumner 1-0/+212 2021-10-14Support passing an absolute pathGravatar Jarred Sumner 4-171/+313 2021-10-14Update bun-create.mdGravatar Jarred Sumner 1-2/+6 2021-10-14Update bun-create.mdGravatar Jarred Sumner 1-1/+1 2021-10-14Add doc explaining bun-createGravatar Jarred Sumner 3-3/+60 2021-10-14`bun create react app` is almost doneGravatar Jarred Sumner 27-57/+1561 2021-10-13v0.0.0v0.0.0Gravatar Jarred Sumner 1-1/+2 2021-10-13[fetch] Slight perf improvementGravatar Jarred Sumner 1-0/+4 2021-10-13`--turbo` mode for fetch cli, which disables sending TLS shutdownGravatar Jarred Sumner 2-2/+5 2021-10-13[fetch] Support Transfer-Encoding: chunkedGravatar Jarred Sumner 5-39/+135 2021-10-13Update build.zigGravatar Jarred Sumner 1-2/+3 2021-10-13Clean up examples a littleGravatar Jarred Sumner 42-102/+7 2021-10-13Add TLS 1.3 support, improve fetch() HTTPS performanceGravatar Jarred Sumner 16-287/+751