/
Format.pm
110 lines (77 loc) · 2.57 KB
/
Format.pm
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
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
98
99
100
101
102
103
104
105
106
107
108
109
110
#============================================================= -*-Perl-*-
#
# Template::Plugin::Format
#
# DESCRIPTION
#
# Simple Template Toolkit Plugin which creates formatting functions.
#
# AUTHOR
# Andy Wardley <abw@kfs.org>
#
# COPYRIGHT
# Copyright (C) 1996-2000 Andy Wardley. All Rights Reserved.
# Copyright (C) 1998-2000 Canon Research Centre Europe Ltd.
#
# This module is free software; you can redistribute it and/or
# modify it under the same terms as Perl itself.
#
#----------------------------------------------------------------------------
#
# $Id$
#
#============================================================================
package Template::Plugin::Format;
require 5.004;
use strict;
use vars qw( @ISA $VERSION );
use base qw( Template::Plugin );
use Template::Plugin;
$VERSION = sprintf("%d.%02d", q$Revision$ =~ /(\d+)\.(\d+)/);
sub new {
my ($class, $context, $format) = @_;;
return defined $format
? make_formatter($format)
: \&make_formatter;
}
sub make_formatter {
my $format = shift;
$format = '%s' unless defined $format;
return sub { return sprintf($format, @_); }
}
1;
__END__
#------------------------------------------------------------------------
# IMPORTANT NOTE
# This documentation is generated automatically from source
# templates. Any changes you make here may be lost.
#
# The 'docsrc' documentation source bundle is available for download
# from http://www.template-toolkit.org/docs.html and contains all
# the source templates, XML files, scripts, etc., from which the
# documentation for the Template Toolkit is built.
#------------------------------------------------------------------------
=head1 NAME
Template::Plugin::Format - Plugin to create formatting functions
=head1 SYNOPSIS
[% USE format %]
[% commented = format('# %s') %]
[% commented('The cat sat on the mat') %]
[% USE bold = format('<b>%s</b>') %]
[% bold('Hello') %]
=head1 DESCRIPTION
The format plugin constructs sub-routines which format text according to
a printf()-like format string.
=head1 AUTHOR
Andy Wardley E<lt>abw@kfs.orgE<gt>
L<http://www.andywardley.com/|http://www.andywardley.com/>
=head1 VERSION
2.24, distributed as part of the
Template Toolkit version 2.05, released on 11 September 2001.
=head1 COPYRIGHT
Copyright (C) 1996-2001 Andy Wardley. All Rights Reserved.
Copyright (C) 1998-2001 Canon Research Centre Europe Ltd.
This module is free software; you can redistribute it and/or
modify it under the same terms as Perl itself.
=head1 SEE ALSO
L<Template::Plugin|Template::Plugin>