Skip to content
Snippets Groups Projects
Commit e9788ff9 authored by Jorge Aparicio's avatar Jorge Aparicio
Browse files

rename rtfm! to app! and adapt to changes in rtfm-syntax

parent 98596554
Branches
No related tags found
No related merge requests found
use std::collections::HashMap;
use quote::Tokens;
use rtfm_syntax::{Idents, Idle, Init, Statics};
use syn::Ident;
use syntax::check::{self, Idle, Init};
use syntax::{self, Idents, Statics};
use error::*;
use syntax::error::*;
pub struct App {
pub device: Tokens,
......@@ -22,27 +23,28 @@ pub struct Task {
pub resources: Idents,
}
pub fn app(app: ::rtfm_syntax::App) -> Result<App> {
let mut tasks = HashMap::new();
for (k, v) in app.tasks {
let name = k.clone();
tasks.insert(
k,
::check::task(v)
.chain_err(|| format!("checking task `{}`", name))?,
);
}
pub fn app(app: check::App) -> Result<App> {
let app = App {
device: app.device,
idle: app.idle,
init: app.init,
resources: app.resources,
tasks,
tasks: app.tasks
.into_iter()
.map(|(k, v)| {
let name = k.clone();
Ok((
k,
::check::task(v)
.chain_err(|| format!("checking task `{}`", name))?,
))
})
.collect::<Result<_>>()
.chain_err(|| "checking `tasks`")?,
};
::check::resources(&app)?;
::check::resources(&app)
.chain_err(|| "checking `resources`")?;
Ok(app)
}
......@@ -66,7 +68,7 @@ fn resources(app: &App) -> Result<()> {
Ok(())
}
fn task(task: ::rtfm_syntax::Task) -> Result<Task> {
fn task(task: syntax::check::Task) -> Result<Task> {
if let Some(priority) = task.priority {
Ok(Task {
enabled: task.enabled,
......
error_chain!();
......@@ -6,21 +6,20 @@ extern crate error_chain;
extern crate proc_macro;
#[macro_use]
extern crate quote;
extern crate rtfm_syntax;
extern crate rtfm_syntax as syntax;
extern crate syn;
use proc_macro::TokenStream;
use rtfm_syntax::App;
use syntax::App;
use error::*;
use syntax::error::*;
mod analyze;
mod check;
mod error;
mod trans;
#[proc_macro]
pub fn rtfm(ts: TokenStream) -> TokenStream {
pub fn app(ts: TokenStream) -> TokenStream {
match run(ts) {
Err(e) => panic!("{}", error_chain::ChainedError::display(&e)),
Ok(ts) => ts,
......@@ -30,10 +29,9 @@ pub fn rtfm(ts: TokenStream) -> TokenStream {
fn run(ts: TokenStream) -> Result<TokenStream> {
let input = format!("{}", ts);
let app = check::app(App::parse(&input)
.chain_err(|| "parsing the `rtfm!` macro")?).chain_err(
|| "checking the application specification",
)?;
let app = App::parse(&input).chain_err(|| "parsing")?;
let app = syntax::check::app(app).chain_err(|| "checking the AST")?;
let app = check::app(app)?;
let ownerships = analyze::app(&app);
let tokens = trans::app(&app, &ownerships);
......
......@@ -10,7 +10,7 @@ extern crate static_ref;
use core::cell::UnsafeCell;
pub use cortex_m_rtfm_macros::rtfm;
pub use cortex_m_rtfm_macros::app;
pub use cortex_m::asm::{bkpt, wfi};
pub use cortex_m::interrupt::CriticalSection;
pub use cortex_m::interrupt::free as atomic;
......
0% Loading or .
You are about to add 0 people to the discussion. Proceed with caution.
Please register or to comment