From 1a2822c8b182b19d70fd116a3a0bcf038caa6aef Mon Sep 17 00:00:00 2001 From: Gianni Ceccarelli Date: Wed, 25 Mar 2009 16:48:14 +0100 Subject: now you can specify the engine in the transfor class --- lib/Tree/Transform/XSLTish.pm | 29 +++++++++++++++++++++++++---- lib/Tree/Transform/XSLTish/Transformer.pm | 15 ++++++++++++++- lib/Tree/Transform/XSLTish/Utils.pm | 12 ++++++++++++ 3 files changed, 51 insertions(+), 5 deletions(-) (limited to 'lib') diff --git a/lib/Tree/Transform/XSLTish.pm b/lib/Tree/Transform/XSLTish.pm index 3889b3a..97a6f1f 100644 --- a/lib/Tree/Transform/XSLTish.pm +++ b/lib/Tree/Transform/XSLTish.pm @@ -9,12 +9,15 @@ use Carp::Clan qw(^Tree::Transform::XSLTish); our $VERSION='0.1'; +my @DEFAULT_EXPORTS=('tree_rule', + 'default_rules', + 'new_transformer' => {-as => 'new'}); + Sub::Exporter::setup_exporter({ - exports => [qw(tree_rule default_rules new_transformer)], + exports => [qw(tree_rule default_rules new_transformer engine_class engine_factory)], groups => { - default => [ 'tree_rule', - 'default_rules', - 'new_transformer' => {-as => 'new'} ], + default => \@DEFAULT_EXPORTS, + engine => [@DEFAULT_EXPORTS, qw(engine_class engine_factory)], } }); @@ -55,6 +58,24 @@ sub tree_rule { return; } +sub engine_class { + my ($classname)=@_; + + my $factory=Tree::Transform::XSLTish::Utils::_engine_factory(scalar caller); + $$factory=sub{$classname->new()}; + + return; +} + +sub engine_factory { + my ($new_factory)=@_; + + my $factory=Tree::Transform::XSLTish::Utils::_engine_factory(scalar caller); + $$factory=$new_factory; + + return; +} + sub _transformer_class { 'Tree::Transform::XSLTish::Transformer' }; sub new_transformer { diff --git a/lib/Tree/Transform/XSLTish/Transformer.pm b/lib/Tree/Transform/XSLTish/Transformer.pm index c6102a7..fd61ea6 100644 --- a/lib/Tree/Transform/XSLTish/Transformer.pm +++ b/lib/Tree/Transform/XSLTish/Transformer.pm @@ -36,9 +36,22 @@ has 'context_stack' => ( has 'engine' => ( is => 'ro', isa => 'Tree::Transform::XSLTish::Engine', - default => sub { Tree::XPathEngine->new() }, + lazy => 1, + builder => '_build_engine', ); +sub _build_engine { + my ($self)=@_; + + if ($self->rules_package) { + my $factory=Tree::Transform::XSLTish::Utils::_engine_factory($self->rules_package); + if ($$factory) { + return $$factory->(); + } + } + return Tree::XPathEngine->new(); +} + sub it { $_[0]->context->current_node } sub transform { diff --git a/lib/Tree/Transform/XSLTish/Utils.pm b/lib/Tree/Transform/XSLTish/Utils.pm index 11a25cb..bed1167 100644 --- a/lib/Tree/Transform/XSLTish/Utils.pm +++ b/lib/Tree/Transform/XSLTish/Utils.pm @@ -14,6 +14,18 @@ sub _rules_store { return $pack->get_package_symbol($RULES_NAME); } +my $ENGINE_FACTORY_NAME='$_tree_transform_engine_factory'; + +sub _engine_factory { + my $pack=Class::MOP::Class->initialize($_[0]); + + if (! $pack->has_package_symbol($ENGINE_FACTORY_NAME) ) { + $pack->add_package_symbol($ENGINE_FACTORY_NAME,undef); + } + return $pack->get_package_symbol($ENGINE_FACTORY_NAME); +} + + sub _get_inheritance { return Class::MOP::Class->initialize($_[0])->class_precedence_list; } -- cgit v1.2.3