From 6ff12b877afbda62ad2cb6d748487e7674e5c396 Mon Sep 17 00:00:00 2001 From: Jesse Luehrs Date: Fri, 5 Oct 2012 18:30:32 -0500 Subject: change back to defining helpers and functions separately helpers are different from functions because they implicitly receive the current context as the first argument, so they need to be declared differently. they work identically to functions in all other respects. --- lib/Text/Handlebars.pm | 18 ++++++++++++++++++ lib/Text/Handlebars/Compiler.pm | 2 ++ lib/Text/Xslate/Syntax/Handlebars.pm | 17 +++++++++++++++++ t/block-helpers.t | 26 +++++++++++++------------- t/helpers-examples.t | 4 ++-- t/helpers.t | 6 +++--- 6 files changed, 55 insertions(+), 18 deletions(-) diff --git a/lib/Text/Handlebars.pm b/lib/Text/Handlebars.pm index 25075b1..a040504 100644 --- a/lib/Text/Handlebars.pm +++ b/lib/Text/Handlebars.pm @@ -90,6 +90,7 @@ sub options { my $options = $class->SUPER::options(@_); $options->{compiler} = 'Text::Handlebars::Compiler'; + $options->{helpers} = {}; return $options; } @@ -128,6 +129,23 @@ sub _register_builtin_methods { return $code->($vars, @args, $options); }; + + for my $helper (keys %{ $self->{helpers} }) { + $funcs->{$helper} = $self->{helpers}{$helper}; + } +} + +sub _compiler { + my $self = shift; + + if (!ref($self->{compiler})) { + my $compiler = $self->SUPER::_compiler(@_); + $compiler->define_helper(keys %{ $self->{helpers} }); + return $compiler; + } + else { + return $self->SUPER::_compiler(@_); + } } sub render_string { diff --git a/lib/Text/Handlebars/Compiler.pm b/lib/Text/Handlebars/Compiler.pm index ae1738b..184b9b6 100644 --- a/lib/Text/Handlebars/Compiler.pm +++ b/lib/Text/Handlebars/Compiler.pm @@ -9,6 +9,8 @@ has '+syntax' => ( default => 'Handlebars', ); +sub define_helper { shift->parser->define_helper(@_) } + sub _generate_block { my $self = shift; my ($node) = @_; diff --git a/lib/Text/Xslate/Syntax/Handlebars.pm b/lib/Text/Xslate/Syntax/Handlebars.pm index 252b4c9..a24fa00 100644 --- a/lib/Text/Xslate/Syntax/Handlebars.pm +++ b/lib/Text/Xslate/Syntax/Handlebars.pm @@ -5,6 +5,8 @@ use Any::Moose; use Carp 'confess'; use Text::Xslate::Util qw($DEBUG $NUMBER neat p); +use Text::Handlebars::Symbol; + extends 'Text::Xslate::Parser'; use constant _DUMP_PROTO => scalar($DEBUG =~ /\b dump=proto \b/xmsi); @@ -29,6 +31,8 @@ sub _build_tag_end { '}}' } sub _build_shortcut_table { +{} } +sub symbol_class { 'Text::Handlebars::Symbol' } + sub split_tags { my $self = shift; my ($input) = @_; @@ -584,6 +588,19 @@ sub define_function { return; } +sub define_helper { + my $self = shift; + my (@names) = @_; + + $self->define_function(@names); + for my $name (@names) { + my $symbol = $self->symbol($name); + $symbol->is_helper(1); + } + + return; +} + sub parse_literal { my $self = shift; my ($literal) = @_; diff --git a/t/block-helpers.t b/t/block-helpers.t index 5ca009a..4b68d1e 100644 --- a/t/block-helpers.t +++ b/t/block-helpers.t @@ -7,7 +7,7 @@ use Test::Handlebars; render_ok( { - function => { + helpers => { noop => sub { my ($context, $options) = @_; return $options->{fn}->($context); @@ -36,7 +36,7 @@ RENDERED render_ok( { - function => { + helpers => { with => sub { my ($context, $new_context, $options) = @_; return $options->{fn}->($new_context); @@ -71,7 +71,7 @@ RENDERED render_ok( { - function => { + helpers => { with => sub { my ($context, $new_context, $options) = @_; return $options->{fn}->($new_context); @@ -138,7 +138,7 @@ RENDERED render_ok( { - function => { + helpers => { list => sub { my ($context, $items, $options) = @_; my $out = "