diff options
author | Dirkjan Ochtman <dirkjan@ochtman.nl> | 2017-01-03 10:01:16 +0100 |
---|---|---|
committer | Dirkjan Ochtman <dirkjan@ochtman.nl> | 2017-01-03 10:01:16 +0100 |
commit | 4c8c773c84a48963e892c72f38f37bcb99b6eb74 (patch) | |
tree | 7ea8dd95e81bd40c1b24bb9143cbe865005b1ae0 /askama_codegen/src/lib.rs | |
parent | 3e7983d7af8d19393507e50778b818f8dcf24b91 (diff) | |
download | askama-4c8c773c84a48963e892c72f38f37bcb99b6eb74.tar.gz askama-4c8c773c84a48963e892c72f38f37bcb99b6eb74.tar.bz2 askama-4c8c773c84a48963e892c72f38f37bcb99b6eb74.zip |
Rename askama_codegen to askama_derive
This appears to be best practice for crates using macros 1.1.
Diffstat (limited to 'askama_codegen/src/lib.rs')
-rw-r--r-- | askama_codegen/src/lib.rs | 72 |
1 files changed, 0 insertions, 72 deletions
diff --git a/askama_codegen/src/lib.rs b/askama_codegen/src/lib.rs deleted file mode 100644 index d923e19..0000000 --- a/askama_codegen/src/lib.rs +++ /dev/null @@ -1,72 +0,0 @@ -#![feature(proc_macro, proc_macro_lib)] - -#[macro_use] -extern crate nom; -extern crate proc_macro; -#[macro_use] -extern crate quote; -extern crate syn; - -mod generator; -mod parser; - -use proc_macro::TokenStream; -use std::fs::File; -use std::io::Read; -use std::path::{Path, PathBuf}; - -fn get_path_from_attrs(attrs: &Vec<syn::Attribute>) -> String { - for attr in attrs { - if attr.name() == "template" { - match attr.value { - syn::MetaItem::List(_, ref inner) => { - match inner[0] { - syn::NestedMetaItem::MetaItem(ref item) => { - match item { - &syn::MetaItem::NameValue(ref key, ref val) => { - assert_eq!(key.as_ref(), "path"); - match val { - &syn::Lit::Str(ref s, _) => { return s.clone(); }, - _ => panic!("template path must be a string"), - } - }, - _ => panic!("template annotation must contain key/value pair"), - } - }, - _ => panic!("template annotation must contain item"), - } - }, - _ => panic!("template annotation must be of List type"), - } - } - } - panic!("template annotation not found"); -} - -fn get_template_source(tpl_file: &str) -> String { - let root = ::std::env::var("CARGO_MANIFEST_DIR").unwrap(); - let mut path = PathBuf::from(root); - path.push("templates"); - path.push(Path::new(tpl_file)); - let mut f = File::open(path).unwrap(); - let mut s = String::new(); - f.read_to_string(&mut s).unwrap(); - s -} - -#[proc_macro_derive(Template, attributes(template))] -pub fn derive_template(input: TokenStream) -> TokenStream { - let source = input.to_string(); - - let ast = syn::parse_macro_input(&source).unwrap(); - let _ctx = match ast.body { - syn::Body::Struct(ref data) => data, - _ => panic!("#[derive(Template)] can only be used with structs"), - }; - - let name = &ast.ident; - let path = get_path_from_attrs(&ast.attrs); - let src = get_template_source(&path); - let tokens = parser::parse(&src); - generator::generate(name.as_ref(), &tokens).parse().unwrap() -} |