Apache FreeMarker











































FreeMarker

FreeMarker Logo.png
Developer(s)
Jonathan Revusky, Attila Szegedi, Dániel Dékány, and others
Initial release
2000

Stable release
2.3.28
/ April 4, 2018 (2018-04-04)


Written in
Java
Operating system
Cross-platform
Type
Template Engine
License
Apache License 2.0
Website
freemarker.apache.org

FreeMarker is a free Java-based Template Engine, originally focusing on dynamic web page generation with MVC software architecture. However, it is a general purpose template engine, with no dependency on servlets or HTTP or HTML, and is thus often used for generating source code, configuration files or e-mails.




Contents






  • 1 History


  • 2 Example


  • 3 See also


  • 4 External links





History


FreeMarker had a somewhat hectic history until about 2004, caused by paradigm shifts and other significant changes on multiple occasions. FreeMarker 1 (now known as FreeMarker Classic, a separate project) was originally written by Benjamin Geer and Mike Bayer.
From 2002, the new project lead was Jonathan Revusky, who released FreeMarker 2, which started a sequence of several substantial changes. The main goal of the changes was to make the template language more strict, i.e., to detect as many of the typos and other typical mistakes as possible. Also, automatic object wrapping was introduced, along with gradual advancement of the type system of the template language. The language has gained many power-user features, such as more powerful macro programming capabilities and namespaces. The language has reached a quite settled state with version 2.3, released in 2004 Q3. As of 2016, the product has remained backward compatible. No significant backward incompatible changes are expected in the FreeMarker 2 series in the future.


In late 2015, FreeMarker was granted to the Apache Software Foundation, where it has entered the Apache Incubator, and in 2018-03-21 it has become a fully accepted Apache project.



Example


The following template:


<html>
<body>
<p>Hello ${name}! You have the following messages:
<#list messages as m>
<p><b>${m.from}:</b> ${m.body}</p>
</#list>
</p>
</body>
</html>

processed by FreeMarker will produce something like:


<html>
<body>
<p>Hello Joe! You have the following messages:
<p><b>Tim:</b> Please don't forget to bring the conference papers!</p>
<p><b>Cindy:</b> Can you give me a visit this afternoon?</p>
<p><b>Richard:</b> Don't forget the papers this time!</p>
</p>
</body>
</html>

Variables like "name" and "messages" are coming from outside the template, and thus the template author has to deal with the presentation issues only. The template remains the same regardless if these variables are coming from a database or from a cookie or calculated on whatever other ways. Also the exact Java API (and hence the class) of the values can be hidden in FreeMarker using a technique called object wrapping. For example, "messages" seems to be a list or array of Java beans that have "from" and "body" properties, but it might as well be something very different, and the template is not affected (as long as a proper object wrapper is used).



See also



  • JSP

  • Apache Velocity

  • Thymeleaf



External links



  • FreeMarker

  • Online FreeMarker template tester

  • FreeMarker Classic


  • FMPP, is a FreeMarker-based text file PreProcessor


  • web-mode.el, emacs major mode for editing FreeMarker templates




Popular posts from this blog

Florida Star v. B. J. F.

Danny Elfman

Lugert, Oklahoma