1 2 3 4 5 6 7 8 9 10 11 12 13 14 15 16 17 18 19 20 21 22 23 24 25 26 27 28 29 30 31 32 33 34 35 36 37 38 39 40 41 42 43 44 45 46 47 48 49 50 51 52 53 54 55 56 57 58 59 60 61 62 63
use context::Context; use directives::{DirectiveDef, DirectiveResult}; use error::RenderError; use registry::Registry; use render::{Directive, RenderContext}; #[derive(Clone, Copy)] pub struct InlineDirective; fn get_name<'reg: 'rc, 'rc>(d: &'rc Directive<'reg, 'rc>) -> Result<&'rc str, RenderError> { d.param(0) .ok_or_else(|| RenderError::new("Param required for directive \"inline\"")) .and_then(|v| { v.value() .as_str() .ok_or_else(|| RenderError::new("inline name must be string")) }) } impl DirectiveDef for InlineDirective { fn call<'reg: 'rc, 'rc>( &self, d: &Directive<'reg, 'rc>, _: &'reg Registry, _: &'rc Context, rc: &mut RenderContext<'reg>, ) -> DirectiveResult { let name = get_name(d)?; let template = d .template() .ok_or_else(|| RenderError::new("inline should have a block"))?; rc.set_partial(name.to_owned(), template); Ok(()) } } pub static INLINE_DIRECTIVE: InlineDirective = InlineDirective; #[cfg(test)] mod test { use context::Context; use registry::Registry; use render::{Evaluable, RenderContext}; use template::Template; #[test] fn test_inline() { let t0 = Template::compile( "{{#*inline \"hello\"}}the hello world inline partial.{{/inline}}".to_string(), ).ok() .unwrap(); let hbs = Registry::new(); let ctx = Context::null(); let mut rc = RenderContext::new(None); t0.elements[0].eval(&hbs, &ctx, &mut rc).unwrap(); assert!(rc.get_partial(&"hello".to_owned()).is_some()); } }