diff options
Diffstat (limited to 'askama_shared/src/path.rs')
-rw-r--r-- | askama_shared/src/path.rs | 40 |
1 files changed, 3 insertions, 37 deletions
diff --git a/askama_shared/src/path.rs b/askama_shared/src/path.rs index bc329e5..b1a1e6a 100644 --- a/askama_shared/src/path.rs +++ b/askama_shared/src/path.rs @@ -1,10 +1,9 @@ -use std::env; -use std::fs::{self, File}; +use super::Config; + +use std::fs::File; use std::io::Read; use std::path::{Path, PathBuf}; -use toml; - pub fn get_template_source(tpl_path: &Path) -> String { let mut f = match File::open(tpl_path) { Err(_) => panic!("unable to open template file '{}'", tpl_path.to_str().unwrap()), @@ -42,39 +41,6 @@ pub fn template_dirs() -> Vec<PathBuf> { Config::new().dirs } -struct Config { - dirs: Vec<PathBuf>, -} - -impl Config { - fn new() -> Config { - let root = PathBuf::from(env::var("CARGO_MANIFEST_DIR").unwrap()); - let filename = root.join(CONFIG_FILE_NAME); - - let default = vec![root.join("templates")]; - let dirs = if filename.exists() { - let config_str = fs::read_to_string(&filename) - .expect(&format!("unable to read {}", filename.to_str().unwrap())); - let raw: RawConfig = toml::from_str(&config_str) - .expect(&format!("invalid TOML in {}", filename.to_str().unwrap())); - raw.dirs - .map(|dirs| dirs.into_iter().map(|dir| root.join(dir)).collect()) - .unwrap_or_else(|| default) - } else { - default - }; - - Config { dirs } - } -} - -#[derive(Deserialize)] -struct RawConfig { - dirs: Option<Vec<String>>, -} - -static CONFIG_FILE_NAME: &str = "askama.toml"; - #[cfg(test)] mod tests { use super::{find_template_from_path, get_template_source}; |