Filename | /usr/lib/perl5/Template/Filters.pm |
Statements | Executed 4050 statements in 11.4ms |
Calls | P | F | Exclusive Time |
Inclusive Time |
Subroutine |
---|---|---|---|---|---|
183 | 10 | 4 | 2.71ms | 3.42ms | html_filter | Template::Filters::
214 | 1 | 1 | 2.35ms | 2.37ms | fetch | Template::Filters::
763 | 7 | 1 | 809µs | 809µs | CORE:subst (opcode) | Template::Filters::
27 | 2 | 2 | 484µs | 621µs | url_filter | Template::Filters::
1 | 1 | 1 | 408µs | 423µs | uri_filter | Template::Filters::
1 | 1 | 1 | 201µs | 205µs | BEGIN@24 | Template::Filters::
3 | 3 | 1 | 39µs | 65µs | __ANON__[:506] | Template::Filters::
3 | 1 | 1 | 23µs | 23µs | CORE:regcomp (opcode) | Template::Filters::
3 | 1 | 1 | 20µs | 20µs | replace_filter_factory | Template::Filters::
1 | 1 | 1 | 19µs | 24µs | BEGIN@22 | Template::Filters::
1 | 1 | 1 | 17µs | 43µs | BEGIN@23 | Template::Filters::
1 | 1 | 1 | 16µs | 16µs | _init | Template::Filters::
1 | 1 | 1 | 15µs | 47µs | BEGIN@26 | Template::Filters::
1 | 1 | 1 | 12µs | 56µs | BEGIN@27 | Template::Filters::
1 | 1 | 1 | 11µs | 71µs | BEGIN@25 | Template::Filters::
4 | 1 | 1 | 6µs | 6µs | CORE:substcont (opcode) | Template::Filters::
0 | 0 | 0 | 0s | 0s | __ANON__[:450] | Template::Filters::
0 | 0 | 0 | 0s | 0s | __ANON__[:468] | Template::Filters::
0 | 0 | 0 | 0s | 0s | __ANON__[:486] | Template::Filters::
0 | 0 | 0 | 0s | 0s | __ANON__[:524] | Template::Filters::
0 | 0 | 0 | 0s | 0s | __ANON__[:552] | Template::Filters::
0 | 0 | 0 | 0s | 0s | __ANON__[:55] | Template::Filters::
0 | 0 | 0 | 0s | 0s | __ANON__[:568] | Template::Filters::
0 | 0 | 0 | 0s | 0s | __ANON__[:56] | Template::Filters::
0 | 0 | 0 | 0s | 0s | __ANON__[:57] | Template::Filters::
0 | 0 | 0 | 0s | 0s | __ANON__[:58] | Template::Filters::
0 | 0 | 0 | 0s | 0s | __ANON__[:597] | Template::Filters::
0 | 0 | 0 | 0s | 0s | __ANON__[:59] | Template::Filters::
0 | 0 | 0 | 0s | 0s | __ANON__[:60] | Template::Filters::
0 | 0 | 0 | 0s | 0s | __ANON__[:61] | Template::Filters::
0 | 0 | 0 | 0s | 0s | __ANON__[:629] | Template::Filters::
0 | 0 | 0 | 0s | 0s | __ANON__[:63] | Template::Filters::
0 | 0 | 0 | 0s | 0s | __ANON__[:649] | Template::Filters::
0 | 0 | 0 | 0s | 0s | _dump | Template::Filters::
0 | 0 | 0 | 0s | 0s | eval_filter_factory | Template::Filters::
0 | 0 | 0 | 0s | 0s | format_filter_factory | Template::Filters::
0 | 0 | 0 | 0s | 0s | html_entity_filter_factory | Template::Filters::
0 | 0 | 0 | 0s | 0s | html_line_break | Template::Filters::
0 | 0 | 0 | 0s | 0s | html_para_break | Template::Filters::
0 | 0 | 0 | 0s | 0s | html_paragraph | Template::Filters::
0 | 0 | 0 | 0s | 0s | indent_filter_factory | Template::Filters::
0 | 0 | 0 | 0s | 0s | perl_filter_factory | Template::Filters::
0 | 0 | 0 | 0s | 0s | redirect_filter_factory | Template::Filters::
0 | 0 | 0 | 0s | 0s | remove_filter_factory | Template::Filters::
0 | 0 | 0 | 0s | 0s | repeat_filter_factory | Template::Filters::
0 | 0 | 0 | 0s | 0s | stdout_filter_factory | Template::Filters::
0 | 0 | 0 | 0s | 0s | store | Template::Filters::
0 | 0 | 0 | 0s | 0s | truncate_filter_factory | Template::Filters::
0 | 0 | 0 | 0s | 0s | use_apache_util | Template::Filters::
0 | 0 | 0 | 0s | 0s | use_html_entities | Template::Filters::
0 | 0 | 0 | 0s | 0s | xml_filter | Template::Filters::
Line | State ments |
Time on line |
Calls | Time in subs |
Code |
---|---|---|---|---|---|
1 | #============================================================= -*-Perl-*- | ||||
2 | # | ||||
3 | # Template::Filters | ||||
4 | # | ||||
5 | # DESCRIPTION | ||||
6 | # Defines filter plugins as used by the FILTER directive. | ||||
7 | # | ||||
8 | # AUTHORS | ||||
9 | # Andy Wardley <abw@wardley.org>, with a number of filters contributed | ||||
10 | # by Leslie Michael Orchard <deus_x@nijacode.com> | ||||
11 | # | ||||
12 | # COPYRIGHT | ||||
13 | # Copyright (C) 1996-2007 Andy Wardley. All Rights Reserved. | ||||
14 | # | ||||
15 | # This module is free software; you can redistribute it and/or | ||||
16 | # modify it under the same terms as Perl itself. | ||||
17 | # | ||||
18 | #============================================================================ | ||||
19 | |||||
20 | package Template::Filters; | ||||
21 | |||||
22 | 3 | 31µs | 2 | 29µs | # spent 24µs (19+5) within Template::Filters::BEGIN@22 which was called:
# once (19µs+5µs) by Template::Config::load at line 22 # spent 24µs making 1 call to Template::Filters::BEGIN@22
# spent 5µs making 1 call to strict::import |
23 | 3 | 41µs | 2 | 69µs | # spent 43µs (17+26) within Template::Filters::BEGIN@23 which was called:
# once (17µs+26µs) by Template::Config::load at line 23 # spent 43µs making 1 call to Template::Filters::BEGIN@23
# spent 26µs making 1 call to warnings::import |
24 | 3 | 216µs | 2 | 209µs | # spent 205µs (201+4) within Template::Filters::BEGIN@24 which was called:
# once (201µs+4µs) by Template::Config::load at line 24 # spent 205µs making 1 call to Template::Filters::BEGIN@24
# spent 4µs making 1 call to locale::import |
25 | 3 | 32µs | 2 | 132µs | # spent 71µs (11+61) within Template::Filters::BEGIN@25 which was called:
# once (11µs+61µs) by Template::Config::load at line 25 # spent 71µs making 1 call to Template::Filters::BEGIN@25
# spent 61µs making 1 call to base::import |
26 | 3 | 36µs | 2 | 79µs | # spent 47µs (15+32) within Template::Filters::BEGIN@26 which was called:
# once (15µs+32µs) by Template::Config::load at line 26 # spent 47µs making 1 call to Template::Filters::BEGIN@26
# spent 32µs making 1 call to Exporter::import |
27 | 3 | 3.31ms | 2 | 101µs | # spent 56µs (12+44) within Template::Filters::BEGIN@27 which was called:
# once (12µs+44µs) by Template::Config::load at line 27 # spent 56µs making 1 call to Template::Filters::BEGIN@27
# spent 44µs making 1 call to Exporter::import |
28 | |||||
29 | 1 | 800ns | our $VERSION = 2.87; | ||
30 | 1 | 1µs | our $AVAILABLE = { }; | ||
31 | 1 | 300ns | our $TRUNCATE_LENGTH = 32; | ||
32 | 1 | 700ns | our $TRUNCATE_ADDON = '...'; | ||
33 | |||||
34 | |||||
35 | #------------------------------------------------------------------------ | ||||
36 | # standard filters, defined in one of the following forms: | ||||
37 | # name => \&static_filter | ||||
38 | # name => [ \&subref, $is_dynamic ] | ||||
39 | # If the $is_dynamic flag is set then the sub-routine reference | ||||
40 | # is called to create a new filter each time it is requested; if | ||||
41 | # not set, then it is a single, static sub-routine which is returned | ||||
42 | # for every filter request for that name. | ||||
43 | #------------------------------------------------------------------------ | ||||
44 | |||||
45 | our $FILTERS = { | ||||
46 | # static filters | ||||
47 | 'html' => \&html_filter, | ||||
48 | 'html_para' => \&html_paragraph, | ||||
49 | 'html_break' => \&html_para_break, | ||||
50 | 'html_para_break' => \&html_para_break, | ||||
51 | 'html_line_break' => \&html_line_break, | ||||
52 | 'xml' => \&xml_filter, | ||||
53 | 'uri' => \&uri_filter, | ||||
54 | 'url' => \&url_filter, | ||||
55 | 'upper' => sub { uc $_[0] }, | ||||
56 | 'lower' => sub { lc $_[0] }, | ||||
57 | 'ucfirst' => sub { ucfirst $_[0] }, | ||||
58 | 'lcfirst' => sub { lcfirst $_[0] }, | ||||
59 | 'stderr' => sub { print STDERR @_; return '' }, | ||||
60 | 'trim' => sub { for ($_[0]) { s/^\s+//; s/\s+$// }; $_[0] }, | ||||
61 | 'null' => sub { return '' }, | ||||
62 | 'collapse' => sub { for ($_[0]) { s/^\s+//; s/\s+$//; s/\s+/ /g }; | ||||
63 | $_[0] }, | ||||
64 | |||||
65 | # dynamic filters | ||||
66 | 1 | 49µs | 'html_entity' => [ \&html_entity_filter_factory, 1 ], | ||
67 | 'indent' => [ \&indent_filter_factory, 1 ], | ||||
68 | 'format' => [ \&format_filter_factory, 1 ], | ||||
69 | 'truncate' => [ \&truncate_filter_factory, 1 ], | ||||
70 | 'repeat' => [ \&repeat_filter_factory, 1 ], | ||||
71 | 'replace' => [ \&replace_filter_factory, 1 ], | ||||
72 | 'remove' => [ \&remove_filter_factory, 1 ], | ||||
73 | 'eval' => [ \&eval_filter_factory, 1 ], | ||||
74 | 'evaltt' => [ \&eval_filter_factory, 1 ], # alias | ||||
75 | 'perl' => [ \&perl_filter_factory, 1 ], | ||||
76 | 'evalperl' => [ \&perl_filter_factory, 1 ], # alias | ||||
77 | 'redirect' => [ \&redirect_filter_factory, 1 ], | ||||
78 | 'file' => [ \&redirect_filter_factory, 1 ], # alias | ||||
79 | 'stdout' => [ \&stdout_filter_factory, 1 ], | ||||
80 | }; | ||||
81 | |||||
82 | # name of module implementing plugin filters | ||||
83 | 1 | 900ns | our $PLUGIN_FILTER = 'Template::Plugin::Filter'; | ||
84 | |||||
- - | |||||
87 | #======================================================================== | ||||
88 | # -- PUBLIC METHODS -- | ||||
89 | #======================================================================== | ||||
90 | |||||
91 | #------------------------------------------------------------------------ | ||||
92 | # fetch($name, \@args, $context) | ||||
93 | # | ||||
94 | # Attempts to instantiate or return a reference to a filter sub-routine | ||||
95 | # named by the first parameter, $name, with additional constructor | ||||
96 | # arguments passed by reference to a list as the second parameter, | ||||
97 | # $args. A reference to the calling Template::Context object is | ||||
98 | # passed as the third paramter. | ||||
99 | # | ||||
100 | # Returns a reference to a filter sub-routine or a pair of values | ||||
101 | # (undef, STATUS_DECLINED) or ($error, STATUS_ERROR) to decline to | ||||
102 | # deliver the filter or to indicate an error. | ||||
103 | #------------------------------------------------------------------------ | ||||
104 | |||||
105 | # spent 2.37ms (2.35+20µs) within Template::Filters::fetch which was called 214 times, avg 11µs/call:
# 214 times (2.35ms+20µs) by Template::Context::filter at line 228 of Template/Context.pm, avg 11µs/call | ||||
106 | 1498 | 1.15ms | my ($self, $name, $args, $context) = @_; | ||
107 | my ($factory, $is_dynamic, $filter, $error); | ||||
108 | |||||
109 | $self->debug("fetch($name, ", | ||||
110 | defined $args ? ('[ ', join(', ', @$args), ' ]') : '<no args>', ', ', | ||||
111 | defined $context ? $context : '<no context>', | ||||
112 | ')') if $self->{ DEBUG }; | ||||
113 | |||||
114 | # allow $name to be specified as a reference to | ||||
115 | # a plugin filter object; any other ref is | ||||
116 | # assumed to be a coderef and hence already a filter; | ||||
117 | # non-refs are assumed to be regular name lookups | ||||
118 | |||||
119 | 214 | 363µs | if (ref $name) { | ||
120 | if (blessed($name) && $name->isa($PLUGIN_FILTER)) { | ||||
121 | $factory = $name->factory() | ||||
122 | || return $self->error($name->error()); | ||||
123 | } | ||||
124 | else { | ||||
125 | return $name; | ||||
126 | } | ||||
127 | } | ||||
128 | else { | ||||
129 | return (undef, Template::Constants::STATUS_DECLINED) | ||||
130 | unless ($factory = $self->{ FILTERS }->{ $name } | ||||
131 | || $FILTERS->{ $name }); | ||||
132 | } | ||||
133 | |||||
134 | # factory can be an [ $code, $dynamic ] or just $code | ||||
135 | 211 | 85µs | if (ref $factory eq 'ARRAY') { | ||
136 | ($factory, $is_dynamic) = @$factory; | ||||
137 | } | ||||
138 | else { | ||||
139 | $is_dynamic = 0; | ||||
140 | } | ||||
141 | |||||
142 | 214 | 120µs | if (ref $factory eq 'CODE') { | ||
143 | 220 | 135µs | if ($is_dynamic) { | ||
144 | # if the dynamic flag is set then the sub-routine is a | ||||
145 | # factory which should be called to create the actual | ||||
146 | # filter... | ||||
147 | 3 | 9µs | eval { | ||
148 | 3 | 20µs | ($filter, $error) = &$factory($context, $args ? @$args : ()); # spent 20µs making 3 calls to Template::Filters::replace_filter_factory, avg 7µs/call | ||
149 | }; | ||||
150 | $error ||= $@; | ||||
151 | $error = "invalid FILTER for '$name' (not a CODE ref)" | ||||
152 | unless $error || ref($filter) eq 'CODE'; | ||||
153 | } | ||||
154 | else { | ||||
155 | # ...otherwise, it's a static filter sub-routine | ||||
156 | $filter = $factory; | ||||
157 | } | ||||
158 | } | ||||
159 | else { | ||||
160 | $error = "invalid FILTER entry for '$name' (not a CODE ref)"; | ||||
161 | } | ||||
162 | |||||
163 | 214 | 985µs | if ($error) { | ||
164 | return $self->{ TOLERANT } | ||||
165 | ? (undef, Template::Constants::STATUS_DECLINED) | ||||
166 | : ($error, Template::Constants::STATUS_ERROR) ; | ||||
167 | } | ||||
168 | else { | ||||
169 | return $filter; | ||||
170 | } | ||||
171 | } | ||||
172 | |||||
173 | |||||
174 | #------------------------------------------------------------------------ | ||||
175 | # store($name, \&filter) | ||||
176 | # | ||||
177 | # Stores a new filter in the internal FILTERS hash. The first parameter | ||||
178 | # is the filter name, the second a reference to a subroutine or | ||||
179 | # array, as per the standard $FILTERS entries. | ||||
180 | #------------------------------------------------------------------------ | ||||
181 | |||||
182 | sub store { | ||||
183 | my ($self, $name, $filter) = @_; | ||||
184 | |||||
185 | $self->debug("store($name, $filter)") if $self->{ DEBUG }; | ||||
186 | |||||
187 | $self->{ FILTERS }->{ $name } = $filter; | ||||
188 | return 1; | ||||
189 | } | ||||
190 | |||||
191 | |||||
192 | #======================================================================== | ||||
193 | # -- PRIVATE METHODS -- | ||||
194 | #======================================================================== | ||||
195 | |||||
196 | #------------------------------------------------------------------------ | ||||
197 | # _init(\%config) | ||||
198 | # | ||||
199 | # Private initialisation method. | ||||
200 | #------------------------------------------------------------------------ | ||||
201 | |||||
202 | # spent 16µs within Template::Filters::_init which was called:
# once (16µs+0s) by Template::Base::new at line 65 of Template/Base.pm | ||||
203 | 5 | 21µs | my ($self, $params) = @_; | ||
204 | |||||
205 | $self->{ FILTERS } = $params->{ FILTERS } || { }; | ||||
206 | $self->{ TOLERANT } = $params->{ TOLERANT } || 0; | ||||
207 | $self->{ DEBUG } = ( $params->{ DEBUG } || 0 ) | ||||
208 | & Template::Constants::DEBUG_FILTERS; | ||||
209 | |||||
210 | |||||
211 | return $self; | ||||
212 | } | ||||
213 | |||||
- - | |||||
216 | #------------------------------------------------------------------------ | ||||
217 | # _dump() | ||||
218 | # | ||||
219 | # Debug method | ||||
220 | #------------------------------------------------------------------------ | ||||
221 | |||||
222 | sub _dump { | ||||
223 | my $self = shift; | ||||
224 | my $output = "[Template::Filters] {\n"; | ||||
225 | my $format = " %-16s => %s\n"; | ||||
226 | my $key; | ||||
227 | |||||
228 | foreach $key (qw( TOLERANT )) { | ||||
229 | my $val = $self->{ $key }; | ||||
230 | $val = '<undef>' unless defined $val; | ||||
231 | $output .= sprintf($format, $key, $val); | ||||
232 | } | ||||
233 | |||||
234 | my $filters = $self->{ FILTERS }; | ||||
235 | $filters = join('', map { | ||||
236 | sprintf(" $format", $_, $filters->{ $_ }); | ||||
237 | } keys %$filters); | ||||
238 | $filters = "{\n$filters }"; | ||||
239 | |||||
240 | $output .= sprintf($format, 'FILTERS (local)' => $filters); | ||||
241 | |||||
242 | $filters = $FILTERS; | ||||
243 | $filters = join('', map { | ||||
244 | my $f = $filters->{ $_ }; | ||||
245 | my ($ref, $dynamic) = ref $f eq 'ARRAY' ? @$f : ($f, 0); | ||||
246 | sprintf(" $format", $_, $dynamic ? 'dynamic' : 'static'); | ||||
247 | } sort keys %$filters); | ||||
248 | $filters = "{\n$filters }"; | ||||
249 | |||||
250 | $output .= sprintf($format, 'FILTERS (global)' => $filters); | ||||
251 | |||||
252 | $output .= '}'; | ||||
253 | return $output; | ||||
254 | } | ||||
255 | |||||
256 | |||||
257 | #======================================================================== | ||||
258 | # -- STATIC FILTER SUBS -- | ||||
259 | #======================================================================== | ||||
260 | |||||
261 | #------------------------------------------------------------------------ | ||||
262 | # uri_filter() [% FILTER uri %] | ||||
263 | # | ||||
264 | # URI escape a string. This code is borrowed from Gisle Aas' URI::Escape | ||||
265 | # module, copyright 1995-2004. See RFC2396 for details. | ||||
266 | #----------------------------------------------------------------------- | ||||
267 | |||||
268 | # cache of escaped characters | ||||
269 | 1 | 200ns | our $URI_ESCAPES; | ||
270 | |||||
271 | # spent 423µs (408+16) within Template::Filters::uri_filter which was called:
# once (408µs+16µs) by Template::Document::__ANON__[/usr/share/koha/opac/htdocs/opac-tmpl/prog/en-NZ/modules/opac-results.tt:541] at line 106 of /usr/share/koha/opac/htdocs/opac-tmpl/prog/en-NZ/modules/opac-results.tt | ||||
272 | 5 | 426µs | my $text = shift; | ||
273 | |||||
274 | $URI_ESCAPES ||= { | ||||
275 | map { ( chr($_), sprintf("%%%02X", $_) ) } (0..255), | ||||
276 | }; | ||||
277 | |||||
278 | 1 | 3µs | if ($] >= 5.008 && utf8::is_utf8($text)) { # spent 3µs making 1 call to utf8::is_utf8 | ||
279 | utf8::encode($text); | ||||
280 | } | ||||
281 | |||||
282 | 5 | 13µs | $text =~ s/([^A-Za-z0-9\-_.!~*'()])/$URI_ESCAPES->{$1}/eg; # spent 6µs making 4 calls to Template::Filters::CORE:substcont, avg 2µs/call
# spent 6µs making 1 call to Template::Filters::CORE:subst | ||
283 | $text; | ||||
284 | } | ||||
285 | |||||
286 | #------------------------------------------------------------------------ | ||||
287 | # url_filter() [% FILTER uri %] | ||||
288 | # | ||||
289 | # NOTE: the difference: url vs uri. | ||||
290 | # This implements the old-style, non-strict behaviour of the uri filter | ||||
291 | # which allows any valid URL characters to pass through so that | ||||
292 | # http://example.com/blah.html does not get the ':' and '/' characters | ||||
293 | # munged. | ||||
294 | #----------------------------------------------------------------------- | ||||
295 | |||||
296 | # spent 621µs (484+138) within Template::Filters::url_filter which was called 27 times, avg 23µs/call:
# 25 times (462µs+132µs) by Template::Document::__ANON__[/usr/share/koha/opac/htdocs/opac-tmpl/prog/en-NZ/modules/opac-results.tt:541] at line 510 of /usr/share/koha/opac/htdocs/opac-tmpl/prog/en-NZ/modules/opac-results.tt, avg 24µs/call
# 2 times (22µs+6µs) by Template::Document::__ANON__[/usr/share/koha/opac/htdocs/opac-tmpl/prog/en-NZ/includes/masthead.inc:111] at line 107 of /usr/share/koha/opac/htdocs/opac-tmpl/prog/en-NZ/includes/masthead.inc, avg 14µs/call | ||||
297 | 135 | 652µs | my $text = shift; | ||
298 | |||||
299 | $URI_ESCAPES ||= { | ||||
300 | map { ( chr($_), sprintf("%%%02X", $_) ) } (0..255), | ||||
301 | }; | ||||
302 | |||||
303 | 27 | 49µs | if ($] >= 5.008 && utf8::is_utf8($text)) { # spent 49µs making 27 calls to utf8::is_utf8, avg 2µs/call | ||
304 | utf8::encode($text); | ||||
305 | } | ||||
306 | |||||
307 | 27 | 89µs | $text =~ s/([^;\/?:@&=+\$,A-Za-z0-9\-_.!~*'()])/$URI_ESCAPES->{$1}/eg; # spent 89µs making 27 calls to Template::Filters::CORE:subst, avg 3µs/call | ||
308 | $text; | ||||
309 | } | ||||
310 | |||||
311 | |||||
312 | #------------------------------------------------------------------------ | ||||
313 | # html_filter() [% FILTER html %] | ||||
314 | # | ||||
315 | # Convert any '<', '>' or '&' characters to the HTML equivalents, '<', | ||||
316 | # '>' and '&', respectively. | ||||
317 | #------------------------------------------------------------------------ | ||||
318 | |||||
319 | # spent 3.42ms (2.71+711µs) within Template::Filters::html_filter which was called 183 times, avg 19µs/call:
# 101 times (1.25ms+353µs) by Template::Document::__ANON__[/usr/share/koha/opac/htdocs/opac-tmpl/prog/en-NZ/includes/opac-facets.inc:32] at line 18 of /usr/share/koha/opac/htdocs/opac-tmpl/prog/en-NZ/includes/opac-facets.inc, avg 16µs/call
# 60 times (1.15ms+248µs) by Template::Document::__ANON__[/usr/share/koha/opac/htdocs/opac-tmpl/prog/en-NZ/includes/page-numbers.inc:31] at line 12 of /usr/share/koha/opac/htdocs/opac-tmpl/prog/en-NZ/includes/page-numbers.inc, avg 23µs/call
# 5 times (76µs+62µs) by Template::Document::__ANON__[/usr/share/koha/opac/htdocs/opac-tmpl/prog/en-NZ/modules/opac-results.tt:541] at line 10 of /usr/share/koha/opac/htdocs/opac-tmpl/prog/en-NZ/modules/opac-results.tt, avg 28µs/call
# 4 times (71µs+11µs) by Template::Document::__ANON__[/usr/share/koha/opac/htdocs/opac-tmpl/prog/en-NZ/modules/opac-results.tt:541] at line 390 of /usr/share/koha/opac/htdocs/opac-tmpl/prog/en-NZ/modules/opac-results.tt, avg 21µs/call
# 4 times (54µs+10µs) by Template::Document::__ANON__[/usr/share/koha/opac/htdocs/opac-tmpl/prog/en-NZ/includes/masthead.inc:111] at line 77 of /usr/share/koha/opac/htdocs/opac-tmpl/prog/en-NZ/includes/masthead.inc, avg 16µs/call
# 3 times (34µs+10µs) by Template::Document::__ANON__[/usr/share/koha/opac/htdocs/opac-tmpl/prog/en-NZ/includes/opac-facets.inc:32] at line 13 of /usr/share/koha/opac/htdocs/opac-tmpl/prog/en-NZ/includes/opac-facets.inc, avg 15µs/call
# 2 times (28µs+4µs) by Template::Document::__ANON__[/usr/share/koha/opac/htdocs/opac-tmpl/prog/en-NZ/includes/masthead.inc:111] at line 96 of /usr/share/koha/opac/htdocs/opac-tmpl/prog/en-NZ/includes/masthead.inc, avg 16µs/call
# 2 times (20µs+6µs) by Template::Document::__ANON__[/usr/share/koha/opac/htdocs/opac-tmpl/prog/en-NZ/includes/masthead.inc:111] at line 103 of /usr/share/koha/opac/htdocs/opac-tmpl/prog/en-NZ/includes/masthead.inc, avg 13µs/call
# once (15µs+5µs) by Template::Document::__ANON__[/usr/share/koha/opac/htdocs/opac-tmpl/prog/en-NZ/includes/masthead.inc:111] at line 46 of /usr/share/koha/opac/htdocs/opac-tmpl/prog/en-NZ/includes/masthead.inc
# once (11µs+1µs) by Template::Document::__ANON__[/usr/share/koha/opac/htdocs/opac-tmpl/prog/en-NZ/modules/opac-results.tt:541] at line 279 of /usr/share/koha/opac/htdocs/opac-tmpl/prog/en-NZ/modules/opac-results.tt | ||||
320 | 549 | 987µs | my $text = shift; | ||
321 | for ($text) { | ||||
322 | 732 | 2.64ms | 183 | 482µs | s/&/&/g; # spent 482µs making 183 calls to Template::Filters::CORE:subst, avg 3µs/call |
323 | 183 | 78µs | s/</</g; # spent 78µs making 183 calls to Template::Filters::CORE:subst, avg 427ns/call | ||
324 | 183 | 70µs | s/>/>/g; # spent 70µs making 183 calls to Template::Filters::CORE:subst, avg 381ns/call | ||
325 | 183 | 81µs | s/"/"/g; # spent 81µs making 183 calls to Template::Filters::CORE:subst, avg 444ns/call | ||
326 | } | ||||
327 | return $text; | ||||
328 | } | ||||
329 | |||||
330 | |||||
331 | #------------------------------------------------------------------------ | ||||
332 | # xml_filter() [% FILTER xml %] | ||||
333 | # | ||||
334 | # Same as the html filter, but adds the conversion of ' to ' which | ||||
335 | # is native to XML. | ||||
336 | #------------------------------------------------------------------------ | ||||
337 | |||||
338 | sub xml_filter { | ||||
339 | my $text = shift; | ||||
340 | for ($text) { | ||||
341 | s/&/&/g; | ||||
342 | s/</</g; | ||||
343 | s/>/>/g; | ||||
344 | s/"/"/g; | ||||
345 | s/'/'/g; | ||||
346 | } | ||||
347 | return $text; | ||||
348 | } | ||||
349 | |||||
350 | |||||
351 | #------------------------------------------------------------------------ | ||||
352 | # html_paragraph() [% FILTER html_para %] | ||||
353 | # | ||||
354 | # Wrap each paragraph of text (delimited by two or more newlines) in the | ||||
355 | # <p>...</p> HTML tags. | ||||
356 | #------------------------------------------------------------------------ | ||||
357 | |||||
358 | sub html_paragraph { | ||||
359 | my $text = shift; | ||||
360 | return "<p>\n" | ||||
361 | . join("\n</p>\n\n<p>\n", split(/(?:\r?\n){2,}/, $text)) | ||||
362 | . "</p>\n"; | ||||
363 | } | ||||
364 | |||||
365 | |||||
366 | #------------------------------------------------------------------------ | ||||
367 | # html_para_break() [% FILTER html_para_break %] | ||||
368 | # | ||||
369 | # Join each paragraph of text (delimited by two or more newlines) with | ||||
370 | # <br><br> HTML tags. | ||||
371 | #------------------------------------------------------------------------ | ||||
372 | |||||
373 | sub html_para_break { | ||||
374 | my $text = shift; | ||||
375 | $text =~ s|(\r?\n){2,}|$1<br />$1<br />$1|g; | ||||
376 | return $text; | ||||
377 | } | ||||
378 | |||||
379 | #------------------------------------------------------------------------ | ||||
380 | # html_line_break() [% FILTER html_line_break %] | ||||
381 | # | ||||
382 | # replaces any newlines with <br> HTML tags. | ||||
383 | #------------------------------------------------------------------------ | ||||
384 | |||||
385 | sub html_line_break { | ||||
386 | my $text = shift; | ||||
387 | $text =~ s|(\r?\n)|<br />$1|g; | ||||
388 | return $text; | ||||
389 | } | ||||
390 | |||||
391 | #======================================================================== | ||||
392 | # -- DYNAMIC FILTER FACTORIES -- | ||||
393 | #======================================================================== | ||||
394 | |||||
395 | #------------------------------------------------------------------------ | ||||
396 | # html_entity_filter_factory(\%options) [% FILTER html %] | ||||
397 | # | ||||
398 | # Dynamic version of the static html filter which attempts to locate the | ||||
399 | # Apache::Util or HTML::Entities modules to perform full entity encoding | ||||
400 | # of the text passed. Returns an exception if one or other of the | ||||
401 | # modules can't be located. | ||||
402 | #------------------------------------------------------------------------ | ||||
403 | |||||
404 | sub use_html_entities { | ||||
405 | require HTML::Entities; | ||||
406 | return ($AVAILABLE->{ HTML_ENTITY } = \&HTML::Entities::encode_entities); | ||||
407 | } | ||||
408 | |||||
409 | sub use_apache_util { | ||||
410 | require Apache::Util; | ||||
411 | Apache::Util::escape_html(''); # TODO: explain this | ||||
412 | return ($AVAILABLE->{ HTML_ENTITY } = \&Apache::Util::escape_html); | ||||
413 | } | ||||
414 | |||||
415 | sub html_entity_filter_factory { | ||||
416 | my $context = shift; | ||||
417 | my $haz; | ||||
418 | |||||
419 | # if Apache::Util is installed then we use escape_html | ||||
420 | $haz = $AVAILABLE->{ HTML_ENTITY } | ||||
421 | || eval { use_apache_util() } | ||||
422 | || eval { use_html_entities() } | ||||
423 | || -1; # we use -1 for "not available" because it's a true value | ||||
424 | |||||
425 | return ref $haz eq 'CODE' | ||||
426 | ? $haz | ||||
427 | : (undef, Template::Exception->new( | ||||
428 | html_entity => 'cannot locate Apache::Util or HTML::Entities' ) | ||||
429 | ); | ||||
430 | } | ||||
431 | |||||
432 | |||||
433 | #------------------------------------------------------------------------ | ||||
434 | # indent_filter_factory($pad) [% FILTER indent(pad) %] | ||||
435 | # | ||||
436 | # Create a filter to indent text by a fixed pad string or when $pad is | ||||
437 | # numerical, a number of space. | ||||
438 | #------------------------------------------------------------------------ | ||||
439 | |||||
440 | sub indent_filter_factory { | ||||
441 | my ($context, $pad) = @_; | ||||
442 | $pad = 4 unless defined $pad; | ||||
443 | $pad = ' ' x $pad if $pad =~ /^\d+$/; | ||||
444 | |||||
445 | return sub { | ||||
446 | my $text = shift; | ||||
447 | $text = '' unless defined $text; | ||||
448 | $text =~ s/^/$pad/mg; | ||||
449 | return $text; | ||||
450 | } | ||||
451 | } | ||||
452 | |||||
453 | #------------------------------------------------------------------------ | ||||
454 | # format_filter_factory() [% FILTER format(format) %] | ||||
455 | # | ||||
456 | # Create a filter to format text according to a printf()-like format | ||||
457 | # string. | ||||
458 | #------------------------------------------------------------------------ | ||||
459 | |||||
460 | sub format_filter_factory { | ||||
461 | my ($context, $format) = @_; | ||||
462 | $format = '%s' unless defined $format; | ||||
463 | |||||
464 | return sub { | ||||
465 | my $text = shift; | ||||
466 | $text = '' unless defined $text; | ||||
467 | return join("\n", map{ sprintf($format, $_) } split(/\n/, $text)); | ||||
468 | } | ||||
469 | } | ||||
470 | |||||
471 | |||||
472 | #------------------------------------------------------------------------ | ||||
473 | # repeat_filter_factory($n) [% FILTER repeat(n) %] | ||||
474 | # | ||||
475 | # Create a filter to repeat text n times. | ||||
476 | #------------------------------------------------------------------------ | ||||
477 | |||||
478 | sub repeat_filter_factory { | ||||
479 | my ($context, $iter) = @_; | ||||
480 | $iter = 1 unless defined $iter and length $iter; | ||||
481 | |||||
482 | return sub { | ||||
483 | my $text = shift; | ||||
484 | $text = '' unless defined $text; | ||||
485 | return join('\n', $text) x $iter; | ||||
486 | } | ||||
487 | } | ||||
488 | |||||
489 | |||||
490 | #------------------------------------------------------------------------ | ||||
491 | # replace_filter_factory($s, $r) [% FILTER replace(search, replace) %] | ||||
492 | # | ||||
493 | # Create a filter to replace 'search' text with 'replace' | ||||
494 | #------------------------------------------------------------------------ | ||||
495 | |||||
496 | # spent 20µs within Template::Filters::replace_filter_factory which was called 3 times, avg 7µs/call:
# 3 times (20µs+0s) by Template::Filters::fetch at line 148, avg 7µs/call | ||||
497 | 12 | 23µs | my ($context, $search, $replace) = @_; | ||
498 | $search = '' unless defined $search; | ||||
499 | $replace = '' unless defined $replace; | ||||
500 | |||||
501 | # spent 65µs (39+26) within Template::Filters::__ANON__[/usr/lib/perl5/Template/Filters.pm:506] which was called 3 times, avg 22µs/call:
# once (23µs+15µs) by Template::Document::__ANON__[/usr/share/koha/opac/htdocs/opac-tmpl/prog/en-NZ/modules/opac-results.tt:541] at line 267 of /usr/share/koha/opac/htdocs/opac-tmpl/prog/en-NZ/modules/opac-results.tt
# once (9µs+7µs) by Template::Document::__ANON__[/usr/share/koha/opac/htdocs/opac-tmpl/prog/en-NZ/modules/opac-results.tt:541] at line 271 of /usr/share/koha/opac/htdocs/opac-tmpl/prog/en-NZ/modules/opac-results.tt
# once (7µs+4µs) by Template::Document::__ANON__[/usr/share/koha/opac/htdocs/opac-tmpl/prog/en-NZ/modules/opac-results.tt:541] at line 275 of /usr/share/koha/opac/htdocs/opac-tmpl/prog/en-NZ/modules/opac-results.tt | ||||
502 | 12 | 73µs | my $text = shift; | ||
503 | $text = '' unless defined $text; | ||||
504 | 6 | 26µs | $text =~ s/$search/$replace/g; # spent 23µs making 3 calls to Template::Filters::CORE:regcomp, avg 8µs/call
# spent 3µs making 3 calls to Template::Filters::CORE:subst, avg 867ns/call | ||
505 | return $text; | ||||
506 | } | ||||
507 | } | ||||
508 | |||||
509 | |||||
510 | #------------------------------------------------------------------------ | ||||
511 | # remove_filter_factory($text) [% FILTER remove(text) %] | ||||
512 | # | ||||
513 | # Create a filter to remove 'search' string from the input text. | ||||
514 | #------------------------------------------------------------------------ | ||||
515 | |||||
516 | sub remove_filter_factory { | ||||
517 | my ($context, $search) = @_; | ||||
518 | |||||
519 | return sub { | ||||
520 | my $text = shift; | ||||
521 | $text = '' unless defined $text; | ||||
522 | $text =~ s/$search//g; | ||||
523 | return $text; | ||||
524 | } | ||||
525 | } | ||||
526 | |||||
527 | |||||
528 | #------------------------------------------------------------------------ | ||||
529 | # truncate_filter_factory($n) [% FILTER truncate(n) %] | ||||
530 | # | ||||
531 | # Create a filter to truncate text after n characters. | ||||
532 | #------------------------------------------------------------------------ | ||||
533 | |||||
534 | sub truncate_filter_factory { | ||||
535 | my ($context, $len, $char) = @_; | ||||
536 | $len = $TRUNCATE_LENGTH unless defined $len; | ||||
537 | $char = $TRUNCATE_ADDON unless defined $char; | ||||
538 | |||||
539 | # Length of char is the minimum length | ||||
540 | my $lchar = length $char; | ||||
541 | if ($len < $lchar) { | ||||
542 | $char = substr($char, 0, $len); | ||||
543 | $lchar = $len; | ||||
544 | } | ||||
545 | |||||
546 | return sub { | ||||
547 | my $text = shift; | ||||
548 | return $text if length $text <= $len; | ||||
549 | return substr($text, 0, $len - $lchar) . $char; | ||||
550 | |||||
551 | |||||
552 | } | ||||
553 | } | ||||
554 | |||||
555 | |||||
556 | #------------------------------------------------------------------------ | ||||
557 | # eval_filter_factory [% FILTER eval %] | ||||
558 | # | ||||
559 | # Create a filter to evaluate template text. | ||||
560 | #------------------------------------------------------------------------ | ||||
561 | |||||
562 | sub eval_filter_factory { | ||||
563 | my $context = shift; | ||||
564 | |||||
565 | return sub { | ||||
566 | my $text = shift; | ||||
567 | $context->process(\$text); | ||||
568 | } | ||||
569 | } | ||||
570 | |||||
571 | |||||
572 | #------------------------------------------------------------------------ | ||||
573 | # perl_filter_factory [% FILTER perl %] | ||||
574 | # | ||||
575 | # Create a filter to process Perl text iff the context EVAL_PERL flag | ||||
576 | # is set. | ||||
577 | #------------------------------------------------------------------------ | ||||
578 | |||||
579 | sub perl_filter_factory { | ||||
580 | my $context = shift; | ||||
581 | my $stash = $context->stash; | ||||
582 | |||||
583 | return (undef, Template::Exception->new('perl', 'EVAL_PERL is not set')) | ||||
584 | unless $context->eval_perl(); | ||||
585 | |||||
586 | return sub { | ||||
587 | my $text = shift; | ||||
588 | local($Template::Perl::context) = $context; | ||||
589 | local($Template::Perl::stash) = $stash; | ||||
590 | my $out = eval <<EOF; | ||||
591 | package Template::Perl; | ||||
592 | \$stash = \$context->stash(); | ||||
593 | $text | ||||
594 | EOF | ||||
595 | $context->throw($@) if $@; | ||||
596 | return $out; | ||||
597 | } | ||||
598 | } | ||||
599 | |||||
600 | |||||
601 | #------------------------------------------------------------------------ | ||||
602 | # redirect_filter_factory($context, $file) [% FILTER redirect(file) %] | ||||
603 | # | ||||
604 | # Create a filter to redirect the block text to a file. | ||||
605 | #------------------------------------------------------------------------ | ||||
606 | |||||
607 | sub redirect_filter_factory { | ||||
608 | my ($context, $file, $options) = @_; | ||||
609 | my $outpath = $context->config->{ OUTPUT_PATH }; | ||||
610 | |||||
611 | return (undef, Template::Exception->new('redirect', | ||||
612 | 'OUTPUT_PATH is not set')) | ||||
613 | unless $outpath; | ||||
614 | |||||
615 | $context->throw('redirect', "relative filenames are not supported: $file") | ||||
616 | if $file =~ m{(^|/)\.\./}; | ||||
617 | |||||
618 | $options = { binmode => $options } unless ref $options; | ||||
619 | |||||
620 | sub { | ||||
621 | my $text = shift; | ||||
622 | my $outpath = $context->config->{ OUTPUT_PATH } | ||||
623 | || return ''; | ||||
624 | $outpath .= "/$file"; | ||||
625 | my $error = Template::_output($outpath, \$text, $options); | ||||
626 | die Template::Exception->new('redirect', $error) | ||||
627 | if $error; | ||||
628 | return ''; | ||||
629 | } | ||||
630 | } | ||||
631 | |||||
632 | |||||
633 | #------------------------------------------------------------------------ | ||||
634 | # stdout_filter_factory($context, $binmode) [% FILTER stdout(binmode) %] | ||||
635 | # | ||||
636 | # Create a filter to print a block to stdout, with an optional binmode. | ||||
637 | #------------------------------------------------------------------------ | ||||
638 | |||||
639 | sub stdout_filter_factory { | ||||
640 | my ($context, $options) = @_; | ||||
641 | |||||
642 | $options = { binmode => $options } unless ref $options; | ||||
643 | |||||
644 | sub { | ||||
645 | my $text = shift; | ||||
646 | binmode(STDOUT) if $options->{ binmode }; | ||||
647 | print STDOUT $text; | ||||
648 | return ''; | ||||
649 | } | ||||
650 | } | ||||
651 | |||||
652 | |||||
653 | 1 | 22µs | 1; | ||
654 | |||||
655 | __END__ | ||||
# spent 23µs within Template::Filters::CORE:regcomp which was called 3 times, avg 8µs/call:
# 3 times (23µs+0s) by Template::Filters::__ANON__[/usr/lib/perl5/Template/Filters.pm:506] at line 504, avg 8µs/call | |||||
# spent 809µs within Template::Filters::CORE:subst which was called 763 times, avg 1µs/call:
# 183 times (482µs+0s) by Template::Filters::html_filter at line 322, avg 3µs/call
# 183 times (81µs+0s) by Template::Filters::html_filter at line 325, avg 444ns/call
# 183 times (78µs+0s) by Template::Filters::html_filter at line 323, avg 427ns/call
# 183 times (70µs+0s) by Template::Filters::html_filter at line 324, avg 381ns/call
# 27 times (89µs+0s) by Template::Filters::url_filter at line 307, avg 3µs/call
# 3 times (3µs+0s) by Template::Filters::__ANON__[/usr/lib/perl5/Template/Filters.pm:506] at line 504, avg 867ns/call
# once (6µs+0s) by Template::Filters::uri_filter at line 282 | |||||
# spent 6µs within Template::Filters::CORE:substcont which was called 4 times, avg 2µs/call:
# 4 times (6µs+0s) by Template::Filters::uri_filter at line 282, avg 2µs/call |