fixes #1
This commit is contained in:
parent
4a70eb6c05
commit
d814efcf93
|
@ -64,7 +64,8 @@ impl Context {
|
||||||
|
|
||||||
let path = file_path.strip_root(path).map_err(anyhow::Error::from)?;
|
let path = file_path.strip_root(path).map_err(anyhow::Error::from)?;
|
||||||
|
|
||||||
context.insert(&path, &tera::to_value(toml).map_err(anyhow::Error::from)?);
|
let value = tera::to_value(&toml).map_err(anyhow::Error::from)?;
|
||||||
|
context.insert(&path, &value);
|
||||||
}
|
}
|
||||||
|
|
||||||
Ok(context)
|
Ok(context)
|
||||||
|
@ -127,8 +128,11 @@ impl Context {
|
||||||
pub fn insert<P: AsRef<Path>>(&mut self, path: &P, value: &Value) {
|
pub fn insert<P: AsRef<Path>>(&mut self, path: &P, value: &Value) {
|
||||||
let path = Self::as_key(path).map(|p| p.with_extension(""));
|
let path = Self::as_key(path).map(|p| p.with_extension(""));
|
||||||
|
|
||||||
if let Some(v) = Self::create_path(&path.unwrap(), value) {
|
let path = Self::create_path(&path.unwrap(), value).or(Some(value.clone()));
|
||||||
if let Ok(ctx) = tera::Context::from_value(v) {
|
|
||||||
|
if let Some(v) = path {
|
||||||
|
let value = tera::Context::from_value(v);
|
||||||
|
if let Ok(ctx) = value {
|
||||||
self.merge(ctx);
|
self.merge(ctx);
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
Loading…
Reference in a new issue