]> git.r.bdr.sh - rbdr/blog/blobdiff - src/generator/html.rs
Improve the error handling
[rbdr/blog] / src / generator / html.rs
index 0b258bf044119b2747672d3f3159416ef8705aa9..ab47b7aca8f35635843a12f0ad1672418775529d 100644 (file)
@@ -1,16 +1,18 @@
-use std::io::Result;
+use std::fs::write;
+use std::io::{Error, ErrorKind::Other, Result};
 use std::path::PathBuf;
-use crate::post::Post;
-use crate::template::{find, parse};
+use crate::template::{find, parse, TemplateContext};
 
-pub fn generate(_: &PathBuf, template_directory: &PathBuf, _: &PathBuf, _: &Vec<Post>) -> Result<()> {
-    println!("READING TEMP");
-    match find(template_directory, "index.html") {
+const FILENAME: &str = "index.html";
+
+pub fn generate(_: &PathBuf, template_directory: &PathBuf, target: &PathBuf, context: &TemplateContext) -> Result<()> {
+    match find(template_directory, FILENAME) {
         Some(template) => {
-            let parsed_template = parse(&template);
-            for token in parsed_template.tokens {
-                println!("TOKEN {}", token);
-            }
+            let parsed_template = parse(&template)
+                .ok_or_else(|| Error::new(Other, "Unable to parse HTML template"))?;
+            let rendered_template = parsed_template.render(context)?;
+            let location = target.join(FILENAME);
+            write(location, rendered_template)?;
         },
         None => {}
     }