From 521c79b58c41d08ca6d4db39b877d069867fb62d Mon Sep 17 00:00:00 2001 From: Gianni Ceccarelli Date: Wed, 18 Mar 2009 16:38:54 +0100 Subject: call by name --- lib/Tree/Transform/Transformer.pm | 51 ++++++++++++++++++++++++++++++++++++++- 1 file changed, 50 insertions(+), 1 deletion(-) (limited to 'lib/Tree/Transform') diff --git a/lib/Tree/Transform/Transformer.pm b/lib/Tree/Transform/Transformer.pm index 685e99e..c188b29 100644 --- a/lib/Tree/Transform/Transformer.pm +++ b/lib/Tree/Transform/Transformer.pm @@ -64,6 +64,23 @@ sub apply_rules { return @ret; } +sub call_rule { + my ($self,$name)=@_; + + unless ($name) { + carp 'call_rule called without a rule name!'; + return; + } + + unless ($self->has_context) { + carp 'call_rule called without context!'; + return; + } + + my $rule=$self->find_rule_by_name($name); + return $rule->{action}->($self); +} + sub find_rule { my ($self,$context)=@_; @@ -76,6 +93,18 @@ sub find_rule { return $ret; } +sub find_rule_by_name { + my ($self,$name,$context)=@_; + + my $ret=$self->find_rule_by_name_in_package($self->rules_package,$name,$context); + + if (!$ret) { + croak "No rule named $name"; + } + + return $ret; +} + sub find_rule_in_package { my ($self,$package,$context)=@_; @@ -99,7 +128,27 @@ sub find_rule_in_package { my @inherited=Tree::Transform::Utils::_get_isa($package); for my $inh_pack (@inherited) { - my $ret=$self->find_rule_in_package($inh_pack); + my $ret=$self->find_rule_in_package($inh_pack,$context); + return $ret if $ret; + } +} + +sub find_rule_by_name_in_package { + my ($self,$package,$name,$context)=@_; + + $context||=$self->context; + + my $store=Tree::Transform::Utils::_rules_store($package); + + my $rules=$store->{by_name}; + + if (exists $rules->{$name}) { + return $rules->{$name}; + } + + my @inherited=Tree::Transform::Utils::_get_isa($package); + for my $inh_pack (@inherited) { + my $ret=$self->find_rule_by_name_in_package($inh_pack,$name,$context); return $ret if $ret; } } -- cgit v1.2.3