aboutsummaryrefslogtreecommitdiffstats
diff options
context:
space:
mode:
authorLibravatar Dirkjan Ochtman <dirkjan@ochtman.nl>2016-12-24 11:17:26 +0100
committerLibravatar Dirkjan Ochtman <dirkjan@ochtman.nl>2016-12-24 11:20:17 +0100
commit55a75dbfa66fb0c37b1cd6907f3e56679ad9ad5e (patch)
tree7b92780b33693dd50cf2d9684d376a93f0d395c0
parentc238e53ffe41ab54142c798ff4dbe5592ec5ed99 (diff)
downloadaskama-55a75dbfa66fb0c37b1cd6907f3e56679ad9ad5e.tar.gz
askama-55a75dbfa66fb0c37b1cd6907f3e56679ad9ad5e.tar.bz2
askama-55a75dbfa66fb0c37b1cd6907f3e56679ad9ad5e.zip
Make code generator impl more extensible
-rw-r--r--askama_codegen/src/generator.rs58
1 files changed, 42 insertions, 16 deletions
diff --git a/askama_codegen/src/generator.rs b/askama_codegen/src/generator.rs
index 971e2e2..13a91dd 100644
--- a/askama_codegen/src/generator.rs
+++ b/askama_codegen/src/generator.rs
@@ -6,34 +6,60 @@ struct Generator {
}
impl Generator {
+
fn new() -> Generator {
Generator { buf: String::new() }
}
+
+ fn init(&mut self, name: &str) {
+ self.write("impl askama::Template for ");
+ self.write(name);
+ self.write(" {\n");
+ self.write(" fn render(&self) -> String {\n");
+ self.write(" let mut buf = String::new();\n");
+ }
+
fn write(&mut self, s: &str) {
self.buf.push_str(s);
}
+
+ fn visit_lit(&mut self, s: &[u8]) {
+ self.write(" buf.push_str(");
+ self.write(&format!("{:#?}", str::from_utf8(s).unwrap()));
+ self.write(");\n");
+ }
+
+ fn visit_expr(&mut self, s: &[u8]) {
+ self.write(" buf.push_str(");
+ self.write(&format!("&self.{}", str::from_utf8(s).unwrap()));
+ self.write(");\n");
+ }
+
+ fn handle(&mut self, tokens: &Vec<Node>) {
+ for n in tokens {
+ match n {
+ &Node::Lit(val) => { self.visit_lit(val); },
+ &Node::Expr(val) => { self.visit_expr(val); },
+ }
+ }
+ }
+
+ fn finalize(&mut self) {
+ self.write(" buf");
+ self.write(" }\n");
+ self.write("}\n\n");
+ }
+
fn result(self) -> String {
self.buf
}
+
}
pub fn generate(ctx_name: &str, tokens: &Vec<Node>) -> String {
let mut gen = Generator::new();
- gen.write("impl askama::Template for ");
- gen.write(ctx_name);
- gen.write(" {\n");
- gen.write(" fn render(&self) -> String {\n");
- gen.write(" let mut buf = String::new();\n");
- for n in tokens {
- gen.write(" buf.push_str(");
- gen.write(&match n {
- &Node::Lit(val) => format!("{:#?}", str::from_utf8(val).unwrap()),
- &Node::Expr(val) => format!("&self.{}", str::from_utf8(val).unwrap()),
- });
- gen.write(");\n");
- }
- gen.write(" buf");
- gen.write(" }\n");
- gen.write("}\n\n");
+ gen.init(ctx_name);
+ gen.handle(tokens);
+ gen.finalize();
gen.result()
}