NAME Template::Plugin::ListMoreUtils - TT2 plugin to use List::MoreUtils SYNOPSIS [% my1to9even = [ 2, 4, 6, 8 ]; my1to9prim = [ 2, 3, 5, 7 ]; my1to9odd = [ 1, 3, 5, 7, 9 ]; %] [% USE ListMoreUtils %] [% my1to9all = ListMoreUtils.uniq( my1to9even.merge( my1to9prim, my1to9odd ) ); %] 1 .. 9 are [% my1to9all.size() %] DESCRIPTION This module provides an Template::Toolkit interface to Tassilo von Parseval's List::MoreUtils. It extends the built-in functions dealing with lists as well as Template::Plugin::ListUtil. USAGE To use this module from templates, you can choose between class interface [% my1to9even = [ 2, 4, 6, 8 ]; my1to9prim = [ 2, 3, 5, 7 ]; my1to9odd = [ 1, 3, 5, 7, 9 ]; %] [% USE ListMoreUtils %] [% my1to9all = ListMoreUtils.uniq( my1to9even.merge( my1to9prim, my1to9odd ) ); %] 1 .. 9 are [% my1to9all.size() %] or the virtual method interface, which is described in Template::Plugin::ListMoreUtilsVMethods. FUNCTIONS PROVIDED All functions behave as documented in List::MoreUtils. I don't plan to copy the entire POD from there. Template::Toolkit provides lists as list reference, so they were expanded before the appropriate function in "List::MoreUtils" is called. any BLOCK LIST all BLOCK LIST none BLOCK LIST notall BLOCK LIST true BLOCK LIST false BLOCK LIST firstidx BLOCK LIST first_index BLOCK LIST lastidx BLOCK LIST last_index BLOCK LIST insert_after BLOCK VALUE LIST insert_after_string STRING VALUE LIST apply BLOCK LIST after BLOCK LIST after_incl BLOCK LIST before BLOCK LIST before_incl BLOCK LIST indexes BLOCK LIST firstval BLOCK LIST first_value BLOCK LIST lastval BLOCK LIST last_value BLOCK LIST pairwise BLOCK LIST LIST Unlike the original "pairwise", both variables are given through @_. Template::Toolkit uses eval to evaluate the perl code declared there and passes neither $a nor $b (which sounds reasonable to me). minmax LIST uniq LIST mesh zip part BLOCK LIST bsearch BLOCK LIST This function is available only when List::MoreUtils 0.23 or newer is used. Unlike the original "bsearch", the value to compare with is passed in $_[0]. Template::Toolkit uses eval to evaluate the perl code declared there and don't pass $_ (which sounds reasonable to me). INSTALL To install this module, use perl Build.PL ./Build ./Build test ./Build install LIMITATION Except the typical limitations known from perl functions embedded in Template::Toolkit, the only limitation I currently miss is being able to use TT2 defined macros as callback. SUPPORT Free support can be requested via regular CPAN bug-tracking system. There is no guaranteed reaction time or solution time. It depends on business load. That doesn't mean that ticket via rt aren't handles as soon as possible, that means that soon depends on how much I have to do. Business and commercial support should be aquired via preferred freelancer agencies. AUTHOR Jens Rehsack CPAN ID: REHSACK rehsack@cpan.org http://search.cpan.org/~rehsack/ COPYRIGHT This program is free software; you can redistribute it and/or modify it under the same terms as Perl itself. The full text of the license can be found in the LICENSE file included with this module. SEE ALSO perl(1), List::MoreUtils, <Template::Plugin::ListUtil>