File: demo-tt.pl

package info (click to toggle)
libtext-xslate-perl 3.5.9-2
  • links: PTS, VCS
  • area: main
  • in suites: sid, trixie
  • size: 2,108 kB
  • sloc: perl: 19,756; ansic: 214; pascal: 182; makefile: 9; cs: 8
file content (63 lines) | stat: -rw-r--r-- 1,343 bytes parent folder | download | duplicates (5)
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;