Bug 14106: (RM followup) sick of failing tests in Jessie
[koha.git] / C4 / TmplToken.pm
blob05648cea5522e24a8746299a20fe3ee771389300
1 package C4::TmplToken;
3 # Copyright Tamil 2011
5 # This file is part of Koha.
7 # Koha is free software; you can redistribute it and/or modify it
8 # under the terms of the GNU General Public License as published by
9 # the Free Software Foundation; either version 3 of the License, or
10 # (at your option) any later version.
12 # Koha is distributed in the hope that it will be useful, but
13 # WITHOUT ANY WARRANTY; without even the implied warranty of
14 # MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
15 # GNU General Public License for more details.
17 # You should have received a copy of the GNU General Public License
18 # along with Koha; if not, see <http://www.gnu.org/licenses>.
21 use strict;
22 use warnings;
23 use C4::TmplTokenType;
25 =head1 NAME
27 TmplToken.pm - Object representing a scanner token for .tmpl files
29 =head1 DESCRIPTION
31 This is a class representing a token scanned from an HTML::Template .tmpl file.
33 =cut
35 our $VERSION = 3.07.00.049;
38 sub new {
39 my $this = shift;
40 my $class = ref($this) || $this;
41 my $self = {};
42 bless $self, $class;
43 ($self->{'_string'}, $self->{'_type'}, $self->{'_lc'}, $self->{'_path'}) = @_;
44 return $self;
47 sub string {
48 my $this = shift;
49 return $this->{'_string'}
52 sub type {
53 my $this = shift;
54 return $this->{'_type'}
57 sub pathname {
58 my $this = shift;
59 return $this->{'_path'}
62 sub line_number {
63 my $this = shift;
64 return $this->{'_lc'}
67 sub attributes {
68 my $this = shift;
69 return $this->{'_attr'};
72 sub set_attributes {
73 my $this = shift;
74 $this->{'_attr'} = ref $_[0] eq 'HASH'? $_[0]: \@_;
75 return $this;
78 # only meaningful for TEXT_PARAMETRIZED tokens
79 sub children {
80 my $this = shift;
81 return $this->{'_kids'};
84 # only meaningful for TEXT_PARAMETRIZED tokens
85 sub set_children {
86 my $this = shift;
87 $this->{'_kids'} = ref $_[0] eq 'ARRAY'? $_[0]: \@_;
88 return $this;
91 # only meaningful for TEXT_PARAMETRIZED tokens
92 # FIXME: DIRECTIVE is not necessarily TMPL_VAR !!
93 sub parameters_and_fields {
94 my $this = shift;
95 return map { $_->type == C4::TmplTokenType::DIRECTIVE? $_:
96 ($_->type == C4::TmplTokenType::TAG
97 && $_->string =~ /^<input\b/is)? $_: ()}
98 @{$this->{'_kids'}};
101 # only meaningful for TEXT_PARAMETRIZED tokens
102 sub anchors {
103 my $this = shift;
104 return map { $_->type == C4::TmplTokenType::TAG && $_->string =~ /^<a\b/is? $_: ()} @{$this->{'_kids'}};
107 # only meaningful for TEXT_PARAMETRIZED tokens
108 sub form {
109 my $this = shift;
110 return $this->{'_form'};
113 # only meaningful for TEXT_PARAMETRIZED tokens
114 sub set_form {
115 my $this = shift;
116 $this->{'_form'} = $_[0];
117 return $this;
120 sub has_js_data {
121 my $this = shift;
122 return defined $this->{'_js_data'} && ref($this->{'_js_data'}) eq 'ARRAY';
125 sub js_data {
126 my $this = shift;
127 return $this->{'_js_data'};
130 sub set_js_data {
131 my $this = shift;
132 $this->{'_js_data'} = $_[0];
133 return $this;
136 # predefined tests
138 sub tag_p {
139 my $this = shift;
140 return $this->type == C4::TmplTokenType::TAG;
143 sub cdata_p {
144 my $this = shift;
145 return $this->type == C4::TmplTokenType::CDATA;
148 sub text_p {
149 my $this = shift;
150 return $this->type == C4::TmplTokenType::TEXT;
153 sub text_parametrized_p {
154 my $this = shift;
155 return $this->type == C4::TmplTokenType::TEXT_PARAMETRIZED;
158 sub directive_p {
159 my $this = shift;
160 return $this->type == C4::TmplTokenType::DIRECTIVE;
163 ###############################################################################