NAME
XML::XPathScript::Template::Tag - XPathScript Template Element
VERSION
version 2.00
SYNOPSIS
<%
$tag
->set(
'foo'
=> {
testcode
=> \
&frumble
} );
sub
frumble {
my
(
$n
,
$t
) =
@_
;
$t
->set({
'pre'
=>
'<bar>'
});
return
DO_SELF_AND_CHILDREN();
}
%>
<%= apply_templates() %>
DESCRIPTION
The XML::XPathScript::Tag class is used to represent tags within an XPathScript template.
CALLED AS ARGUMENT TO THE TESTCODE FUNCTIONS
Typically, the only time you'll be exposed to those objects is via the testcode functions, which receive as arguments a reference to the current node and its associated template entry.
Note that changing any of the tag's attributes only impacts the current node and doesn't change the tag entry in the template. To modify the template, you'll have to access $template directly.
Example:
<%
$template
->set(
'foo'
=> {
testcode
=> \
&frumble
} );
sub
frumble {
my
(
$n
,
$t
) =
@_
;
if
(
$n
->findvalue(
'./@bar'
) eq
'whonk'
) {
# we've been whonk'ed! This foo must
# blink
$t
->set({
'pre'
=>
'<blink>'
,
'post'
=>
'</blink>'
});
# and the next foos will be in italic
$template
->set(
foo
=> {
pre
=>
'<i>'
,
post
=>
'</i>'
} );
}
return
DO_SELF_AND_CHILDREN();
}
%>
METHODS
new
$tag
= XML::XPathScript::Template::Tag->new
Creates a new, empty tag.
set
$t
->set( \
%attributes
)
Updates the tag's attributes with the values given in \%attributes
Thanks to the magic of overloading, using $t as a function reference acts as a shortcut to set.
Example:
$t
->set({
pre
=>
'<a>'
,
post
=>
'</a>'
});
# or, equivalently,
$t
->({
pre
=>
'<a>'
,
post
=>
'</a>'
});
get
@values
=
$tag
->get(
@attributes
)
Returns the values of @attributes.
Example:
@values
=
$tag
->get(
'pre'
,
'post'
);
BACKWARD COMPATIBILITY
As for XML::XPathScript::Template, prior to release 1.0 of XPathScript, the tags within the template of a stylesheet were not objects but simple hash references. Modifications to the tag attributes were done by manipulating the hash directly.
<%
$t
->{foo}{testcode} =
sub
{
my
(
$n
,
$t
) =
@_
;
$t
->{pre} =
'<a>'
;
$t
->{post} =
'</a>'
;
return
DO_SELF_AND_CHILDREN;
};
%>
Don't tell anyone, but as an XML::XPathScript::Template::Tag is a blessed hash reference this way of doing things will still work. However, direct manipulation of the tag's hash is deprecated. Instead, it is recommended to use the object's access methods.
<%
$template
->set(
foo
=> {
testcode
=> \
&tc_foo
} );
sub
tc_foo {
my
(
$n
,
$t
) =
@_
;
$t
->set({
pre
=>
'<a>'
,
post
=>
'</a>'
});
return
DO_SELF_AND_CHILDREN;
};
%>
AUTHORS
Yanick Champoux <yanick@cpan.org>
Dominique Quatravaux <domq@cpan.org>
Matt Sergeant <matt@sergeant.org>
COPYRIGHT AND LICENSE
This software is copyright (c) 2019, 2018, 2008, 2007 by Matt Sergeant.
This is free software; you can redistribute it and/or modify it under the same terms as the Perl 5 programming language system itself.