aboutsummaryrefslogtreecommitdiffstats
path: root/askama_codegen/src/lib.rs
diff options
context:
space:
mode:
authorLibravatar Dirkjan Ochtman <dirkjan@ochtman.nl>2017-01-03 10:01:16 +0100
committerLibravatar Dirkjan Ochtman <dirkjan@ochtman.nl>2017-01-03 10:01:16 +0100
commit4c8c773c84a48963e892c72f38f37bcb99b6eb74 (patch)
tree7ea8dd95e81bd40c1b24bb9143cbe865005b1ae0 /askama_codegen/src/lib.rs
parent3e7983d7af8d19393507e50778b818f8dcf24b91 (diff)
downloadaskama-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.rs72
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()
-}