Alternative syntax
Sometimes the generated content uses symbols that clashes with the default FreeMarker syntax (typically, ${...}
-s that FreeMarker should print as is, without interpretation), or you use some tool that is confused by the default FreeMarker syntax (typically by <
and >
). While usually there are tricks to work those cases around (like you can use ${'$'}{x}
to print ${x}
as is) , they are often too inconvenient. Thus, the interpolation syntax can be configured to be like [=x]
instead of ${x}
. Also, independently of that, the FreeMarker tag syntax can be configured to use []
, like in [#if x]...[/#if]
.
While both the “tag syntax” and “interpolation syntax” can be configured to use square brackets, they are totally independent configuration settings. Thus, the overall syntax can be like
[#if x]${y}[/#if]
, or like<#if x>[=y]</#if>
as well.
Square bracket tag syntax
This section is about the tag syntax, not the interpolation syntax. Don’t confuse the two, they are independent.
FreeMarker supports an alternative tag syntax, where [
and ]
is used instead of <
and >
in FreeMarker directives and comments, for example:
- Calling predefined directive:
[#list animals as animal]...[/#list]
- Calling user-defined directive:
[@myMacro /]
- Comment:
[#-- the comment --]
To use square tag syntax instead of the default one, it be enforced in the template with the ftl
directive ([#ftl]
) at the beginning of the file.
For example, this is how the template looks with the alternative syntax:
The square bracket and the default (angle bracket) syntax are mutually exclusive within a template; they can’t be mixed. If the template uses square bracket tag syntax, then things like <#if ...>
will be just static text, not FTL tags. Similarly, if the template uses the angle brackets tag syntax, things like [#if ...]
are static text, not FTL tags.
If you start the file with [#ftl ...]
(where the … stands for the optional parameters; of course [#ftl]
works too) the file will use square bracket tag syntax (but that does not change the interpolation syntax to [=...]
). Similarly, if you start the file with <#ftl ...>
the file will use the normal (angle bracket) tag syntax. If there is no ftl directive in the file, angle bracket syntax (<# ...>
) is the default one.
Square bracket interpolation syntax
This section is about the interpolation syntax, not the tag syntax. Don’t confuse the two, they are independent.
In this case instead of ${expression}
you write [=expression]
. This syntax is activated by setting ftl
directive attribute interpolation_syntax=squareBracket
It can be used both together with, and without the square bracket tag syntax, as they are technically unrelated, but it’s probably more aesthetic to use square bracket tag syntax when you use square bracket interpolation syntax:
When square bracket interpolation syntax is used, ${expression}
in the template will be just static text, which is printed as is. This is mostly useful if you generate output that should contain those, such as when generating JSP or Maven pom.xml files.