NAME Template::Plugin::Number::Format - Plugin/filter interface to Number::Format SYNOPSIS [% USE Number.Format %] [% num | format_number %] ABSTRACT Template::Plugin::Number::Format makes the number-munging grooviness of Number::Format available to your templates. It is used like a plugin, but installs filters into the current context. DESCRIPTION All filters created by Template::Plugin::Number::Format can be configured by constructor options and options that can be passed to individual filters. See "METHODS" in Number::Format for all the details. Constructor Parameters The USE line accepts the following parameters, all optional, which define the default behavior for filters within the current Context: THOUSANDS_SEP character inserted between groups of 3 digits DECIMAL_POINT character separating integer and fractional parts MON_THOUSANDS_SEP like THOUSANDS_SEP, but used for format_price MON_DECIMAL_POINT like DECIMAL_POINT, but used for format_price INT_CURR_SYMBOL character(s) denoting currency (see format_price()) DECIMAL_DIGITS number of digits to the right of dec point (def 2) DECIMAL_FILL boolean; whether to add zeroes to fill out decimal NEG_FORMAT format to display negative numbers (def -x) KILO_SUFFIX suffix to add when format_bytes formats kilobytes MEGA_SUFFIX suffix to add when format_bytes formats megabytes GIGA_SUFFIX suffix to add when format_bytes formats gigabytes Using Template::Plugin::Number::Format When you invoke: [% USE Number.Format(option = value) %] the following filters are installed into the current Context: round($precision) Rounds the number to the specified precision. If "$precision" is omitted, the value of the "DECIMAL_DIGITS" parameter is used (default value 2). format_number($precision, $trailing_zeros) Formats a number by adding "THOUSANDS_SEP" between each set of 3 digits to the left of the decimal point, substituting "DECIMAL_POINT" for the decimal point, and rounding to the specified precision using "round()". Note that "$precision" is a maximum precision specifier; trailing zeroes will only appear in the output if "$trailing_zeroes" is provided, or the parameter "DECIMAL_FILL" is set, with a value that is true (not zero, undef, or the empty string). If "$precision" is omitted, the value of the "DECIMAL_DIGITS" parameter (default value of 2) is used. format_negative($picture) Formats a negative number. Picture should be a string that contains the letter "x" where the number should be inserted. For example, for standard negative numbers you might use "-x", while for accounting purposes you might use "(x)". If the specified number begins with a - character, that will be removed before formatting, but formatting will occur whether or not the number is negative. format_picture($picture) Returns a string based on "$picture" with the "#" characters replaced by digits from "$number". If the length of the integer part of $number is too large to fit, the "#" characters are replaced with asterisks ("*") instead. format_price($precision) Returns a string containing "$number" formatted similarly to "format_number()", except that the decimal portion may have trailing zeroes added to make it be exactly "$precision" characters long, and the currency string will be prefixed. If the "INT_CURR_SYMBOL" attribute of the object is the empty string, no currency will be added. If "$precision" is not provided, the default of 2 will be used. format_bytes($precision) Returns a string containing "$number" formatted similarly to "format_number()", except that if the number is over 1024, it will be divided by 1024 and the value of KILO_SUFFIX appended to the end; or if it is over 1048576 (1024*1024), it will be divided by 1048576 and MEGA_SUFFIX appended to the end. Negative values will result in an error. If "$precision" is not provided, the default of 2 will be used. unformat_number Converts a string as returned by "format_number()", "format_price()", or "format_picture()", and returns the corresponding value as a numeric scalar. Returns "undef" if the number does not contain any digits. SEE ALSO Template, Number::Format AUTHOR darren chamberlain <darren@cpan.org>