neutralts/bif/
parse_bif_snippet.rs#![doc = include_str!("../../doc/bif-snippet.md")]
use crate::{bif::constants::*, bif::Bif, bif::BifError, constants::*, json, utils::*};
use std::collections::HashSet;
impl<'a> Bif<'a> {
pub(crate) fn parse_bif_snippet(&mut self) -> Result<(), BifError> {
if self.mod_filter || self.mod_negate || self.mod_scope {
return Err(self.bif_error(BIF_ERROR_MODIFIER_NOT_ALLOWED));
}
self.alias = "snippet".to_string();
let is_set = self.extract_params_code(true);
if !self.flags.is_empty() {
let flags_allowed: HashSet<&str> = ["static"].into_iter().collect();
for f in self.flags.split('|').filter(|s| !s.is_empty()) {
if !flags_allowed.contains(f) {
return Err(self.bif_error(&format!("{} flag not allowed", f)));
}
}
}
if is_set {
if self.inherit.current_file.contains(SNIPPETS_FILES) || self.inherit.alias == "snippet"
{
if self.flags.contains("|static|") {
self.code = new_child_parse!(self, &self.code, self.mod_scope);
} else {
self.inherit.create_block_schema(self.shared);
}
self.shared.schema["__indir"][&self.inherit.indir]["snippets"][&self.params] =
json!(&self.code);
self.shared.schema["__indir"][&self.inherit.indir]["snippets_set_dir"]
[&self.params] = json!(&self.inherit.current_dir);
self.out = EMPTY_STRING;
Ok(())
} else {
return Err(self.bif_error("snippet cannot be set here"));
}
} else {
if self.code.contains(BIF_OPEN) {
self.code = new_child_parse!(self, &self.code, false);
}
let snip_name = self.code.clone();
self.code = get_from_key(
&self.shared.schema["__indir"][&self.inherit.indir]["snippets"],
&self.code,
);
if self.code.contains(BIF_OPEN) {
let set_dir = get_from_key(
&self.shared.schema["__indir"][&self.inherit.indir]["snippets_set_dir"],
&snip_name,
);
if !set_dir.is_empty() {
self.inherit.current_dir = set_dir;
}
self.code = new_child_parse!(self, &self.code, self.code.contains("{:snip"));
}
self.out = self.code.to_string();
Ok(())
}
}
}
#[cfg(test)]
#[path = "parse_bif_snippet_tests.rs"]
mod tests;