1Template::Manual::VMethUosdesr(3C)ontributed Perl DocumeTnetmaptliaotne::Manual::VMethods(3)
2
3
4
6 Template::Manual::VMethods - Virtual Methods
7
9 defined
10 Returns true if the value is defined.
11
12 [% user = get_user(uid) IF uid.defined %]
13
14 length
15 Returns the length of the string representation of the item:
16
17 [% IF password.length < 8 %]
18 Password too short, dumbass!
19 [% END %]
20
21 repeat(n)
22 Repeat the string a specified number of times.
23
24 [% name = 'foo' %]
25 [% name.repeat(3) %] # foofoofoo
26
27 replace(search, replace)
28 Outputs the string with all instances of the first argument (specified
29 as a Perl regular expression) with the second.
30
31 [% name = 'foo, bar & baz' %]
32 [% name.replace('\W+', '_') %] # foo_bar_baz
33
34 You can use $1, $2, etc., to reference captured parts (in parentheses)
35 in the regular expression. Just be careful to single quote the
36 replacement string. If you use double quotes then TT will try and
37 interpolate the variables before passing the string to the "replace"
38 vmethod.
39
40 [% name = 'FooBarBaz' %]
41 [% name.replace('([A-Z])', ' $1') %] # Foo Bar Baz
42
43 remove(pattern)
44 Outputs the string with all instances of the pattern (specified as a
45 Perl regular expression) removed.
46
47 [% name = 'foo, bar & baz' %]
48 [% name.remove('\W+') %] # foobarbaz
49
50 match(pattern, global)
51 Performs a regular expression match on the string using the pattern
52 passed as an argument. If the pattern matches the string then the
53 method returns a reference to a list of any strings captured within
54 parenthesis in the pattern.
55
56 [% name = 'Larry Wall' %]
57 [% matches = name.match('(\w+) (\w+)') %]
58 [% matches.1 %], [% matches.0 %] # Wall, Larry
59
60 If the pattern does not match then the method returns false, rather
61 than returning an empty list which Perl and the Template Toolkit both
62 consider to be a true value. This allows you to write expression like
63 this.
64
65 [% "We're not worthy!" IF name.match('Larry Wall') %]
66
67 [% IF (matches = name.match('(\w+) (\w+)')) %]
68 pattern matches: [% matches.join(', ') %]
69 [% ELSE %]
70 pattern does not match
71 [% END %]
72
73 Any regex modifiers, like "/s", should be added in the regex using the
74 "(?s)" syntax. For example, to modify the regex to disregard
75 whitespace (the "/x" switch), use:
76
77 [% re = '(?x)
78 (\w+)
79 [ ]
80 (\w+)
81 ';
82 matches = name.match(re);
83 %]
84
85 To perform a global search to match the pattern as many times as it
86 appears in the source string, provide a true value for the "global"
87 argument following the pattern.
88
89 [% text = 'bandanna';
90 text.match('an+', 1).join(', ) # an, ann
91 %]
92
93 search(pattern)
94 Performs a similar function to match but simply returns true if the
95 string matches the regular expression pattern passed as an argument.
96
97 [% name = 'foo bar baz' %]
98 [% name.search('bar') ? 'bar' : 'no bar' %] # bar
99
100 This virtual method is now deprecated in favour of match. Move along
101 now, there's nothing more to see here.
102
103 split(pattern)
104 Calls Perl's "split()" function to split a string into a list of
105 strings.
106
107 [% FOREACH dir IN mypath.split(':') %]
108 [% dir %]
109 [% END %]
110
111 chunk(size)
112 Splits the value into a list of chunks of a certain size.
113
114 [% ccard_no = "1234567824683579";
115 ccard_no.chunk(4).join
116 %]
117
118 Output:
119
120 1234 5678 2468 3579
121
122 If the size is specified as a negative number then the text will be
123 chunked from right-to-left. This gives the correct grouping for
124 numbers, for example.
125
126 [% number = 1234567;
127 number.chunk(-3).join(',')
128 %]
129
130 Output:
131
132 1,234,567
133
134 substr(offset, length, replacement)
135 Returns a substring starting at "offset", for "length" characters.
136
137 [% str 'foo bar baz wiz waz woz') %]
138 [% str.substr(4, 3) %] # bar
139
140 If "length" is not specified then it returns everything from the
141 "offset" to the end of the string.
142
143 [% str.substr(12) %] # wiz waz woz
144
145 If both "length" and "replacement" are specified, then the method
146 replaces everything from "offset" for "length" characters with
147 $replacement. The substring removed from the string is then returned.
148
149 [% str.substr(0, 11, 'FOO') %] # foo bar baz
150 [% str %] # FOO wiz waz woz
151
152 list
153 Return the value as a single element list. This can be useful if you
154 have a variable which may contain a single item or a list and you want
155 to treat them equally. The "list" method can be called against a list
156 reference and will simply return the original reference, effectively a
157 no-op.
158
159 [% thing.list.size %] # thing can be a scalar or a list
160
161 hash
162 Return the value as a hash reference containing a single entry with the
163 key "value" indicating the original scalar value. As with the "list"
164 virtual method, this is generally used to help massage data into
165 different formats.
166
167 size
168 Always returns 1 for scalar values. This method is provided for
169 consistency with the hash and list size methods.
170
172 keys
173 Returns a list of keys in the hash. They are not returned in any
174 particular order, but the order is the same as for the corresponding
175 values method.
176
177 [% FOREACH key IN hash.keys %]
178 * [% key %]
179 [% END %]
180
181 If you want the keys in sorted order, use the list "sort" method.
182
183 [% FOREACH key IN hash.keys.sort %]
184 * [% key %]
185 [% END %]
186
187 Having got the keys in sorted order, you can then use variable
188 interpolation to fetch the value. This is shown in the following
189 example by the use of $key to fetch the item from "hash" whose key is
190 stored in the "key" variable.
191
192 [% FOREACH key IN hash.keys.sort %]
193 * [% key %] = [% hash.$key %]
194 [% END %]
195
196 Alternately, you can use the "pairs" method to get a list of key/value
197 pairs in sorted order.
198
199 values
200 Returns a list of the values in the hash. As with the "keys" method,
201 they are not returned in any particular order, although it is the same
202 order that the keys are returned in.
203
204 [% hash.values.join(', ') %]
205
206 items
207 Returns a list of both the keys and the values expanded into a single
208 list.
209
210 [% hash = {
211 a = 10
212 b = 20
213 };
214
215 hash.items.join(', ') # a, 10, b, 20
216 %]
217
218 each
219 This method currently returns the same thing as the "items" method.
220
221 However, please note that this method will change in the next major
222 version of the Template Toolkit (v3) to return the same thing as the
223 "pairs" method. This will be done in an effort to make these virtual
224 method more consistent with each other and how Perl works.
225
226 In anticipation of this, we recommend that you stop using "hash.each"
227 and instead use "hash.items".
228
229 pairs
230 This method returns a list of key/value pairs. They are returned in
231 sorted order according to the keys.
232
233 [% FOREACH pair IN product.pairs %]
234 * [% pair.key %] is [% pair.value %]
235 [% END %]
236
237 list
238 Returns the contents of the hash in list form. An argument can be
239 passed to indicate the desired items required in the list: "keys" to
240 return a list of the keys (same as "hash.keys"), "values" to return a
241 list of the values (same as "hash.values"), "each" to return as list of
242 key and values (same as "hash.each"), or "pairs" to return a list of
243 key/value pairs (same as "hash.pairs").
244
245 [% keys = hash.list('keys') %]
246 [% values = hash.list('values') %]
247 [% items = hash.list('each') %]
248 [% pairs = hash.list('pairs') %]
249
250 When called without an argument it currently returns the same thing as
251 the "pairs" method. However, please note that this method will change
252 in the next major version of the Template Toolkit (v3) to return a
253 reference to a list containing the single hash reference (as per the
254 scalar list method).
255
256 In anticipation of this, we recommend that you stop using "hash.list"
257 and instead use "hash.pairs".
258
259 sort, nsort
260 Return a list of the keys, sorted alphabetically ("sort") or
261 numerically ("nsort") according to the corresponding values in the
262 hash.
263
264 [% FOREACH n IN phones.sort %]
265 [% phones.$n %] is [% n %],
266 [% END %]
267
268 import
269 The "import" method can be called on a hash array to import the
270 contents of another hash array.
271
272 [% hash1 = {
273 foo = 'Foo'
274 bar = 'Bar'
275 }
276 hash2 = {
277 wiz = 'Wiz'
278 woz = 'Woz'
279 }
280 %]
281
282 [% hash1.import(hash2) %]
283 [% hash1.wiz %] # Wiz
284
285 You can also call the "import()" method by itself to import a hash
286 array into the current namespace hash.
287
288 [% user = { id => 'lwall', name => 'Larry Wall' } %]
289 [% import(user) %]
290 [% id %]: [% name %] # lwall: Larry Wall
291
292 defined, exists
293 Returns a true or false value if an item in the hash denoted by the key
294 passed as an argument is defined or exists, respectively.
295
296 [% hash.defined('somekey') ? 'yes' : 'no' %]
297 [% hash.exists('somekey') ? 'yes' : 'no' %]
298
299 When called without any argument, "hash.defined" returns true if the
300 hash itself is defined (e.g. the same effect as "scalar.defined").
301
302 delete
303 Delete one or more items from the hash.
304
305 [% hash.delete('foo', 'bar') %]
306
307 size
308 Returns the number of key/value pairs in the hash.
309
310 item
311 Returns an item from the hash using a key passed as an argument.
312
313 [% hash.item('foo') %] # same as hash.foo
314
316 first, last
317 Returns the first/last item in the list. The item is not removed from
318 the list.
319
320 [% results.first %] to [% results.last %]
321
322 If either is given a numeric argument "n", they return the first or
323 last "n" elements:
324
325 The first 5 results are [% results.first(5).join(", ") %].
326
327 size, max
328 Returns the size of a list (number of elements) and the maximum index
329 number (size - 1), respectively.
330
331 [% results.size %] search results matched your query
332
333 defined
334 Returns a true or false value if the item in the list denoted by the
335 argument is defined.
336
337 [% list.defined(3) ? 'yes' : 'no' %]
338
339 When called without any argument, "list.defined" returns true if the
340 list itself is defined (e.g. the same effect as "scalar.defined").
341
342 reverse
343 Returns the items of the list in reverse order.
344
345 [% FOREACH s IN scores.reverse %]
346 ...
347 [% END %]
348
349 join
350 Joins the items in the list into a single string, using Perl's "join()"
351 function.
352
353 [% items.join(', ') %]
354
355 grep
356 Returns a list of the items in the list that match a regular expression
357 pattern.
358
359 [% FOREACH directory.files.grep('\.txt$') %]
360 ...
361 [% END %]
362
363 sort, nsort
364 Returns the items in alpha ("sort") or numerical ("nsort") order.
365
366 [% library = books.sort %]
367
368 An argument can be provided to specify a search key. Where an item in
369 the list is a hash reference, the search key will be used to retrieve a
370 value from the hash which will then be used as the comparison value.
371 Where an item is an object which implements a method of that name, the
372 method will be called to return a comparison value.
373
374 [% library = books.sort('author') %]
375
376 In the example, the "books" list can contains hash references with an
377 "author" key or objects with an "author" method.
378
379 You can also specify multiple sort keys.
380
381 [% library = books.sort('author', 'title') %]
382
383 In this case the books will be sorted primarily by author. If two or
384 more books have authors with the same name then they will be sorted by
385 title.
386
387 unshift(item), push(item)
388 The "push()" method adds an item or items to the end of list.
389
390 [% mylist.push(foo) %]
391 [% mylist.push(foo, bar) %]
392
393 The "unshift()" method adds an item or items to the start of a list.
394
395 [% mylist.unshift(foo) %]
396 [% mylist.push(foo, bar) %]
397
398 shift, pop
399 Removes the first/last item from the list and returns it.
400
401 [% first = mylist.shift %]
402 [% last = mylist.pop %]
403
404 unique
405 Returns a list of the unique elements in a list, in the same order as
406 in the list itself.
407
408 [% mylist = [ 1, 2, 3, 2, 3, 4, 1, 4, 3, 4, 5 ] %]
409 [% numbers = mylist.unique %]
410
411 While this can be explicitly sorted, it is not required that the list
412 be sorted before the unique elements are pulled out (unlike the Unix
413 command line utility).
414
415 [% numbers = mylist.unique.sort %]
416
417 import
418 Appends the contents of one or more other lists to the end of the
419 current list.
420
421 [% one = [ 1 2 3 ];
422 two = [ 4 5 6 ];
423 three = [ 7 8 9 ];
424 one.import(two, three);
425 one.join(', ); # 1, 2, 3, 4, 5, 6, 7, 8, 9
426 %]
427
428 merge
429 Returns a list composed of zero or more other lists:
430
431 [% list_one = [ 1 2 3 ];
432 list_two = [ 4 5 6 ];
433 list_three = [ 7 8 9 ];
434 list_four = list_one.merge(list_two, list_three);
435 %]
436
437 The original lists are not modified.
438
439 slice(from, to)
440 Returns a slice of items in the list between the bounds passed as
441 arguments. If the second argument, "to", isn't specified, then it
442 defaults to the last item in the list. The original list is not
443 modified.
444
445 [% first_three = list.slice(0,2) %]
446 [% last_three = list.slice(-3, -1) %]
447
448 splice(offset, length, list)
449 Behaves just like Perl's "splice()" function allowing you to
450 selectively remove and/or replace elements in a list. It removes
451 "length" items from the list, starting at "offset" and replaces them
452 with the items in "list".
453
454 [% play_game = [ 'play', 'scrabble' ];
455 ping_pong = [ 'ping', 'pong' ];
456 redundant = play_game.splice(1, 1, ping_pong);
457 redundant.join; # scrabble
458 play_game.join; # play ping pong
459 %]
460
461 The method returns a list of the items removed by the splice. You can
462 use the "CALL" directive to ignore the output if you're not planning to
463 do anything with it.
464
465 [% CALL play_game.splice(1, 1, ping_pong) %]
466
467 As well as providing a reference to a list of replacement values, you
468 can pass in a list of items.
469
470 [% CALL list.splice(-1, 0, 'foo', 'bar') %]
471
472 Be careful about passing just one item in as a replacement value. If
473 it is a reference to a list then the contents of the list will be used.
474 If it's not a list, then it will be treated as a single value. You can
475 use square brackets around a single item if you need to be explicit:
476
477 [% # push a single item, an_item
478 CALL list.splice(-1, 0, an_item);
479
480 # push the items from another_list
481 CALL list.splice(-1, 0, another_list);
482
483 # push a reference to another_list
484 CALL list.splice(-1, 0, [ another_list ]);
485 %]
486
487 hash
488 Returns a reference to a hash array comprised of the elements in the
489 list. The even-numbered elements (0, 2, 4, etc) become the keys and
490 the odd-numbered elements (1, 3, 5, etc) the values.
491
492 [% list = ['pi', 3.14, 'e', 2.718] %]
493 [% hash = list.hash %]
494 [% hash.pi %] # 3.14
495 [% hash.e %] # 2.718
496
497 If a numerical argument is provided then the hash returned will have
498 keys generated for each item starting at the number specified.
499
500 [% list = ['beer', 'peanuts'] %]
501 [% hash = list.hash(1) %]
502 [% hash.1 %] # beer
503 [% hash.2 %] # peanuts
504
506 In addition to the scalar virtual methods listed in the previous
507 section, you can also call any list virtual method against a scalar.
508 The item will be automagically promoted to a single element list and
509 the appropriate list virtual method will be called.
510
511 One particular benefit of this comes when calling subroutines or object
512 methods that return a list of items, rather than the preferred
513 reference to a list of items. In this case, the Template Toolkit
514 automatically folds the items returned into a list.
515
516 The upshot is that you can continue to use existing Perl modules or
517 code that returns lists of items, without having to refactor it just to
518 keep the Template Toolkit happy (by returning references to list).
519 "Class::DBI" module is just one example of a particularly useful module
520 which returns values this way.
521
522 If only a single item is returned from a subroutine then the Template
523 Toolkit assumes it meant to return a single item (rather than a list of
524 1 item) and leaves it well alone, returning the single value as it is.
525 If you're executing a database query, for example, you might get 1 item
526 returned, or perhaps many items which are then folded into a list.
527
528 The "FOREACH" directive will happily accept either a list or a single
529 item which it will treat as a list. So it's safe to write directives
530 like this, where we assume that the "something" variable is bound to a
531 subroutine which may return one or more items:
532
533 [% FOREACH item IN something %]
534 ...
535 [% END %]
536
537 The automagic promotion of scalars to single item lists means that you
538 can also use list virtual methods safely, even if you only get one item
539 returned. For example:
540
541 [% something.first %]
542 [% something.join %]
543 [% something.reverse.join(', ') %]
544
545 Note that this is very much a last-ditch behaviour. If the single item
546 return is an object with a "first" method, for example, then that will
547 be called, as expected, in preference to the list virtual method.
548
550 You can define your own virtual methods for scalars, lists and hash
551 arrays. The Template::Stash package variables $SCALAR_OPS, $LIST_OPS
552 and $HASH_OPS are references to hash arrays that define these virtual
553 methods. "HASH_OPS" and "LIST_OPS" methods are subroutines that accept
554 a hash/list reference as the first item. "SCALAR_OPS" are subroutines
555 that accept a scalar value as the first item. Any other arguments
556 specified when the method is called will be passed to the subroutine.
557
558 # load Template::Stash to make method tables visible
559 use Template::Stash;
560
561 # define list method to return new list of odd numbers only
562 $Template::Stash::LIST_OPS->{ odd } = sub {
563 my $list = shift;
564 return [ grep { $_ % 2 } @$list ];
565 };
566
567 Example template:
568
569 [% primes = [ 2, 3, 5, 7, 9 ] %]
570 [% primes.odd.join(', ') %] # 3, 5, 7, 9
571
572 TODO: document the define_vmethod() method which makes this even easier
573
574
575
576perl v5.10.1 2009-07-04 Template::Manual::VMethods(3)