setting
Synopsis
Where:
- name: name of the setting. It is not expression!
- value: New value of the setting. Expression.
Description
Sets a setting for the further part of processing. Settings are values that influence the behavior of FreeMarker. The new value will be present only in the template processing where it was set, and does not touch the template itself.
The supported settings are:
-
locale
: The locale (language) of the output. It can influence the presentation format of numbers, dates, etc. The value is a string which consist of a language code (lowercase two-letter ISO-639 code) plus optional county code (uppercase two-letterISO-3166
code) separated from the language code with underscore, and if we have specified the country then an optional variant code (not standardized) separated from the country with underscore. Examples of valid values:en
,en_US
, en_US_MAC. FreeMarker will try to use the most specific available locale, so if you specifyen_US_MAC
but that is not known, then it will tryen_US
, and thenen
, and then the default locale. -
number_format
: The number format that is used to convert numbers to strings when no explicit format is specified. Can be one of the following:-
Predefined values defined by the Java platform:
number
(the default),currency
, orpercent
-
computer
, which formats like the c built-in -
Format pattern written in Java decimal number format syntax, for example
0.###
. FreeMarker extends this format to allow specifying rounding mode, symbols used, etc. -
Values starting with
@
that’s also followed by a letter, refer to a custom format. For example,"@price"
refers to the custom format registered with the"price"
name. The custom format name is possibly followed by space or _ and then format parameters, whose interpretation depends on the custom format. For backward compatibility, the initial @ only has this new meaning if either the incompatible_improvements setting is at least 2.3.24, or there’s any custom formats defined. When the initial@
isn’t followed by a letter (any UNICODE letter), it’s never treated as a reference to a custom format.
-
-
boolean_format
: The comma-separated pair of strings for representing true and false values respectively that is used to convert booleans to strings when no explicit format is specified (like in${booleanValue}
). Note that currently white space isn’t removed from this string, so don’t put space after the comma. Default value is"true,false"
, but FreeMarker will deny using that particular value for${booleanValue}
, and requires using${booleanValue?c}
instead. For any other value, like"Y,N"
,${booleanValue}
will work. See also:string
built-in. -
date_format
,time_format
,datetime_format
: The format used to convert date/time/date-time values to strings when no explicit format is specified via the [string
built-in] (or otherwise), as in the case of${someDate}
. Thedate_format
setting only effects the formatting of date values that store no time part,time_format
only effects the formatting of times that store no date part, anddatetime_format
only effects formatting of date-time values. These settings also effects what format do?time
,?date
, and?datetime
expect when it’s applied on a string value.The possible setting values are (the quotation marks aren’t part of the value itself):
-
Patterns accepted by Java’s SimpleDateFormat, for example
"dd.MM.yyyy HH:mm:ss"
(where"HH"
means 0-23 hours) or"MM/dd/yyyy hh:mm:ss a"
(where"a"
prints AM or PM, if the current language is English).Be careful not to use
YYYY
(upper case, means “week year”) instead ofyyyy
(lower case, means year)! It’s an easy mistake to do, and hard to notice during testing, as “week year” only differs from “year” near the edge of years. -
"xs"
for XML Schema format, or “iso” for ISO 8601:2004 format. These formats allow various additional options, separated with space, like in"iso m nz"
(or with_
, like in"iso_m_nz"
; this is useful in a case likelastModified?string.iso_m_nz
). The options and their meanings are:-
Accuracy options:
ms
: Milliseconds, always shown with all 3 digits, even if it’s all 0-s. Example:13:45:05.800
s
: Seconds (fraction seconds are dropped even if non-0), like13:45:05
m
: Minutes, like13:45
. This isn’t allowed for"xs"
.h
: Hours, like13
. This isn’t allowed for"xs"
.- Neither: Up to millisecond accuracy, but trailing millisecond 0-s are removed, also the whole milliseconds part if it would be 0 otherwise. Example:
13:45:05.8
-
Time zone offset visibility options:
fz
: “Force Zone”, always show time zone offset. But, because ISO 8601 doesn’t allow for dates (means date without time of the day) to show the zone offset, this option will have no effect in the case of"iso"
with dates.nz
: “No Zone”, never show time zone offset- Neither: Always show time zone offset, and for “iso” date values.
-
Time zone options:
u
: Use UTC instead of what thetime_zone
setting suggests.fu
: “Force UTC”, that is, use UTC instead of what thetime_zone
setting suggests.- Neither: Use the time zone suggested by the
time_zone
configuration setting
Options from the same category are mutually exclusive, like using
m
ands
together is an error.The options can be specified in any order.
The accuracy and time zone offset visibility options don’t influence parsing, only formatting. For example, even if you use
"iso m nz"
,"2012-01-01T15:30:05.125+01"
will be parsed successfully and with milliseconds accuracy. The time zone options (like"u"
) influence what time zone is chosen only when parsing a string that doesn’t contain time zone offset.Parsing with
"iso"
understands both “extend format” and “basic format”, like20141225T235018
. It doesn’t, however, support the parsing of all kind of ISO 8601 strings: if there’s a date part, it must use year, month and day of the month values (not week of the year), and the day can’t be omitted.The output of
"iso"
is deliberately so that it’s also a good representation of the value with XML Schema format, except for 0 and negative years, where it’s impossible. Also note that the time zone offset is omitted for date values in the"iso"
format, while it’s preserved for the"xs"
format. -
-
"short"
,"medium"
,"long"
, or"full"
, which has locale-dependent meaning defined by the Java platform. For date-time values, you can specify the length of the date and time part independently, be separating them with_
, like"short_medium"
. ("medium"
means"medium_medium"
for date-time values.)
-
-
time_zone: The name of the time zone used to format times for display. Can be any value that is accepted by Java TimeZone API. Examples:
"GMT"
,"GMT+2"
,"GMT-1:30"
,"CET"
,"PST"
,"America/Los_Angeles"
.
output_encoding
: Tells FreeMarker what the charset of the output is. As FreeMarker outputs a stream of UNICODE characters, it’s not affected by the output encoding, but some macros/functions and built-ins may want to use this information.
Example: Assume that the initial locale of template is de_DE
(German). Then this:
will output this:
because German people use the comma as their decimal separator, while US people use the dot.