1 2 3 4 5 6 7 8 9 10 11 12 13 14 15 16 17 18 19 20 21 22 23 24 25 26 27 28 29 30 31 32 33 34 35 36 37 38 39 40 41 42 43 44 45 46 47 48 49 50 51 52 53 54 55 56 57 58 59 60 61 62 63
|
#!perl -w
use strict;
use Text::Xslate;
use Template;
use Time::HiRes qw(time);
use FindBin qw($Bin);
use Config; printf "Perl/%vd %s\n", $^V, $Config{archname};
foreach my $mod(qw(Text::Xslate Template)){
print $mod, '/', $mod->VERSION, "\n";
}
my $file = 'list.tt';
my $tt = Template->new(
INCLUDE_PATH => ["$Bin/template"],
COMPILE_EXT => '.out',
);
my $tx = Text::Xslate->new(
syntax => 'TTerse',
path => ["$Bin/template"],
cache_dir => '.xslate_cache',
cache => 2,
);
my %vars = (
data => [
({ title => 'Programming Perl'}) x 100,
]
);
{
my $out;
$tt->process($file, \%vars, \$out);
$tx->render($file, \%vars) eq $out
or die $tx->render($file, \%vars), "\n", $out;
}
$| = 1;
print "Template-Toolkit's process() x 1000\n";
my $start = time();
foreach (1 .. 1000) {
print $_, "\r";
$tt->process($file, \%vars, \my $out);
}
print "\n";
my $tt_used = time() - $start;
printf "Used: %.03f sec.\n", $tt_used;
print "Text::Xslate's render() x 1000\n";
$start = time();
foreach (1 .. 1000) {
print $_, "\r";
my $out = $tx->render($file, \%vars);
}
print "\n";
my $tx_used = time() - $start;
printf "Used: %.03f sec.\n", $tx_used;
printf "In this benchmark, Xslate is about %.01f times faster than Template-Tookit.\n",
$tt_used / $tx_used;
|