http://git-wip-us.apache.org/repos/asf/freemarker-site/blob/a4a53cb9/builds/2.3.28-voting/documentation/api/freemarker/cache/TemplateNameFormat.html
----------------------------------------------------------------------
diff --git 
a/builds/2.3.28-voting/documentation/api/freemarker/cache/TemplateNameFormat.html
 
b/builds/2.3.28-voting/documentation/api/freemarker/cache/TemplateNameFormat.html
deleted file mode 100644
index 8b801bb..0000000
--- 
a/builds/2.3.28-voting/documentation/api/freemarker/cache/TemplateNameFormat.html
+++ /dev/null
@@ -1,319 +0,0 @@
-<!DOCTYPE HTML PUBLIC "-//W3C//DTD HTML 4.01 Transitional//EN" 
"http://www.w3.org/TR/html4/loose.dtd";>
-<!-- NewPage -->
-<html lang="en">
-<head>
-<!-- Generated by javadoc (1.8.0_144) on Fri Mar 30 23:10:42 CEST 2018 -->
-<meta http-equiv="Content-Type" content="text/html; charset=UTF-8">
-<title>TemplateNameFormat (FreeMarker 2.3.28 API)</title>
-<meta name="date" content="2018-03-30">
-<link rel="stylesheet" type="text/css" href="../../stylesheet.css" 
title="Style">
-<script type="text/javascript" src="../../script.js"></script>
-</head>
-<body>
-<script type="text/javascript"><!--
-    try {
-        if (location.href.indexOf('is-external=true') == -1) {
-            parent.document.title="TemplateNameFormat (FreeMarker 2.3.28 API)";
-        }
-    }
-    catch(err) {
-    }
-//-->
-</script>
-<noscript>
-<div>JavaScript is disabled on your browser.</div>
-</noscript>
-<!-- ========= START OF TOP NAVBAR ======= -->
-<div class="topNav"><a name="navbar.top">
-<!--   -->
-</a>
-<div class="skipNav"><a href="#skip.navbar.top" title="Skip navigation 
links">Skip navigation links</a></div>
-<a name="navbar.top.firstrow">
-<!--   -->
-</a>
-<ul class="navList" title="Navigation">
-<li><a href="../../overview-summary.html">Overview</a></li>
-<li><a href="package-summary.html">Package</a></li>
-<li class="navBarCell1Rev">Class</li>
-<li><a href="class-use/TemplateNameFormat.html">Use</a></li>
-<li><a href="package-tree.html">Tree</a></li>
-<li><a href="../../deprecated-list.html">Deprecated</a></li>
-<li><a href="../../index-all.html">Index</a></li>
-<li><a href="../../help-doc.html">Help</a></li>
-</ul>
-</div>
-<div class="subNav">
-<ul class="navList">
-<li><a href="../../freemarker/cache/TemplateLookupStrategy.html" title="class 
in freemarker.cache"><span class="typeNameLink">Prev&nbsp;Class</span></a></li>
-<li><a href="../../freemarker/cache/TemplateSourceMatcher.html" title="class 
in freemarker.cache"><span class="typeNameLink">Next&nbsp;Class</span></a></li>
-</ul>
-<ul class="navList">
-<li><a href="../../index.html?freemarker/cache/TemplateNameFormat.html" 
target="_top">Frames</a></li>
-<li><a href="TemplateNameFormat.html" target="_top">No&nbsp;Frames</a></li>
-</ul>
-<ul class="navList" id="allclasses_navbar_top">
-<li><a href="../../allclasses-noframe.html">All&nbsp;Classes</a></li>
-</ul>
-<div>
-<script type="text/javascript"><!--
-  allClassesLink = document.getElementById("allclasses_navbar_top");
-  if(window==top) {
-    allClassesLink.style.display = "block";
-  }
-  else {
-    allClassesLink.style.display = "none";
-  }
-  //-->
-</script>
-</div>
-<div>
-<ul class="subNavList">
-<li>Summary:&nbsp;</li>
-<li>Nested&nbsp;|&nbsp;</li>
-<li><a href="#field.summary">Field</a>&nbsp;|&nbsp;</li>
-<li>Constr&nbsp;|&nbsp;</li>
-<li><a href="#methods.inherited.from.class.java.lang.Object">Method</a></li>
-</ul>
-<ul class="subNavList">
-<li>Detail:&nbsp;</li>
-<li><a href="#field.detail">Field</a>&nbsp;|&nbsp;</li>
-<li>Constr&nbsp;|&nbsp;</li>
-<li>Method</li>
-</ul>
-</div>
-<a name="skip.navbar.top">
-<!--   -->
-</a></div>
-<!-- ========= END OF TOP NAVBAR ========= -->
-<!-- ======== START OF CLASS DATA ======== -->
-<div class="header">
-<div class="subTitle">freemarker.cache</div>
-<h2 title="Class TemplateNameFormat" class="title">Class 
TemplateNameFormat</h2>
-</div>
-<div class="contentContainer">
-<ul class="inheritance">
-<li>java.lang.Object</li>
-<li>
-<ul class="inheritance">
-<li>freemarker.cache.TemplateNameFormat</li>
-</ul>
-</li>
-</ul>
-<div class="description">
-<ul class="blockList">
-<li class="blockList">
-<hr>
-<br>
-<pre>public abstract class <span 
class="typeNameLabel">TemplateNameFormat</span>
-extends java.lang.Object</pre>
-<div class="block">Symbolizes a template name format, which defines the basic 
syntax of names through algorithms such as normalization.
- The API of this class isn't exposed as it's too immature, so custom template 
name formats aren't possible yet.</div>
-<dl>
-<dt><span class="simpleTagLabel">Since:</span></dt>
-<dd>2.3.22</dd>
-</dl>
-</li>
-</ul>
-</div>
-<div class="summary">
-<ul class="blockList">
-<li class="blockList">
-<!-- =========== FIELD SUMMARY =========== -->
-<ul class="blockList">
-<li class="blockList"><a name="field.summary">
-<!--   -->
-</a>
-<h3>Field Summary</h3>
-<table class="memberSummary" border="0" cellpadding="3" cellspacing="0" 
summary="Field Summary table, listing fields, and an explanation">
-<caption><span>Fields</span><span class="tabEnd">&nbsp;</span></caption>
-<tr>
-<th class="colFirst" scope="col">Modifier and Type</th>
-<th class="colLast" scope="col">Field and Description</th>
-</tr>
-<tr class="altColor">
-<td class="colFirst"><code>static <a 
href="../../freemarker/cache/TemplateNameFormat.html" title="class in 
freemarker.cache">TemplateNameFormat</a></code></td>
-<td class="colLast"><code><span class="memberNameLink"><a 
href="../../freemarker/cache/TemplateNameFormat.html#DEFAULT_2_3_0">DEFAULT_2_3_0</a></span></code>
-<div class="block">The default template name format when <a 
href="../../freemarker/template/Configuration.html#Configuration-freemarker.template.Version-"><code>incompatible_improvements</code></a>
 is
- below 2.4.0.</div>
-</td>
-</tr>
-<tr class="rowColor">
-<td class="colFirst"><code>static <a 
href="../../freemarker/cache/TemplateNameFormat.html" title="class in 
freemarker.cache">TemplateNameFormat</a></code></td>
-<td class="colLast"><code><span class="memberNameLink"><a 
href="../../freemarker/cache/TemplateNameFormat.html#DEFAULT_2_4_0">DEFAULT_2_4_0</a></span></code>
-<div class="block">The default template name format only when <a 
href="../../freemarker/template/Configuration.html#Configuration-freemarker.template.Version-"><code>incompatible_improvements</code></a>
- is set to 2.4.0 (or higher).</div>
-</td>
-</tr>
-</table>
-</li>
-</ul>
-<!-- ========== METHOD SUMMARY =========== -->
-<ul class="blockList">
-<li class="blockList"><a name="method.summary">
-<!--   -->
-</a>
-<h3>Method Summary</h3>
-<ul class="blockList">
-<li class="blockList"><a name="methods.inherited.from.class.java.lang.Object">
-<!--   -->
-</a>
-<h3>Methods inherited from class&nbsp;java.lang.Object</h3>
-<code>clone, equals, finalize, getClass, hashCode, notify, notifyAll, 
toString, wait, wait, wait</code></li>
-</ul>
-</li>
-</ul>
-</li>
-</ul>
-</div>
-<div class="details">
-<ul class="blockList">
-<li class="blockList">
-<!-- ============ FIELD DETAIL =========== -->
-<ul class="blockList">
-<li class="blockList"><a name="field.detail">
-<!--   -->
-</a>
-<h3>Field Detail</h3>
-<a name="DEFAULT_2_3_0">
-<!--   -->
-</a>
-<ul class="blockList">
-<li class="blockList">
-<h4>DEFAULT_2_3_0</h4>
-<pre>public static final&nbsp;<a 
href="../../freemarker/cache/TemplateNameFormat.html" title="class in 
freemarker.cache">TemplateNameFormat</a> DEFAULT_2_3_0</pre>
-<div class="block">The default template name format when <a 
href="../../freemarker/template/Configuration.html#Configuration-freemarker.template.Version-"><code>incompatible_improvements</code></a>
 is
- below 2.4.0. As of FreeMarker 2.4.0, the default 
<code>incompatible_improvements</code> is still <code>2.3.0</code>, and it
- will certainly remain so for a very long time. In new projects it's highly 
recommended to use
- <a 
href="../../freemarker/cache/TemplateNameFormat.html#DEFAULT_2_4_0"><code>DEFAULT_2_4_0</code></a>
 instead.</div>
-</li>
-</ul>
-<a name="DEFAULT_2_4_0">
-<!--   -->
-</a>
-<ul class="blockListLast">
-<li class="blockList">
-<h4>DEFAULT_2_4_0</h4>
-<pre>public static final&nbsp;<a 
href="../../freemarker/cache/TemplateNameFormat.html" title="class in 
freemarker.cache">TemplateNameFormat</a> DEFAULT_2_4_0</pre>
-<div class="block">The default template name format only when <a 
href="../../freemarker/template/Configuration.html#Configuration-freemarker.template.Version-"><code>incompatible_improvements</code></a>
- is set to 2.4.0 (or higher). This is not the out-of-the-box default format of 
FreeMarker 2.4.x, because the
- default <code>incompatible_improvements</code> is still 2.3.0 there.
- 
- <p>
- Differences to the <a 
href="../../freemarker/cache/TemplateNameFormat.html#DEFAULT_2_3_0"><code>DEFAULT_2_3_0</code></a>
 format:
- 
- <ul>
- 
- <li>The scheme and the path need not be separated with <code>"://"</code> 
anymore, only with <code>":"</code>. This makes
- template names like <code>"classpath:foo.ftl"</code> interpreted as an 
absolute name with scheme <code>"classpath"</code>
- and absolute path "foo.ftl". The scheme name before the <code>":"</code> 
can't contain <code>"/"</code>, or else it's
- treated as a malformed name. The scheme part can be separated either with 
<code>"://"</code> or just <code>":"</code> from
- the path. Hence, <code>myscheme:/x</code> is normalized to 
<code>myscheme:x</code>, while <code>myscheme:///x</code> is
- normalized to <code>myscheme://x</code>, but <code>myscehme://x</code> or 
<code>myscheme:/x</code> aren't changed by
- normalization. It's up the <a 
href="../../freemarker/cache/TemplateLoader.html" title="interface in 
freemarker.cache"><code>TemplateLoader</code></a> to which the normalized names 
are passed to decide which of
- these scheme separation conventions are valid (maybe both).</li>
- 
- <li><code>":"</code> is not allowed in template names, except as the scheme 
separator (see previous point).
- 
- <li>Malformed paths throw <a 
href="../../freemarker/template/MalformedTemplateNameException.html" 
title="class in 
freemarker.template"><code>MalformedTemplateNameException</code></a> instead of 
acting like if the template wasn't
- found.
- 
- <li><code>"\"</code> (backslash) is not allowed in template names, and causes 
<a href="../../freemarker/template/MalformedTemplateNameException.html" 
title="class in 
freemarker.template"><code>MalformedTemplateNameException</code></a>.
- With <a 
href="../../freemarker/cache/TemplateNameFormat.html#DEFAULT_2_3_0"><code>DEFAULT_2_3_0</code></a>
 you would certainly end up with a <a 
href="../../freemarker/template/TemplateNotFoundException.html" title="class in 
freemarker.template"><code>TemplateNotFoundException</code></a> (or worse,
- it would work, but steps like <code>".."</code> wouldn't be normalized by 
FreeMarker).
- 
- <li>Template names might end with <code>/</code>, like <code>"foo/"</code>, 
and the presence or lack of the terminating
- <code>/</code> is seen as significant. While their actual interpretation is 
up to the <a href="../../freemarker/cache/TemplateLoader.html" title="interface 
in freemarker.cache"><code>TemplateLoader</code></a>,
- operations that manipulate template names assume that the last step refers to 
a "directory" as opposed to a
- "file" exactly if the terminating <code>/</code> is present. Except, the 
empty name is assumed to refer to the root
- "directory" (despite that it doesn't end with <code>/</code>).
-
- <li><code>//</code> is normalized to <code>/</code>, except of course if it's 
in the scheme name terminator. Like
- <code>foo//bar///baaz.ftl</code> is normalized to 
<code>foo/bar/baaz.ftl</code>. (In general, 0 long step names aren't
- possible anymore.)</li>
- 
- <li>The <code>".."</code> bugs of the legacy normalizer are fixed: 
<code>".."</code> steps has removed the preceding
- <code>"."</code> or <code>"*"</code> or scheme steps, not treating them 
specially as they should be. Now these work as
- expected. Examples: <code>"a/./../c"</code> has become to <code>"a/c"</code>, 
now it will be <code>"c"</code>; <code>"a/b/*</code>
- <code>/../c"</code> has become to <code>"a/b/c"</code>, now it will be 
<code>"a/*</code><code>/c"</code>; <code>"scheme://.."</code> has
- become to <code>"scheme:/"</code>, now it will be <code>null</code> (<a 
href="../../freemarker/template/TemplateNotFoundException.html" title="class in 
freemarker.template"><code>TemplateNotFoundException</code></a>) for backing 
out of
- the root directory.</li>
- 
- <li>As now directory paths has to be handled as well, it recognizes 
terminating, leading, and lonely <code>".."</code>
- and <code>"."</code> steps. For example, <code>"foo/bar/.."</code> now 
becomes to <code>"foo/"</code></li>
- 
- <li>Multiple consecutive <code>*</code> steps are normalized to one</li>
- 
- </ul></div>
-</li>
-</ul>
-</li>
-</ul>
-</li>
-</ul>
-</div>
-</div>
-<!-- ========= END OF CLASS DATA ========= -->
-<!-- ======= START OF BOTTOM NAVBAR ====== -->
-<div class="bottomNav"><a name="navbar.bottom">
-<!--   -->
-</a>
-<div class="skipNav"><a href="#skip.navbar.bottom" title="Skip navigation 
links">Skip navigation links</a></div>
-<a name="navbar.bottom.firstrow">
-<!--   -->
-</a>
-<ul class="navList" title="Navigation">
-<li><a href="../../overview-summary.html">Overview</a></li>
-<li><a href="package-summary.html">Package</a></li>
-<li class="navBarCell1Rev">Class</li>
-<li><a href="class-use/TemplateNameFormat.html">Use</a></li>
-<li><a href="package-tree.html">Tree</a></li>
-<li><a href="../../deprecated-list.html">Deprecated</a></li>
-<li><a href="../../index-all.html">Index</a></li>
-<li><a href="../../help-doc.html">Help</a></li>
-</ul>
-</div>
-<div class="subNav">
-<ul class="navList">
-<li><a href="../../freemarker/cache/TemplateLookupStrategy.html" title="class 
in freemarker.cache"><span class="typeNameLink">Prev&nbsp;Class</span></a></li>
-<li><a href="../../freemarker/cache/TemplateSourceMatcher.html" title="class 
in freemarker.cache"><span class="typeNameLink">Next&nbsp;Class</span></a></li>
-</ul>
-<ul class="navList">
-<li><a href="../../index.html?freemarker/cache/TemplateNameFormat.html" 
target="_top">Frames</a></li>
-<li><a href="TemplateNameFormat.html" target="_top">No&nbsp;Frames</a></li>
-</ul>
-<ul class="navList" id="allclasses_navbar_bottom">
-<li><a href="../../allclasses-noframe.html">All&nbsp;Classes</a></li>
-</ul>
-<div>
-<script type="text/javascript"><!--
-  allClassesLink = document.getElementById("allclasses_navbar_bottom");
-  if(window==top) {
-    allClassesLink.style.display = "block";
-  }
-  else {
-    allClassesLink.style.display = "none";
-  }
-  //-->
-</script>
-</div>
-<div>
-<ul class="subNavList">
-<li>Summary:&nbsp;</li>
-<li>Nested&nbsp;|&nbsp;</li>
-<li><a href="#field.summary">Field</a>&nbsp;|&nbsp;</li>
-<li>Constr&nbsp;|&nbsp;</li>
-<li><a href="#methods.inherited.from.class.java.lang.Object">Method</a></li>
-</ul>
-<ul class="subNavList">
-<li>Detail:&nbsp;</li>
-<li><a href="#field.detail">Field</a>&nbsp;|&nbsp;</li>
-<li>Constr&nbsp;|&nbsp;</li>
-<li>Method</li>
-</ul>
-</div>
-<a name="skip.navbar.bottom">
-<!--   -->
-</a></div>
-<!-- ======== END OF BOTTOM NAVBAR ======= -->
-</body>
-</html>

http://git-wip-us.apache.org/repos/asf/freemarker-site/blob/a4a53cb9/builds/2.3.28-voting/documentation/api/freemarker/cache/TemplateSourceMatcher.html
----------------------------------------------------------------------
diff --git 
a/builds/2.3.28-voting/documentation/api/freemarker/cache/TemplateSourceMatcher.html
 
b/builds/2.3.28-voting/documentation/api/freemarker/cache/TemplateSourceMatcher.html
deleted file mode 100644
index a2d3051..0000000
--- 
a/builds/2.3.28-voting/documentation/api/freemarker/cache/TemplateSourceMatcher.html
+++ /dev/null
@@ -1,246 +0,0 @@
-<!DOCTYPE HTML PUBLIC "-//W3C//DTD HTML 4.01 Transitional//EN" 
"http://www.w3.org/TR/html4/loose.dtd";>
-<!-- NewPage -->
-<html lang="en">
-<head>
-<!-- Generated by javadoc (1.8.0_144) on Fri Mar 30 23:10:42 CEST 2018 -->
-<meta http-equiv="Content-Type" content="text/html; charset=UTF-8">
-<title>TemplateSourceMatcher (FreeMarker 2.3.28 API)</title>
-<meta name="date" content="2018-03-30">
-<link rel="stylesheet" type="text/css" href="../../stylesheet.css" 
title="Style">
-<script type="text/javascript" src="../../script.js"></script>
-</head>
-<body>
-<script type="text/javascript"><!--
-    try {
-        if (location.href.indexOf('is-external=true') == -1) {
-            parent.document.title="TemplateSourceMatcher (FreeMarker 2.3.28 
API)";
-        }
-    }
-    catch(err) {
-    }
-//-->
-</script>
-<noscript>
-<div>JavaScript is disabled on your browser.</div>
-</noscript>
-<!-- ========= START OF TOP NAVBAR ======= -->
-<div class="topNav"><a name="navbar.top">
-<!--   -->
-</a>
-<div class="skipNav"><a href="#skip.navbar.top" title="Skip navigation 
links">Skip navigation links</a></div>
-<a name="navbar.top.firstrow">
-<!--   -->
-</a>
-<ul class="navList" title="Navigation">
-<li><a href="../../overview-summary.html">Overview</a></li>
-<li><a href="package-summary.html">Package</a></li>
-<li class="navBarCell1Rev">Class</li>
-<li><a href="class-use/TemplateSourceMatcher.html">Use</a></li>
-<li><a href="package-tree.html">Tree</a></li>
-<li><a href="../../deprecated-list.html">Deprecated</a></li>
-<li><a href="../../index-all.html">Index</a></li>
-<li><a href="../../help-doc.html">Help</a></li>
-</ul>
-</div>
-<div class="subNav">
-<ul class="navList">
-<li><a href="../../freemarker/cache/TemplateNameFormat.html" title="class in 
freemarker.cache"><span class="typeNameLink">Prev&nbsp;Class</span></a></li>
-<li><a href="../../freemarker/cache/URLTemplateLoader.html" title="class in 
freemarker.cache"><span class="typeNameLink">Next&nbsp;Class</span></a></li>
-</ul>
-<ul class="navList">
-<li><a href="../../index.html?freemarker/cache/TemplateSourceMatcher.html" 
target="_top">Frames</a></li>
-<li><a href="TemplateSourceMatcher.html" target="_top">No&nbsp;Frames</a></li>
-</ul>
-<ul class="navList" id="allclasses_navbar_top">
-<li><a href="../../allclasses-noframe.html">All&nbsp;Classes</a></li>
-</ul>
-<div>
-<script type="text/javascript"><!--
-  allClassesLink = document.getElementById("allclasses_navbar_top");
-  if(window==top) {
-    allClassesLink.style.display = "block";
-  }
-  else {
-    allClassesLink.style.display = "none";
-  }
-  //-->
-</script>
-</div>
-<div>
-<ul class="subNavList">
-<li>Summary:&nbsp;</li>
-<li>Nested&nbsp;|&nbsp;</li>
-<li>Field&nbsp;|&nbsp;</li>
-<li><a href="#constructor.summary">Constr</a>&nbsp;|&nbsp;</li>
-<li><a href="#methods.inherited.from.class.java.lang.Object">Method</a></li>
-</ul>
-<ul class="subNavList">
-<li>Detail:&nbsp;</li>
-<li>Field&nbsp;|&nbsp;</li>
-<li><a href="#constructor.detail">Constr</a>&nbsp;|&nbsp;</li>
-<li>Method</li>
-</ul>
-</div>
-<a name="skip.navbar.top">
-<!--   -->
-</a></div>
-<!-- ========= END OF TOP NAVBAR ========= -->
-<!-- ======== START OF CLASS DATA ======== -->
-<div class="header">
-<div class="subTitle">freemarker.cache</div>
-<h2 title="Class TemplateSourceMatcher" class="title">Class 
TemplateSourceMatcher</h2>
-</div>
-<div class="contentContainer">
-<ul class="inheritance">
-<li>java.lang.Object</li>
-<li>
-<ul class="inheritance">
-<li>freemarker.cache.TemplateSourceMatcher</li>
-</ul>
-</li>
-</ul>
-<div class="description">
-<ul class="blockList">
-<li class="blockList">
-<dl>
-<dt>Direct Known Subclasses:</dt>
-<dd><a href="../../freemarker/cache/AndMatcher.html" title="class in 
freemarker.cache">AndMatcher</a>, <a 
href="../../freemarker/cache/FileExtensionMatcher.html" title="class in 
freemarker.cache">FileExtensionMatcher</a>, <a 
href="../../freemarker/cache/FileNameGlobMatcher.html" title="class in 
freemarker.cache">FileNameGlobMatcher</a>, <a 
href="../../freemarker/cache/NotMatcher.html" title="class in 
freemarker.cache">NotMatcher</a>, <a 
href="../../freemarker/cache/OrMatcher.html" title="class in 
freemarker.cache">OrMatcher</a>, <a 
href="../../freemarker/cache/PathGlobMatcher.html" title="class in 
freemarker.cache">PathGlobMatcher</a>, <a 
href="../../freemarker/cache/PathRegexMatcher.html" title="class in 
freemarker.cache">PathRegexMatcher</a></dd>
-</dl>
-<hr>
-<br>
-<pre>public abstract class <span 
class="typeNameLabel">TemplateSourceMatcher</span>
-extends java.lang.Object</pre>
-<dl>
-<dt><span class="simpleTagLabel">Since:</span></dt>
-<dd>2.3.24</dd>
-</dl>
-</li>
-</ul>
-</div>
-<div class="summary">
-<ul class="blockList">
-<li class="blockList">
-<!-- ======== CONSTRUCTOR SUMMARY ======== -->
-<ul class="blockList">
-<li class="blockList"><a name="constructor.summary">
-<!--   -->
-</a>
-<h3>Constructor Summary</h3>
-<table class="memberSummary" border="0" cellpadding="3" cellspacing="0" 
summary="Constructor Summary table, listing constructors, and an explanation">
-<caption><span>Constructors</span><span class="tabEnd">&nbsp;</span></caption>
-<tr>
-<th class="colOne" scope="col">Constructor and Description</th>
-</tr>
-<tr class="altColor">
-<td class="colOne"><code><span class="memberNameLink"><a 
href="../../freemarker/cache/TemplateSourceMatcher.html#TemplateSourceMatcher--">TemplateSourceMatcher</a></span>()</code>&nbsp;</td>
-</tr>
-</table>
-</li>
-</ul>
-<!-- ========== METHOD SUMMARY =========== -->
-<ul class="blockList">
-<li class="blockList"><a name="method.summary">
-<!--   -->
-</a>
-<h3>Method Summary</h3>
-<ul class="blockList">
-<li class="blockList"><a name="methods.inherited.from.class.java.lang.Object">
-<!--   -->
-</a>
-<h3>Methods inherited from class&nbsp;java.lang.Object</h3>
-<code>clone, equals, finalize, getClass, hashCode, notify, notifyAll, 
toString, wait, wait, wait</code></li>
-</ul>
-</li>
-</ul>
-</li>
-</ul>
-</div>
-<div class="details">
-<ul class="blockList">
-<li class="blockList">
-<!-- ========= CONSTRUCTOR DETAIL ======== -->
-<ul class="blockList">
-<li class="blockList"><a name="constructor.detail">
-<!--   -->
-</a>
-<h3>Constructor Detail</h3>
-<a name="TemplateSourceMatcher--">
-<!--   -->
-</a>
-<ul class="blockListLast">
-<li class="blockList">
-<h4>TemplateSourceMatcher</h4>
-<pre>public&nbsp;TemplateSourceMatcher()</pre>
-</li>
-</ul>
-</li>
-</ul>
-</li>
-</ul>
-</div>
-</div>
-<!-- ========= END OF CLASS DATA ========= -->
-<!-- ======= START OF BOTTOM NAVBAR ====== -->
-<div class="bottomNav"><a name="navbar.bottom">
-<!--   -->
-</a>
-<div class="skipNav"><a href="#skip.navbar.bottom" title="Skip navigation 
links">Skip navigation links</a></div>
-<a name="navbar.bottom.firstrow">
-<!--   -->
-</a>
-<ul class="navList" title="Navigation">
-<li><a href="../../overview-summary.html">Overview</a></li>
-<li><a href="package-summary.html">Package</a></li>
-<li class="navBarCell1Rev">Class</li>
-<li><a href="class-use/TemplateSourceMatcher.html">Use</a></li>
-<li><a href="package-tree.html">Tree</a></li>
-<li><a href="../../deprecated-list.html">Deprecated</a></li>
-<li><a href="../../index-all.html">Index</a></li>
-<li><a href="../../help-doc.html">Help</a></li>
-</ul>
-</div>
-<div class="subNav">
-<ul class="navList">
-<li><a href="../../freemarker/cache/TemplateNameFormat.html" title="class in 
freemarker.cache"><span class="typeNameLink">Prev&nbsp;Class</span></a></li>
-<li><a href="../../freemarker/cache/URLTemplateLoader.html" title="class in 
freemarker.cache"><span class="typeNameLink">Next&nbsp;Class</span></a></li>
-</ul>
-<ul class="navList">
-<li><a href="../../index.html?freemarker/cache/TemplateSourceMatcher.html" 
target="_top">Frames</a></li>
-<li><a href="TemplateSourceMatcher.html" target="_top">No&nbsp;Frames</a></li>
-</ul>
-<ul class="navList" id="allclasses_navbar_bottom">
-<li><a href="../../allclasses-noframe.html">All&nbsp;Classes</a></li>
-</ul>
-<div>
-<script type="text/javascript"><!--
-  allClassesLink = document.getElementById("allclasses_navbar_bottom");
-  if(window==top) {
-    allClassesLink.style.display = "block";
-  }
-  else {
-    allClassesLink.style.display = "none";
-  }
-  //-->
-</script>
-</div>
-<div>
-<ul class="subNavList">
-<li>Summary:&nbsp;</li>
-<li>Nested&nbsp;|&nbsp;</li>
-<li>Field&nbsp;|&nbsp;</li>
-<li><a href="#constructor.summary">Constr</a>&nbsp;|&nbsp;</li>
-<li><a href="#methods.inherited.from.class.java.lang.Object">Method</a></li>
-</ul>
-<ul class="subNavList">
-<li>Detail:&nbsp;</li>
-<li>Field&nbsp;|&nbsp;</li>
-<li><a href="#constructor.detail">Constr</a>&nbsp;|&nbsp;</li>
-<li>Method</li>
-</ul>
-</div>
-<a name="skip.navbar.bottom">
-<!--   -->
-</a></div>
-<!-- ======== END OF BOTTOM NAVBAR ======= -->
-</body>
-</html>

http://git-wip-us.apache.org/repos/asf/freemarker-site/blob/a4a53cb9/builds/2.3.28-voting/documentation/api/freemarker/cache/URLTemplateLoader.html
----------------------------------------------------------------------
diff --git 
a/builds/2.3.28-voting/documentation/api/freemarker/cache/URLTemplateLoader.html
 
b/builds/2.3.28-voting/documentation/api/freemarker/cache/URLTemplateLoader.html
deleted file mode 100644
index 49a76a4..0000000
--- 
a/builds/2.3.28-voting/documentation/api/freemarker/cache/URLTemplateLoader.html
+++ /dev/null
@@ -1,539 +0,0 @@
-<!DOCTYPE HTML PUBLIC "-//W3C//DTD HTML 4.01 Transitional//EN" 
"http://www.w3.org/TR/html4/loose.dtd";>
-<!-- NewPage -->
-<html lang="en">
-<head>
-<!-- Generated by javadoc (1.8.0_144) on Fri Mar 30 23:10:42 CEST 2018 -->
-<meta http-equiv="Content-Type" content="text/html; charset=UTF-8">
-<title>URLTemplateLoader (FreeMarker 2.3.28 API)</title>
-<meta name="date" content="2018-03-30">
-<link rel="stylesheet" type="text/css" href="../../stylesheet.css" 
title="Style">
-<script type="text/javascript" src="../../script.js"></script>
-</head>
-<body>
-<script type="text/javascript"><!--
-    try {
-        if (location.href.indexOf('is-external=true') == -1) {
-            parent.document.title="URLTemplateLoader (FreeMarker 2.3.28 API)";
-        }
-    }
-    catch(err) {
-    }
-//-->
-var methods = {"i0":9,"i1":10,"i2":10,"i3":10,"i4":10,"i5":6,"i6":10,"i7":10};
-var tabs = {65535:["t0","All Methods"],1:["t1","Static 
Methods"],2:["t2","Instance Methods"],4:["t3","Abstract 
Methods"],8:["t4","Concrete Methods"]};
-var altColor = "altColor";
-var rowColor = "rowColor";
-var tableTab = "tableTab";
-var activeTableTab = "activeTableTab";
-</script>
-<noscript>
-<div>JavaScript is disabled on your browser.</div>
-</noscript>
-<!-- ========= START OF TOP NAVBAR ======= -->
-<div class="topNav"><a name="navbar.top">
-<!--   -->
-</a>
-<div class="skipNav"><a href="#skip.navbar.top" title="Skip navigation 
links">Skip navigation links</a></div>
-<a name="navbar.top.firstrow">
-<!--   -->
-</a>
-<ul class="navList" title="Navigation">
-<li><a href="../../overview-summary.html">Overview</a></li>
-<li><a href="package-summary.html">Package</a></li>
-<li class="navBarCell1Rev">Class</li>
-<li><a href="class-use/URLTemplateLoader.html">Use</a></li>
-<li><a href="package-tree.html">Tree</a></li>
-<li><a href="../../deprecated-list.html">Deprecated</a></li>
-<li><a href="../../index-all.html">Index</a></li>
-<li><a href="../../help-doc.html">Help</a></li>
-</ul>
-</div>
-<div class="subNav">
-<ul class="navList">
-<li><a href="../../freemarker/cache/TemplateSourceMatcher.html" title="class 
in freemarker.cache"><span class="typeNameLink">Prev&nbsp;Class</span></a></li>
-<li><a href="../../freemarker/cache/WebappTemplateLoader.html" title="class in 
freemarker.cache"><span class="typeNameLink">Next&nbsp;Class</span></a></li>
-</ul>
-<ul class="navList">
-<li><a href="../../index.html?freemarker/cache/URLTemplateLoader.html" 
target="_top">Frames</a></li>
-<li><a href="URLTemplateLoader.html" target="_top">No&nbsp;Frames</a></li>
-</ul>
-<ul class="navList" id="allclasses_navbar_top">
-<li><a href="../../allclasses-noframe.html">All&nbsp;Classes</a></li>
-</ul>
-<div>
-<script type="text/javascript"><!--
-  allClassesLink = document.getElementById("allclasses_navbar_top");
-  if(window==top) {
-    allClassesLink.style.display = "block";
-  }
-  else {
-    allClassesLink.style.display = "none";
-  }
-  //-->
-</script>
-</div>
-<div>
-<ul class="subNavList">
-<li>Summary:&nbsp;</li>
-<li>Nested&nbsp;|&nbsp;</li>
-<li>Field&nbsp;|&nbsp;</li>
-<li><a href="#constructor.summary">Constr</a>&nbsp;|&nbsp;</li>
-<li><a href="#method.summary">Method</a></li>
-</ul>
-<ul class="subNavList">
-<li>Detail:&nbsp;</li>
-<li>Field&nbsp;|&nbsp;</li>
-<li><a href="#constructor.detail">Constr</a>&nbsp;|&nbsp;</li>
-<li><a href="#method.detail">Method</a></li>
-</ul>
-</div>
-<a name="skip.navbar.top">
-<!--   -->
-</a></div>
-<!-- ========= END OF TOP NAVBAR ========= -->
-<!-- ======== START OF CLASS DATA ======== -->
-<div class="header">
-<div class="subTitle">freemarker.cache</div>
-<h2 title="Class URLTemplateLoader" class="title">Class URLTemplateLoader</h2>
-</div>
-<div class="contentContainer">
-<ul class="inheritance">
-<li>java.lang.Object</li>
-<li>
-<ul class="inheritance">
-<li>freemarker.cache.URLTemplateLoader</li>
-</ul>
-</li>
-</ul>
-<div class="description">
-<ul class="blockList">
-<li class="blockList">
-<dl>
-<dt>All Implemented Interfaces:</dt>
-<dd><a href="../../freemarker/cache/TemplateLoader.html" title="interface in 
freemarker.cache">TemplateLoader</a></dd>
-</dl>
-<dl>
-<dt>Direct Known Subclasses:</dt>
-<dd><a href="../../freemarker/cache/ClassTemplateLoader.html" title="class in 
freemarker.cache">ClassTemplateLoader</a></dd>
-</dl>
-<hr>
-<br>
-<pre>public abstract class <span class="typeNameLabel">URLTemplateLoader</span>
-extends java.lang.Object
-implements <a href="../../freemarker/cache/TemplateLoader.html" 
title="interface in freemarker.cache">TemplateLoader</a></pre>
-<div class="block">This is an abstract template loader that can load templates 
whose location can be described by an URL. This
- superclass only works for cases where merely getting the URL immediately 
tells if the resource exists, not for cases
- where for example you had to check response headers to know that. The 
subclasses only need to override the
- <a 
href="../../freemarker/cache/URLTemplateLoader.html#getURL-java.lang.String-"><code>getURL(String)</code></a>
 method.</div>
-</li>
-</ul>
-</div>
-<div class="summary">
-<ul class="blockList">
-<li class="blockList">
-<!-- ======== CONSTRUCTOR SUMMARY ======== -->
-<ul class="blockList">
-<li class="blockList"><a name="constructor.summary">
-<!--   -->
-</a>
-<h3>Constructor Summary</h3>
-<table class="memberSummary" border="0" cellpadding="3" cellspacing="0" 
summary="Constructor Summary table, listing constructors, and an explanation">
-<caption><span>Constructors</span><span class="tabEnd">&nbsp;</span></caption>
-<tr>
-<th class="colOne" scope="col">Constructor and Description</th>
-</tr>
-<tr class="altColor">
-<td class="colOne"><code><span class="memberNameLink"><a 
href="../../freemarker/cache/URLTemplateLoader.html#URLTemplateLoader--">URLTemplateLoader</a></span>()</code>&nbsp;</td>
-</tr>
-</table>
-</li>
-</ul>
-<!-- ========== METHOD SUMMARY =========== -->
-<ul class="blockList">
-<li class="blockList"><a name="method.summary">
-<!--   -->
-</a>
-<h3>Method Summary</h3>
-<table class="memberSummary" border="0" cellpadding="3" cellspacing="0" 
summary="Method Summary table, listing methods, and an explanation">
-<caption><span id="t0" class="activeTableTab"><span>All Methods</span><span 
class="tabEnd">&nbsp;</span></span><span id="t1" class="tableTab"><span><a 
href="javascript:show(1);">Static Methods</a></span><span 
class="tabEnd">&nbsp;</span></span><span id="t2" class="tableTab"><span><a 
href="javascript:show(2);">Instance Methods</a></span><span 
class="tabEnd">&nbsp;</span></span><span id="t3" class="tableTab"><span><a 
href="javascript:show(4);">Abstract Methods</a></span><span 
class="tabEnd">&nbsp;</span></span><span id="t4" class="tableTab"><span><a 
href="javascript:show(8);">Concrete Methods</a></span><span 
class="tabEnd">&nbsp;</span></span></caption>
-<tr>
-<th class="colFirst" scope="col">Modifier and Type</th>
-<th class="colLast" scope="col">Method and Description</th>
-</tr>
-<tr id="i0" class="altColor">
-<td class="colFirst"><code>protected static java.lang.String</code></td>
-<td class="colLast"><code><span class="memberNameLink"><a 
href="../../freemarker/cache/URLTemplateLoader.html#canonicalizePrefix-java.lang.String-">canonicalizePrefix</a></span>(java.lang.String&nbsp;prefix)</code>
-<div class="block">Can be used by subclasses to canonicalize URL path 
prefixes.</div>
-</td>
-</tr>
-<tr id="i1" class="rowColor">
-<td class="colFirst"><code>void</code></td>
-<td class="colLast"><code><span class="memberNameLink"><a 
href="../../freemarker/cache/URLTemplateLoader.html#closeTemplateSource-java.lang.Object-">closeTemplateSource</a></span>(java.lang.Object&nbsp;templateSource)</code>
-<div class="block">Closes the template source, releasing any resources held 
that are only required for reading the template and/or
- its metadata.</div>
-</td>
-</tr>
-<tr id="i2" class="altColor">
-<td class="colFirst"><code>java.lang.Object</code></td>
-<td class="colLast"><code><span class="memberNameLink"><a 
href="../../freemarker/cache/URLTemplateLoader.html#findTemplateSource-java.lang.String-">findTemplateSource</a></span>(java.lang.String&nbsp;name)</code>
-<div class="block">Finds the template in the backing storage and returns an 
object that identifies the storage location where the
- template can be loaded from.</div>
-</td>
-</tr>
-<tr id="i3" class="rowColor">
-<td class="colFirst"><code>long</code></td>
-<td class="colLast"><code><span class="memberNameLink"><a 
href="../../freemarker/cache/URLTemplateLoader.html#getLastModified-java.lang.Object-">getLastModified</a></span>(java.lang.Object&nbsp;templateSource)</code>
-<div class="block">Returns the time of last modification of the specified 
template source.</div>
-</td>
-</tr>
-<tr id="i4" class="altColor">
-<td class="colFirst"><code>java.io.Reader</code></td>
-<td class="colLast"><code><span class="memberNameLink"><a 
href="../../freemarker/cache/URLTemplateLoader.html#getReader-java.lang.Object-java.lang.String-">getReader</a></span>(java.lang.Object&nbsp;templateSource,
-         java.lang.String&nbsp;encoding)</code>
-<div class="block">Returns the character stream of a template represented by 
the specified template source.</div>
-</td>
-</tr>
-<tr id="i5" class="rowColor">
-<td class="colFirst"><code>protected abstract java.net.URL</code></td>
-<td class="colLast"><code><span class="memberNameLink"><a 
href="../../freemarker/cache/URLTemplateLoader.html#getURL-java.lang.String-">getURL</a></span>(java.lang.String&nbsp;name)</code>
-<div class="block">Given a template name (plus potential locale decorations) 
retrieves
- an URL that points the template source.</div>
-</td>
-</tr>
-<tr id="i6" class="altColor">
-<td class="colFirst"><code>java.lang.Boolean</code></td>
-<td class="colLast"><code><span class="memberNameLink"><a 
href="../../freemarker/cache/URLTemplateLoader.html#getURLConnectionUsesCaches--">getURLConnectionUsesCaches</a></span>()</code>
-<div class="block">Getter pair of <a 
href="../../freemarker/cache/URLTemplateLoader.html#setURLConnectionUsesCaches-java.lang.Boolean-"><code>setURLConnectionUsesCaches(Boolean)</code></a>.</div>
-</td>
-</tr>
-<tr id="i7" class="rowColor">
-<td class="colFirst"><code>void</code></td>
-<td class="colLast"><code><span class="memberNameLink"><a 
href="../../freemarker/cache/URLTemplateLoader.html#setURLConnectionUsesCaches-java.lang.Boolean-">setURLConnectionUsesCaches</a></span>(java.lang.Boolean&nbsp;urlConnectionUsesCaches)</code>
-<div class="block">Sets if <code>URLConnection.setUseCaches(boolean)</code> 
will be called, and with what value.</div>
-</td>
-</tr>
-</table>
-<ul class="blockList">
-<li class="blockList"><a name="methods.inherited.from.class.java.lang.Object">
-<!--   -->
-</a>
-<h3>Methods inherited from class&nbsp;java.lang.Object</h3>
-<code>clone, equals, finalize, getClass, hashCode, notify, notifyAll, 
toString, wait, wait, wait</code></li>
-</ul>
-</li>
-</ul>
-</li>
-</ul>
-</div>
-<div class="details">
-<ul class="blockList">
-<li class="blockList">
-<!-- ========= CONSTRUCTOR DETAIL ======== -->
-<ul class="blockList">
-<li class="blockList"><a name="constructor.detail">
-<!--   -->
-</a>
-<h3>Constructor Detail</h3>
-<a name="URLTemplateLoader--">
-<!--   -->
-</a>
-<ul class="blockListLast">
-<li class="blockList">
-<h4>URLTemplateLoader</h4>
-<pre>public&nbsp;URLTemplateLoader()</pre>
-</li>
-</ul>
-</li>
-</ul>
-<!-- ============ METHOD DETAIL ========== -->
-<ul class="blockList">
-<li class="blockList"><a name="method.detail">
-<!--   -->
-</a>
-<h3>Method Detail</h3>
-<a name="findTemplateSource-java.lang.String-">
-<!--   -->
-</a>
-<ul class="blockList">
-<li class="blockList">
-<h4>findTemplateSource</h4>
-<pre>public&nbsp;java.lang.Object&nbsp;findTemplateSource(java.lang.String&nbsp;name)
-                                    throws java.io.IOException</pre>
-<div class="block"><span class="descfrmTypeLabel">Description copied from 
interface:&nbsp;<code><a 
href="../../freemarker/cache/TemplateLoader.html#findTemplateSource-java.lang.String-">TemplateLoader</a></code></span></div>
-<div class="block">Finds the template in the backing storage and returns an 
object that identifies the storage location where the
- template can be loaded from. See the return value for more information.</div>
-<dl>
-<dt><span class="overrideSpecifyLabel">Specified by:</span></dt>
-<dd><code><a 
href="../../freemarker/cache/TemplateLoader.html#findTemplateSource-java.lang.String-">findTemplateSource</a></code>&nbsp;in
 interface&nbsp;<code><a href="../../freemarker/cache/TemplateLoader.html" 
title="interface in freemarker.cache">TemplateLoader</a></code></dd>
-<dt><span class="paramLabel">Parameters:</span></dt>
-<dd><code>name</code> - The name (template root directory relative path) of 
the template, already localized and normalized by
-            the <a href="../../freemarker/cache/TemplateCache.html" 
title="class in freemarker.cache"><code>cache</code></a>. It is completely up 
to the loader implementation to
-            interpret the name, however it should expect to receive 
hierarchical paths where path components are
-            separated by a slash (not backslash). Backslashes (or any other OS 
specific separator character) are
-            not considered as separators by FreeMarker, and thus they will not 
be replaced with slash before
-            passing to this method, so it's up to the template loader to 
handle them (say, by throwing an
-            exception that tells the user that the path (s)he has entered is 
invalid, as (s)he must use slash --
-            typical mistake of Windows users). The passed names are always 
considered relative to some
-            loader-defined root location (often referred as the "template root 
directory"), and will never start
-            with a slash, nor will they contain a path component consisting of 
either a single or a double dot --
-            these are all resolved by the template cache before passing the 
name to the loader. As a side effect,
-            paths that trivially reach outside template root directory, such 
as <tt>../my.ftl</tt>, will be
-            rejected by the template cache, so they never reach the template 
loader. Note again, that if the path
-            uses backslash as path separator instead of slash as (the template 
loader should not accept that), the
-            normalization will not properly happen, as FreeMarker (the cache) 
recognizes only the slashes as
-            separators.</dd>
-<dt><span class="returnLabel">Returns:</span></dt>
-<dd>An object representing the template source, which can be supplied in 
subsequent calls to
-         <a 
href="../../freemarker/cache/TemplateLoader.html#getLastModified-java.lang.Object-"><code>TemplateLoader.getLastModified(Object)</code></a>
 and <a 
href="../../freemarker/cache/TemplateLoader.html#getReader-java.lang.Object-java.lang.String-"><code>TemplateLoader.getReader(Object,
 String)</code></a>, when those are called on the
-         same <a href="../../freemarker/cache/TemplateLoader.html" 
title="interface in freemarker.cache"><code>TemplateLoader</code></a>. 
<code>null</code> must be returned if the source for the template doesn't exist;
-         don't throw exception then! The exact type of this object is up to 
the <a href="../../freemarker/cache/TemplateLoader.html" title="interface in 
freemarker.cache"><code>TemplateLoader</code></a>
-         implementation. As this object is possibly used as hash key in 
caches, and is surly compared with another
-         template source for equality, <b>it must have a proper 
<code>Object.equals(Object)</code> and
-         <code>Object.hashCode()</code>) implementation</b>. Especially, 
template sources that refer to the same
-         physical source must be equivalent, otherwise template caching can 
become inefficient. This is only
-         expected from <code>Object.equals(Object)</code> when the compared 
template sources came from the same
-         <a href="../../freemarker/cache/TemplateLoader.html" title="interface 
in freemarker.cache"><code>TemplateLoader</code></a> instance. Also, it must 
not influence the equality if the source is open or
-         closed (<a 
href="../../freemarker/cache/TemplateLoader.html#closeTemplateSource-java.lang.Object-"><code>TemplateLoader.closeTemplateSource(Object)</code></a>).</dd>
-<dt><span class="throwsLabel">Throws:</span></dt>
-<dd><code>java.io.IOException</code> - When an error occurs that makes it 
impossible to find out if the template exists, or to access the
-             existing template. Don't throw exception if the template doesn't 
exist, instead return with
-             <code>null</code> then!</dd>
-</dl>
-</li>
-</ul>
-<a name="getLastModified-java.lang.Object-">
-<!--   -->
-</a>
-<ul class="blockList">
-<li class="blockList">
-<h4>getLastModified</h4>
-<pre>public&nbsp;long&nbsp;getLastModified(java.lang.Object&nbsp;templateSource)</pre>
-<div class="block"><span class="descfrmTypeLabel">Description copied from 
interface:&nbsp;<code><a 
href="../../freemarker/cache/TemplateLoader.html#getLastModified-java.lang.Object-">TemplateLoader</a></code></span></div>
-<div class="block">Returns the time of last modification of the specified 
template source. This method is called after
- <code>findTemplateSource()</code>.</div>
-<dl>
-<dt><span class="overrideSpecifyLabel">Specified by:</span></dt>
-<dd><code><a 
href="../../freemarker/cache/TemplateLoader.html#getLastModified-java.lang.Object-">getLastModified</a></code>&nbsp;in
 interface&nbsp;<code><a href="../../freemarker/cache/TemplateLoader.html" 
title="interface in freemarker.cache">TemplateLoader</a></code></dd>
-<dt><span class="paramLabel">Parameters:</span></dt>
-<dd><code>templateSource</code> - an object representing a template source, 
obtained through a prior call to
-            <a 
href="../../freemarker/cache/TemplateLoader.html#findTemplateSource-java.lang.String-"><code>TemplateLoader.findTemplateSource(String)</code></a>.
 This must be an object on which
-            <a 
href="../../freemarker/cache/TemplateLoader.html#closeTemplateSource-java.lang.Object-"><code>TemplateLoader.closeTemplateSource(Object)</code></a>
 wasn't applied yet.</dd>
-<dt><span class="returnLabel">Returns:</span></dt>
-<dd>the time of last modification of the specified template source, or -1 if 
the time is not known.</dd>
-</dl>
-</li>
-</ul>
-<a name="getReader-java.lang.Object-java.lang.String-">
-<!--   -->
-</a>
-<ul class="blockList">
-<li class="blockList">
-<h4>getReader</h4>
-<pre>public&nbsp;java.io.Reader&nbsp;getReader(java.lang.Object&nbsp;templateSource,
-                                java.lang.String&nbsp;encoding)
-                         throws java.io.IOException</pre>
-<div class="block"><span class="descfrmTypeLabel">Description copied from 
interface:&nbsp;<code><a 
href="../../freemarker/cache/TemplateLoader.html#getReader-java.lang.Object-java.lang.String-">TemplateLoader</a></code></span></div>
-<div class="block">Returns the character stream of a template represented by 
the specified template source. This method is possibly
- called for multiple times for the same template source object, and it must 
always return a <code>Reader</code> that
- reads the template from its beginning. Before this method is called for the 
second time (or later), its caller
- must close the previously returned <code>Reader</code>, and it must not use 
it anymore. That is, this method is not
- required to support multiple concurrent readers for the same source 
<code>templateSource</code> object.
- 
- <p>
- Typically, this method is called if the template is missing from the cache, 
or if after calling
- <a 
href="../../freemarker/cache/TemplateLoader.html#findTemplateSource-java.lang.String-"><code>TemplateLoader.findTemplateSource(String)</code></a>
 and <a 
href="../../freemarker/cache/TemplateLoader.html#getLastModified-java.lang.Object-"><code>TemplateLoader.getLastModified(Object)</code></a>
 it was determined that the cached copy
- of the template is stale. Then, if it turns out that the 
<code>encoding</code> parameter used doesn't match the actual
- template content (based on the <code>#ftl encoding=...</code> header), this 
method will be called for a second time
- with the correct <code>encoding</code> parameter value.
- 
- <p>
- Unlike <a 
href="../../freemarker/cache/TemplateLoader.html#findTemplateSource-java.lang.String-"><code>TemplateLoader.findTemplateSource(String)</code></a>,
 this method must not tolerate if the template is not found, and
- must throw <code>IOException</code> in that case.</div>
-<dl>
-<dt><span class="overrideSpecifyLabel">Specified by:</span></dt>
-<dd><code><a 
href="../../freemarker/cache/TemplateLoader.html#getReader-java.lang.Object-java.lang.String-">getReader</a></code>&nbsp;in
 interface&nbsp;<code><a href="../../freemarker/cache/TemplateLoader.html" 
title="interface in freemarker.cache">TemplateLoader</a></code></dd>
-<dt><span class="paramLabel">Parameters:</span></dt>
-<dd><code>templateSource</code> - an object representing a template source, 
obtained through a prior call to
-            <a 
href="../../freemarker/cache/TemplateLoader.html#findTemplateSource-java.lang.String-"><code>TemplateLoader.findTemplateSource(String)</code></a>.
 This must be an object on which
-            <a 
href="../../freemarker/cache/TemplateLoader.html#closeTemplateSource-java.lang.Object-"><code>TemplateLoader.closeTemplateSource(Object)</code></a>
 wasn't applied yet.</dd>
-<dd><code>encoding</code> - the character encoding used to translate source 
bytes to characters. Some loaders may not have access
-            to the byte representation of the template stream, and instead 
directly obtain a character stream.
-            These loaders should ignore the encoding parameter.</dd>
-<dt><span class="returnLabel">Returns:</span></dt>
-<dd>A <code>Reader</code> representing the template character stream; not 
<code>null</code>. It's the responsibility of
-         the caller (which is <a 
href="../../freemarker/cache/TemplateCache.html" title="class in 
freemarker.cache"><code>TemplateCache</code></a> usually) to 
<code>close()</code> it. The <code>Reader</code> is not
-         required to work after the <code>templateSource</code> was closed (<a 
href="../../freemarker/cache/TemplateLoader.html#closeTemplateSource-java.lang.Object-"><code>TemplateLoader.closeTemplateSource(Object)</code></a>).</dd>
-<dt><span class="throwsLabel">Throws:</span></dt>
-<dd><code>java.io.IOException</code> - if an I/O error occurs while accessing 
the stream.</dd>
-</dl>
-</li>
-</ul>
-<a name="closeTemplateSource-java.lang.Object-">
-<!--   -->
-</a>
-<ul class="blockList">
-<li class="blockList">
-<h4>closeTemplateSource</h4>
-<pre>public&nbsp;void&nbsp;closeTemplateSource(java.lang.Object&nbsp;templateSource)
-                         throws java.io.IOException</pre>
-<div class="block"><span class="descfrmTypeLabel">Description copied from 
interface:&nbsp;<code><a 
href="../../freemarker/cache/TemplateLoader.html#closeTemplateSource-java.lang.Object-">TemplateLoader</a></code></span></div>
-<div class="block">Closes the template source, releasing any resources held 
that are only required for reading the template and/or
- its metadata. This is the last method that is called by the <a 
href="../../freemarker/cache/TemplateCache.html" title="class in 
freemarker.cache"><code>TemplateCache</code></a> for a template source, except
- that <code>Object.equals(Object)</code> is might called later too. <a 
href="../../freemarker/cache/TemplateCache.html" title="class in 
freemarker.cache"><code>TemplateCache</code></a> ensures that this method will
- be called on every object that is returned from <a 
href="../../freemarker/cache/TemplateLoader.html#findTemplateSource-java.lang.String-"><code>TemplateLoader.findTemplateSource(String)</code></a>.</div>
-<dl>
-<dt><span class="overrideSpecifyLabel">Specified by:</span></dt>
-<dd><code><a 
href="../../freemarker/cache/TemplateLoader.html#closeTemplateSource-java.lang.Object-">closeTemplateSource</a></code>&nbsp;in
 interface&nbsp;<code><a href="../../freemarker/cache/TemplateLoader.html" 
title="interface in freemarker.cache">TemplateLoader</a></code></dd>
-<dt><span class="paramLabel">Parameters:</span></dt>
-<dd><code>templateSource</code> - the template source that should be 
closed.</dd>
-<dt><span class="throwsLabel">Throws:</span></dt>
-<dd><code>java.io.IOException</code></dd>
-</dl>
-</li>
-</ul>
-<a name="getURLConnectionUsesCaches--">
-<!--   -->
-</a>
-<ul class="blockList">
-<li class="blockList">
-<h4>getURLConnectionUsesCaches</h4>
-<pre>public&nbsp;java.lang.Boolean&nbsp;getURLConnectionUsesCaches()</pre>
-<div class="block">Getter pair of <a 
href="../../freemarker/cache/URLTemplateLoader.html#setURLConnectionUsesCaches-java.lang.Boolean-"><code>setURLConnectionUsesCaches(Boolean)</code></a>.</div>
-<dl>
-<dt><span class="simpleTagLabel">Since:</span></dt>
-<dd>2.3.21</dd>
-</dl>
-</li>
-</ul>
-<a name="setURLConnectionUsesCaches-java.lang.Boolean-">
-<!--   -->
-</a>
-<ul class="blockList">
-<li class="blockList">
-<h4>setURLConnectionUsesCaches</h4>
-<pre>public&nbsp;void&nbsp;setURLConnectionUsesCaches(java.lang.Boolean&nbsp;urlConnectionUsesCaches)</pre>
-<div class="block">Sets if <code>URLConnection.setUseCaches(boolean)</code> 
will be called, and with what value. By default this is
- <code>null</code>; see the behavior then below. The recommended value is 
<code>false</code>, so that FreeMarker can always
- reliably detect when a template was changed. The default is <code>null</code> 
only for backward compatibility,
- and certainly will be changed to <code>false</code> in 2.4.0. As FreeMarker 
has its own template cache with its
- own update delay setting (<a 
href="../../freemarker/template/Configuration.html#setTemplateUpdateDelay-int-"><code>Configuration.setTemplateUpdateDelay(int)</code></a>),
 setting this to <code>false</code>
- shouldn't cause performance problems.
- 
- <p>Regarding <code>null</code> value: By default then 
<code>URLConnection.setUseCaches(boolean)</code> won't be called,
- and so the default of the <code>URLConnection</code> subclass will be in 
effect (usually <code>true</code>). That's the
- 2.3.0-compatible mode. However, if <a 
href="../../freemarker/template/Configuration.html#getIncompatibleImprovements--"><code>Configuration.getIncompatibleImprovements()</code></a>
 is at least 2.3.21, then
- when <code>Configuration.getTemplate</code> is used, <code>null</code> will 
mean <code>false</code>. Note that this 2.3.21 trick
- only works if the template is loaded through 
<code>Configuration.getTemplate</code> (or <a 
href="../../freemarker/cache/TemplateCache.html" title="class in 
freemarker.cache"><code>TemplateCache</code></a>).</div>
-<dl>
-<dt><span class="simpleTagLabel">Since:</span></dt>
-<dd>2.3.21</dd>
-</dl>
-</li>
-</ul>
-<a name="getURL-java.lang.String-">
-<!--   -->
-</a>
-<ul class="blockList">
-<li class="blockList">
-<h4>getURL</h4>
-<pre>protected 
abstract&nbsp;java.net.URL&nbsp;getURL(java.lang.String&nbsp;name)</pre>
-<div class="block">Given a template name (plus potential locale decorations) 
retrieves
- an URL that points the template source.</div>
-<dl>
-<dt><span class="paramLabel">Parameters:</span></dt>
-<dd><code>name</code> - the name of the sought template, including the locale
- decorations.</dd>
-<dt><span class="returnLabel">Returns:</span></dt>
-<dd>an URL that points to the template source, or <code>null</code> if the 
template does not exist.</dd>
-</dl>
-</li>
-</ul>
-<a name="canonicalizePrefix-java.lang.String-">
-<!--   -->
-</a>
-<ul class="blockListLast">
-<li class="blockList">
-<h4>canonicalizePrefix</h4>
-<pre>protected 
static&nbsp;java.lang.String&nbsp;canonicalizePrefix(java.lang.String&nbsp;prefix)</pre>
-<div class="block">Can be used by subclasses to canonicalize URL path 
prefixes.</div>
-<dl>
-<dt><span class="paramLabel">Parameters:</span></dt>
-<dd><code>prefix</code> - the path prefix to canonicalize</dd>
-<dt><span class="returnLabel">Returns:</span></dt>
-<dd>the canonicalized prefix. All backslashes are replaced with
- forward slashes, and a trailing slash is appended if the original
- prefix wasn't empty and didn't already end with a slash.</dd>
-</dl>
-</li>
-</ul>
-</li>
-</ul>
-</li>
-</ul>
-</div>
-</div>
-<!-- ========= END OF CLASS DATA ========= -->
-<!-- ======= START OF BOTTOM NAVBAR ====== -->
-<div class="bottomNav"><a name="navbar.bottom">
-<!--   -->
-</a>
-<div class="skipNav"><a href="#skip.navbar.bottom" title="Skip navigation 
links">Skip navigation links</a></div>
-<a name="navbar.bottom.firstrow">
-<!--   -->
-</a>
-<ul class="navList" title="Navigation">
-<li><a href="../../overview-summary.html">Overview</a></li>
-<li><a href="package-summary.html">Package</a></li>
-<li class="navBarCell1Rev">Class</li>
-<li><a href="class-use/URLTemplateLoader.html">Use</a></li>
-<li><a href="package-tree.html">Tree</a></li>
-<li><a href="../../deprecated-list.html">Deprecated</a></li>
-<li><a href="../../index-all.html">Index</a></li>
-<li><a href="../../help-doc.html">Help</a></li>
-</ul>
-</div>
-<div class="subNav">
-<ul class="navList">
-<li><a href="../../freemarker/cache/TemplateSourceMatcher.html" title="class 
in freemarker.cache"><span class="typeNameLink">Prev&nbsp;Class</span></a></li>
-<li><a href="../../freemarker/cache/WebappTemplateLoader.html" title="class in 
freemarker.cache"><span class="typeNameLink">Next&nbsp;Class</span></a></li>
-</ul>
-<ul class="navList">
-<li><a href="../../index.html?freemarker/cache/URLTemplateLoader.html" 
target="_top">Frames</a></li>
-<li><a href="URLTemplateLoader.html" target="_top">No&nbsp;Frames</a></li>
-</ul>
-<ul class="navList" id="allclasses_navbar_bottom">
-<li><a href="../../allclasses-noframe.html">All&nbsp;Classes</a></li>
-</ul>
-<div>
-<script type="text/javascript"><!--
-  allClassesLink = document.getElementById("allclasses_navbar_bottom");
-  if(window==top) {
-    allClassesLink.style.display = "block";
-  }
-  else {
-    allClassesLink.style.display = "none";
-  }
-  //-->
-</script>
-</div>
-<div>
-<ul class="subNavList">
-<li>Summary:&nbsp;</li>
-<li>Nested&nbsp;|&nbsp;</li>
-<li>Field&nbsp;|&nbsp;</li>
-<li><a href="#constructor.summary">Constr</a>&nbsp;|&nbsp;</li>
-<li><a href="#method.summary">Method</a></li>
-</ul>
-<ul class="subNavList">
-<li>Detail:&nbsp;</li>
-<li>Field&nbsp;|&nbsp;</li>
-<li><a href="#constructor.detail">Constr</a>&nbsp;|&nbsp;</li>
-<li><a href="#method.detail">Method</a></li>
-</ul>
-</div>
-<a name="skip.navbar.bottom">
-<!--   -->
-</a></div>
-<!-- ======== END OF BOTTOM NAVBAR ======= -->
-</body>
-</html>

http://git-wip-us.apache.org/repos/asf/freemarker-site/blob/a4a53cb9/builds/2.3.28-voting/documentation/api/freemarker/cache/WebappTemplateLoader.html
----------------------------------------------------------------------
diff --git 
a/builds/2.3.28-voting/documentation/api/freemarker/cache/WebappTemplateLoader.html
 
b/builds/2.3.28-voting/documentation/api/freemarker/cache/WebappTemplateLoader.html
deleted file mode 100644
index 0fd912e..0000000
--- 
a/builds/2.3.28-voting/documentation/api/freemarker/cache/WebappTemplateLoader.html
+++ /dev/null
@@ -1,578 +0,0 @@
-<!DOCTYPE HTML PUBLIC "-//W3C//DTD HTML 4.01 Transitional//EN" 
"http://www.w3.org/TR/html4/loose.dtd";>
-<!-- NewPage -->
-<html lang="en">
-<head>
-<!-- Generated by javadoc (1.8.0_144) on Fri Mar 30 23:10:42 CEST 2018 -->
-<meta http-equiv="Content-Type" content="text/html; charset=UTF-8">
-<title>WebappTemplateLoader (FreeMarker 2.3.28 API)</title>
-<meta name="date" content="2018-03-30">
-<link rel="stylesheet" type="text/css" href="../../stylesheet.css" 
title="Style">
-<script type="text/javascript" src="../../script.js"></script>
-</head>
-<body>
-<script type="text/javascript"><!--
-    try {
-        if (location.href.indexOf('is-external=true') == -1) {
-            parent.document.title="WebappTemplateLoader (FreeMarker 2.3.28 
API)";
-        }
-    }
-    catch(err) {
-    }
-//-->
-var methods = 
{"i0":10,"i1":10,"i2":10,"i3":10,"i4":10,"i5":10,"i6":10,"i7":10,"i8":10};
-var tabs = {65535:["t0","All Methods"],2:["t2","Instance 
Methods"],8:["t4","Concrete Methods"]};
-var altColor = "altColor";
-var rowColor = "rowColor";
-var tableTab = "tableTab";
-var activeTableTab = "activeTableTab";
-</script>
-<noscript>
-<div>JavaScript is disabled on your browser.</div>
-</noscript>
-<!-- ========= START OF TOP NAVBAR ======= -->
-<div class="topNav"><a name="navbar.top">
-<!--   -->
-</a>
-<div class="skipNav"><a href="#skip.navbar.top" title="Skip navigation 
links">Skip navigation links</a></div>
-<a name="navbar.top.firstrow">
-<!--   -->
-</a>
-<ul class="navList" title="Navigation">
-<li><a href="../../overview-summary.html">Overview</a></li>
-<li><a href="package-summary.html">Package</a></li>
-<li class="navBarCell1Rev">Class</li>
-<li><a href="class-use/WebappTemplateLoader.html">Use</a></li>
-<li><a href="package-tree.html">Tree</a></li>
-<li><a href="../../deprecated-list.html">Deprecated</a></li>
-<li><a href="../../index-all.html">Index</a></li>
-<li><a href="../../help-doc.html">Help</a></li>
-</ul>
-</div>
-<div class="subNav">
-<ul class="navList">
-<li><a href="../../freemarker/cache/URLTemplateLoader.html" title="class in 
freemarker.cache"><span class="typeNameLink">Prev&nbsp;Class</span></a></li>
-<li>Next&nbsp;Class</li>
-</ul>
-<ul class="navList">
-<li><a href="../../index.html?freemarker/cache/WebappTemplateLoader.html" 
target="_top">Frames</a></li>
-<li><a href="WebappTemplateLoader.html" target="_top">No&nbsp;Frames</a></li>
-</ul>
-<ul class="navList" id="allclasses_navbar_top">
-<li><a href="../../allclasses-noframe.html">All&nbsp;Classes</a></li>
-</ul>
-<div>
-<script type="text/javascript"><!--
-  allClassesLink = document.getElementById("allclasses_navbar_top");
-  if(window==top) {
-    allClassesLink.style.display = "block";
-  }
-  else {
-    allClassesLink.style.display = "none";
-  }
-  //-->
-</script>
-</div>
-<div>
-<ul class="subNavList">
-<li>Summary:&nbsp;</li>
-<li>Nested&nbsp;|&nbsp;</li>
-<li>Field&nbsp;|&nbsp;</li>
-<li><a href="#constructor.summary">Constr</a>&nbsp;|&nbsp;</li>
-<li><a href="#method.summary">Method</a></li>
-</ul>
-<ul class="subNavList">
-<li>Detail:&nbsp;</li>
-<li>Field&nbsp;|&nbsp;</li>
-<li><a href="#constructor.detail">Constr</a>&nbsp;|&nbsp;</li>
-<li><a href="#method.detail">Method</a></li>
-</ul>
-</div>
-<a name="skip.navbar.top">
-<!--   -->
-</a></div>
-<!-- ========= END OF TOP NAVBAR ========= -->
-<!-- ======== START OF CLASS DATA ======== -->
-<div class="header">
-<div class="subTitle">freemarker.cache</div>
-<h2 title="Class WebappTemplateLoader" class="title">Class 
WebappTemplateLoader</h2>
-</div>
-<div class="contentContainer">
-<ul class="inheritance">
-<li>java.lang.Object</li>
-<li>
-<ul class="inheritance">
-<li>freemarker.cache.WebappTemplateLoader</li>
-</ul>
-</li>
-</ul>
-<div class="description">
-<ul class="blockList">
-<li class="blockList">
-<dl>
-<dt>All Implemented Interfaces:</dt>
-<dd><a href="../../freemarker/cache/TemplateLoader.html" title="interface in 
freemarker.cache">TemplateLoader</a></dd>
-</dl>
-<hr>
-<br>
-<pre>public class <span class="typeNameLabel">WebappTemplateLoader</span>
-extends java.lang.Object
-implements <a href="../../freemarker/cache/TemplateLoader.html" 
title="interface in freemarker.cache">TemplateLoader</a></pre>
-<div class="block">A <a href="../../freemarker/cache/TemplateLoader.html" 
title="interface in freemarker.cache"><code>TemplateLoader</code></a> that uses 
streams reachable through <code>ServletContext.getResource(String)</code> as 
its source
- of templates.</div>
-</li>
-</ul>
-</div>
-<div class="summary">
-<ul class="blockList">
-<li class="blockList">
-<!-- ======== CONSTRUCTOR SUMMARY ======== -->
-<ul class="blockList">
-<li class="blockList"><a name="constructor.summary">
-<!--   -->
-</a>
-<h3>Constructor Summary</h3>
-<table class="memberSummary" border="0" cellpadding="3" cellspacing="0" 
summary="Constructor Summary table, listing constructors, and an explanation">
-<caption><span>Constructors</span><span class="tabEnd">&nbsp;</span></caption>
-<tr>
-<th class="colOne" scope="col">Constructor and Description</th>
-</tr>
-<tr class="altColor">
-<td class="colOne"><code><span class="memberNameLink"><a 
href="../../freemarker/cache/WebappTemplateLoader.html#WebappTemplateLoader-javax.servlet.ServletContext-">WebappTemplateLoader</a></span>(javax.servlet.ServletContext&nbsp;servletContext)</code>
-<div class="block">Creates a template loader that will use the specified 
servlet context to load the resources.</div>
-</td>
-</tr>
-<tr class="rowColor">
-<td class="colOne"><code><span class="memberNameLink"><a 
href="../../freemarker/cache/WebappTemplateLoader.html#WebappTemplateLoader-javax.servlet.ServletContext-java.lang.String-">WebappTemplateLoader</a></span>(javax.servlet.ServletContext&nbsp;servletContext,
-                    java.lang.String&nbsp;subdirPath)</code>
-<div class="block">Creates a template loader that will use the specified 
servlet context to load the resources.</div>
-</td>
-</tr>
-</table>
-</li>
-</ul>
-<!-- ========== METHOD SUMMARY =========== -->
-<ul class="blockList">
-<li class="blockList"><a name="method.summary">
-<!--   -->
-</a>
-<h3>Method Summary</h3>
-<table class="memberSummary" border="0" cellpadding="3" cellspacing="0" 
summary="Method Summary table, listing methods, and an explanation">
-<caption><span id="t0" class="activeTableTab"><span>All Methods</span><span 
class="tabEnd">&nbsp;</span></span><span id="t2" class="tableTab"><span><a 
href="javascript:show(2);">Instance Methods</a></span><span 
class="tabEnd">&nbsp;</span></span><span id="t4" class="tableTab"><span><a 
href="javascript:show(8);">Concrete Methods</a></span><span 
class="tabEnd">&nbsp;</span></span></caption>
-<tr>
-<th class="colFirst" scope="col">Modifier and Type</th>
-<th class="colLast" scope="col">Method and Description</th>
-</tr>
-<tr id="i0" class="altColor">
-<td class="colFirst"><code>void</code></td>
-<td class="colLast"><code><span class="memberNameLink"><a 
href="../../freemarker/cache/WebappTemplateLoader.html#closeTemplateSource-java.lang.Object-">closeTemplateSource</a></span>(java.lang.Object&nbsp;templateSource)</code>
-<div class="block">Closes the template source, releasing any resources held 
that are only required for reading the template and/or
- its metadata.</div>
-</td>
-</tr>
-<tr id="i1" class="rowColor">
-<td class="colFirst"><code>java.lang.Object</code></td>
-<td class="colLast"><code><span class="memberNameLink"><a 
href="../../freemarker/cache/WebappTemplateLoader.html#findTemplateSource-java.lang.String-">findTemplateSource</a></span>(java.lang.String&nbsp;name)</code>
-<div class="block">Finds the template in the backing storage and returns an 
object that identifies the storage location where the
- template can be loaded from.</div>
-</td>
-</tr>
-<tr id="i2" class="altColor">
-<td class="colFirst"><code>boolean</code></td>
-<td class="colLast"><code><span class="memberNameLink"><a 
href="../../freemarker/cache/WebappTemplateLoader.html#getAttemptFileAccess--">getAttemptFileAccess</a></span>()</code>
-<div class="block">Getter pair of <a 
href="../../freemarker/cache/WebappTemplateLoader.html#setAttemptFileAccess-boolean-"><code>setAttemptFileAccess(boolean)</code></a>.</div>
-</td>
-</tr>
-<tr id="i3" class="rowColor">
-<td class="colFirst"><code>long</code></td>
-<td class="colLast"><code><span class="memberNameLink"><a 
href="../../freemarker/cache/WebappTemplateLoader.html#getLastModified-java.lang.Object-">getLastModified</a></span>(java.lang.Object&nbsp;templateSource)</code>
-<div class="block">Returns the time of last modification of the specified 
template source.</div>
-</td>
-</tr>
-<tr id="i4" class="altColor">
-<td class="colFirst"><code>java.io.Reader</code></td>
-<td class="colLast"><code><span class="memberNameLink"><a 
href="../../freemarker/cache/WebappTemplateLoader.html#getReader-java.lang.Object-java.lang.String-">getReader</a></span>(java.lang.Object&nbsp;templateSource,
-         java.lang.String&nbsp;encoding)</code>
-<div class="block">Returns the character stream of a template represented by 
the specified template source.</div>
-</td>
-</tr>
-<tr id="i5" class="rowColor">
-<td class="colFirst"><code>java.lang.Boolean</code></td>
-<td class="colLast"><code><span class="memberNameLink"><a 
href="../../freemarker/cache/WebappTemplateLoader.html#getURLConnectionUsesCaches--">getURLConnectionUsesCaches</a></span>()</code>
-<div class="block">Getter pair of <a 
href="../../freemarker/cache/WebappTemplateLoader.html#setURLConnectionUsesCaches-java.lang.Boolean-"><code>setURLConnectionUsesCaches(Boolean)</code></a>.</div>
-</td>
-</tr>
-<tr id="i6" class="altColor">
-<td class="colFirst"><code>void</code></td>
-<td class="colLast"><code><span class="memberNameLink"><a 
href="../../freemarker/cache/WebappTemplateLoader.html#setAttemptFileAccess-boolean-">setAttemptFileAccess</a></span>(boolean&nbsp;attemptLoadingFromFile)</code>
-<div class="block">Specifies that before loading templates with 
<code>ServletContext.getResource(String)</code>, it should try to load
- the template as <code>File</code>; default is <code>true</code>, though it's 
not always recommended anymore.</div>
-</td>
-</tr>
-<tr id="i7" class="rowColor">
-<td class="colFirst"><code>void</code></td>
-<td class="colLast"><code><span class="memberNameLink"><a 
href="../../freemarker/cache/WebappTemplateLoader.html#setURLConnectionUsesCaches-java.lang.Boolean-">setURLConnectionUsesCaches</a></span>(java.lang.Boolean&nbsp;urlConnectionUsesCaches)</code>
-<div class="block">It does the same as <a 
href="../../freemarker/cache/URLTemplateLoader.html#setURLConnectionUsesCaches-java.lang.Boolean-"><code>URLTemplateLoader.setURLConnectionUsesCaches(Boolean)</code></a>;
 see there.</div>
-</td>
-</tr>
-<tr id="i8" class="altColor">
-<td class="colFirst"><code>java.lang.String</code></td>
-<td class="colLast"><code><span class="memberNameLink"><a 
href="../../freemarker/cache/WebappTemplateLoader.html#toString--">toString</a></span>()</code>
-<div class="block">Show class name and some details that are useful in 
template-not-found errors.</div>
-</td>
-</tr>
-</table>
-<ul class="blockList">
-<li class="blockList"><a name="methods.inherited.from.class.java.lang.Object">
-<!--   -->
-</a>
-<h3>Methods inherited from class&nbsp;java.lang.Object</h3>
-<code>clone, equals, finalize, getClass, hashCode, notify, notifyAll, wait, 
wait, wait</code></li>
-</ul>
-</li>
-</ul>
-</li>
-</ul>
-</div>
-<div class="details">
-<ul class="blockList">
-<li class="blockList">
-<!-- ========= CONSTRUCTOR DETAIL ======== -->
-<ul class="blockList">
-<li class="blockList"><a name="constructor.detail">
-<!--   -->
-</a>
-<h3>Constructor Detail</h3>
-<a name="WebappTemplateLoader-javax.servlet.ServletContext-">
-<!--   -->
-</a>
-<ul class="blockList">
-<li class="blockList">
-<h4>WebappTemplateLoader</h4>
-<pre>public&nbsp;WebappTemplateLoader(javax.servlet.ServletContext&nbsp;servletContext)</pre>
-<div class="block">Creates a template loader that will use the specified 
servlet context to load the resources. It will use
- the base path of <code>"/"</code> meaning templates will be resolved relative 
to the servlet context root
- location.</div>
-<dl>
-<dt><span class="paramLabel">Parameters:</span></dt>
-<dd><code>servletContext</code> - the servlet context whose 
<code>ServletContext.getResource(String)</code> will be used to load the
-            templates.</dd>
-</dl>
-</li>
-</ul>
-<a name="WebappTemplateLoader-javax.servlet.ServletContext-java.lang.String-">
-<!--   -->
-</a>
-<ul class="blockListLast">
-<li class="blockList">
-<h4>WebappTemplateLoader</h4>
-<pre>public&nbsp;WebappTemplateLoader(javax.servlet.ServletContext&nbsp;servletContext,
-                            java.lang.String&nbsp;subdirPath)</pre>
-<div class="block">Creates a template loader that will use the specified 
servlet context to load the resources. It will use the
- specified base path, which is interpreted relatively to the context root 
(does not mater if you start it with "/"
- or not). Path components should be separated by forward slashes independently 
of the separator character used by
- the underlying operating system.</div>
-<dl>
-<dt><span class="paramLabel">Parameters:</span></dt>
-<dd><code>servletContext</code> - the servlet context whose 
<code>ServletContext.getResource(String)</code> will be used to load the
-            templates.</dd>
-<dd><code>subdirPath</code> - the base path to template resources.</dd>
-</dl>
-</li>
-</ul>
-</li>
-</ul>
-<!-- ============ METHOD DETAIL ========== -->
-<ul class="blockList">
-<li class="blockList"><a name="method.detail">
-<!--   -->
-</a>
-<h3>Method Detail</h3>
-<a name="findTemplateSource-java.lang.String-">
-<!--   -->
-</a>
-<ul class="blockList">
-<li class="blockList">
-<h4>findTemplateSource</h4>
-<pre>public&nbsp;java.lang.Object&nbsp;findTemplateSource(java.lang.String&nbsp;name)
-                                    throws java.io.IOException</pre>
-<div class="block"><span class="descfrmTypeLabel">Description copied from 
interface:&nbsp;<code><a 
href="../../freemarker/cache/TemplateLoader.html#findTemplateSource-java.lang.String-">TemplateLoader</a></code></span></div>
-<div class="block">Finds the template in the backing storage and returns an 
object that identifies the storage location where the
- template can be loaded from. See the return value for more information.</div>
-<dl>
-<dt><span class="overrideSpecifyLabel">Specified by:</span></dt>
-<dd><code><a 
href="../../freemarker/cache/TemplateLoader.html#findTemplateSource-java.lang.String-">findTemplateSource</a></code>&nbsp;in
 interface&nbsp;<code><a href="../../freemarker/cache/TemplateLoader.html" 
title="interface in freemarker.cache">TemplateLoader</a></code></dd>
-<dt><span class="paramLabel">Parameters:</span></dt>
-<dd><code>name</code> - The name (template root directory relative path) of 
the template, already localized and normalized by
-            the <a href="../../freemarker/cache/TemplateCache.html" 
title="class in freemarker.cache"><code>cache</code></a>. It is completely up 
to the loader implementation to
-            interpret the name, however it should expect to receive 
hierarchical paths where path components are
-            separated by a slash (not backslash). Backslashes (or any other OS 
specific separator character) are
-            not considered as separators by FreeMarker, and thus they will not 
be replaced with slash before
-            passing to this method, so it's up to the template loader to 
handle them (say, by throwing an
-            exception that tells the user that the path (s)he has entered is 
invalid, as (s)he must use slash --
-            typical mistake of Windows users). The passed names are always 
considered relative to some
-            loader-defined root location (often referred as the "template root 
directory"), and will never start
-            with a slash, nor will they contain a path component consisting of 
either a single or a double dot --
-            these are all resolved by the template cache before passing the 
name to the loader. As a side effect,
-            paths that trivially reach outside template root directory, such 
as <tt>../my.ftl</tt>, will be
-            rejected by the template cache, so they never reach the template 
loader. Note again, that if the path
-            uses backslash as path separator instead of slash as (the template 
loader should not accept that), the
-            normalization will not properly happen, as FreeMarker (the cache) 
recognizes only the slashes as
-            separators.</dd>
-<dt><span class="returnLabel">Returns:</span></dt>
-<dd>An object representing the template source, which can be supplied in 
subsequent calls to
-         <a 
href="../../freemarker/cache/TemplateLoader.html#getLastModified-java.lang.Object-"><code>TemplateLoader.getLastModified(Object)</code></a>
 and <a 
href="../../freemarker/cache/TemplateLoader.html#getReader-java.lang.Object-java.lang.String-"><code>TemplateLoader.getReader(Object,
 String)</code></a>, when those are called on the
-         same <a href="../../freemarker/cache/TemplateLoader.html" 
title="interface in freemarker.cache"><code>TemplateLoader</code></a>. 
<code>null</code> must be returned if the source for the template doesn't exist;
-         don't throw exception then! The exact type of this object is up to 
the <a href="../../freemarker/cache/TemplateLoader.html" title="interface in 
freemarker.cache"><code>TemplateLoader</code></a>
-         implementation. As this object is possibly used as hash key in 
caches, and is surly compared with another
-         template source for equality, <b>it must have a proper 
<code>Object.equals(Object)</code> and
-         <code>Object.hashCode()</code>) implementation</b>. Especially, 
template sources that refer to the same
-         physical source must be equivalent, otherwise template caching can 
become inefficient. This is only
-         expected from <code>Object.equals(Object)</code> when the compared 
template sources came from the same
-         <a href="../../freemarker/cache/TemplateLoader.html" title="interface 
in freemarker.cache"><code>TemplateLoader</code></a> instance. Also, it must 
not influence the equality if the source is open or
-         closed (<a 
href="../../freemarker/cache/TemplateLoader.html#closeTemplateSource-java.lang.Object-"><code>TemplateLoader.closeTemplateSource(Object)</code></a>).</dd>
-<dt><span class="throwsLabel">Throws:</span></dt>
-<dd><code>java.io.IOException</code> - When an error occurs that makes it 
impossible to find out if the template exists, or to access the
-             existing template. Don't throw exception if the template doesn't 
exist, instead return with
-             <code>null</code> then!</dd>
-</dl>
-</li>
-</ul>
-<a name="getLastModified-java.lang.Object-">
-<!--   -->
-</a>
-<ul class="blockList">
-<li class="blockList">
-<h4>getLastModified</h4>
-<pre>public&nbsp;long&nbsp;getLastModified(java.lang.Object&nbsp;templateSource)</pre>
-<div class="block"><span class="descfrmTypeLabel">Description copied from 
interface:&nbsp;<code><a 
href="../../freemarker/cache/TemplateLoader.html#getLastModified-java.lang.Object-">TemplateLoader</a></code></span></div>
-<div class="block">Returns the time of last modification of the specified 
template source. This method is called after
- <code>findTemplateSource()</code>.</div>
-<dl>
-<dt><span class="overrideSpecifyLabel">Specified by:</span></dt>
-<dd><code><a 
href="../../freemarker/cache/TemplateLoader.html#getLastModified-java.lang.Object-">getLastModified</a></code>&nbsp;in
 interface&nbsp;<code><a href="../../freemarker/cache/TemplateLoader.html" 
title="interface in freemarker.cache">TemplateLoader</a></code></dd>
-<dt><span class="paramLabel">Parameters:</span></dt>
-<dd><code>templateSource</code> - an object representing a template source, 
obtained through a prior call to
-            <a 
href="../../freemarker/cache/TemplateLoader.html#findTemplateSource-java.lang.String-"><code>TemplateLoader.findTemplateSource(String)</code></a>.
 This must be an object on which
-            <a 
href="../../freemarker/cache/TemplateLoader.html#closeTemplateSource-java.lang.Object-"><code>TemplateLoader.closeTemplateSource(Object)</code></a>
 wasn't applied yet.</dd>
-<dt><span class="returnLabel">Returns:</span></dt>
-<dd>the time of last modification of the specified template source, or -1 if 
the time is not known.</dd>
-</dl>
-</li>
-</ul>
-<a name="getReader-java.lang.Object-java.lang.String-">
-<!--   -->
-</a>
-<ul class="blockList">
-<li class="blockList">
-<h4>getReader</h4>
-<pre>public&nbsp;java.io.Reader&nbsp;getReader(java.lang.Object&nbsp;templateSource,
-                                java.lang.String&nbsp;encoding)
-                         throws java.io.IOException</pre>
-<div class="block"><span class="descfrmTypeLabel">Description copied from 
interface:&nbsp;<code><a 
href="../../freemarker/cache/TemplateLoader.html#getReader-java.lang.Object-java.lang.String-">TemplateLoader</a></code></span></div>
-<div class="block">Returns the character stream of a template represented by 
the specified template source. This method is possibly
- called for multiple times for the same template source object, and it must 
always return a <code>Reader</code> that
- reads the template from its beginning. Before this method is called for the 
second time (or later), its caller
- must close the previously returned <code>Reader</code>, and it must not use 
it anymore. That is, this method is not
- required to support multiple concurrent readers for the same source 
<code>templateSource</code> object.
- 
- <p>
- Typically, this method is called if the template is missing from the cache, 
or if after calling
- <a 
href="../../freemarker/cache/TemplateLoader.html#findTemplateSource-java.lang.String-"><code>TemplateLoader.findTemplateSource(String)</code></a>
 and <a 
href="../../freemarker/cache/TemplateLoader.html#getLastModified-java.lang.Object-"><code>TemplateLoader.getLastModified(Object)</code></a>
 it was determined that the cached copy
- of the template is stale. Then, if it turns out that the 
<code>encoding</code> parameter used doesn't match the actual
- template content (based on the <code>#ftl encoding=...</code> header), this 
method will be called for a second time
- with the correct <code>encoding</code> parameter value.
- 
- <p>
- Unlike <a 
href="../../freemarker/cache/TemplateLoader.html#findTemplateSource-java.lang.String-"><code>TemplateLoader.findTemplateSource(String)</code></a>,
 this method must not tolerate if the template is not found, and
- must throw <code>IOException</code> in that case.</div>
-<dl>
-<dt><span class="overrideSpecifyLabel">Specified by:</span></dt>
-<dd><code><a 
href="../../freemarker/cache/TemplateLoader.html#getReader-java.lang.Object-java.lang.String-">getReader</a></code>&nbsp;in
 interface&nbsp;<code><a href="../../freemarker/cache/TemplateLoader.html" 
title="interface in freemarker.cache">TemplateLoader</a></code></dd>
-<dt><span class="paramLabel">Parameters:</span></dt>
-<dd><code>templateSource</code> - an object representing a template source, 
obtained through a prior call to
-            <a 
href="../../freemarker/cache/TemplateLoader.html#findTemplateSource-java.lang.String-"><code>TemplateLoader.findTemplateSource(String)</code></a>.
 This must be an object on which
-            <a 
href="../../freemarker/cache/TemplateLoader.html#closeTemplateSource-java.lang.Object-"><code>TemplateLoader.closeTemplateSource(Object)</code></a>
 wasn't applied yet.</dd>
-<dd><code>encoding</code> - the character encoding used to translate source 
bytes to characters. Some loaders may not have access
-            to the byte representation of the template stream, and instead 
directly obtain a character stream.
-            These loaders should ignore the encoding parameter.</dd>
-<dt><span class="returnLabel">Returns:</span></dt>
-<dd>A <code>Reader</code> representing the template character stream; not 
<code>null</code>. It's the responsibility of
-         the caller (which is <a 
href="../../freemarker/cache/TemplateCache.html" title="class in 
freemarker.cache"><code>TemplateCache</code></a> usually) to 
<code>close()</code> it. The <code>Reader</code> is not
-         required to work after the <code>templateSource</code> was closed (<a 
href="../../freemarker/cache/TemplateLoader.html#closeTemplateSource-java.lang.Object-"><code>TemplateLoader.closeTemplateSource(Object)</code></a>).</dd>
-<dt><span class="throwsLabel">Throws:</span></dt>
-<dd><code>java.io.IOException</code> - if an I/O error occurs while accessing 
the stream.</dd>
-</dl>
-</li>
-</ul>
-<a name="closeTemplateSource-java.lang.Object-">
-<!--   -->
-</a>
-<ul class="blockList">
-<li class="blockList">
-<h4>closeTemplateSource</h4>
-<pre>public&nbsp;void&nbsp;closeTemplateSource(java.lang.Object&nbsp;templateSource)
-                         throws java.io.IOException</pre>
-<div class="block"><span class="descfrmTypeLabel">Description copied from 
interface:&nbsp;<code><a 
href="../../freemarker/cache/TemplateLoader.html#closeTemplateSource-java.lang.Object-">TemplateLoader</a></code></span></div>
-<div class="block">Closes the template source, releasing any resources held 
that are only required for reading the template and/or
- its metadata. This is the last method that is called by the <a 
href="../../freemarker/cache/TemplateCache.html" title="class in 
freemarker.cache"><code>TemplateCache</code></a> for a template source, except
- that <code>Object.equals(Object)</code> is might called later too. <a 
href="../../freemarker/cache/TemplateCache.html" title="class in 
freemarker.cache"><code>TemplateCache</code></a> ensures that this method will
- be called on every object that is returned from <a 
href="../../freemarker/cache/TemplateLoader.html#findTemplateSource-java.lang.String-"><code>TemplateLoader.findTemplateSource(String)</code></a>.</div>
-<dl>
-<dt><span class="overrideSpecifyLabel">Specified by:</span></dt>
-<dd><code><a 
href="../../freemarker/cache/TemplateLoader.html#closeTemplateSource-java.lang.Object-">closeTemplateSource</a></code>&nbsp;in
 interface&nbsp;<code><a href="../../freemarker/cache/TemplateLoader.html" 
title="interface in freemarker.cache">TemplateLoader</a></code></dd>
-<dt><span class="paramLabel">Parameters:</span></dt>
-<dd><code>templateSource</code> - the template source that should be 
closed.</dd>
-<dt><span class="throwsLabel">Throws:</span></dt>
-<dd><code>java.io.IOException</code></dd>
-</dl>
-</li>
-</ul>
-<a name="getURLConnectionUsesCaches--">
-<!--   -->
-</a>
-<ul class="blockList">
-<li class="blockList">
-<h4>getURLConnectionUsesCaches</h4>
-<pre>public&nbsp;java.lang.Boolean&nbsp;getURLConnectionUsesCaches()</pre>
-<div class="block">Getter pair of <a 
href="../../freemarker/cache/WebappTemplateLoader.html#setURLConnectionUsesCaches-java.lang.Boolean-"><code>setURLConnectionUsesCaches(Boolean)</code></a>.</div>
-<dl>
-<dt><span class="simpleTagLabel">Since:</span></dt>
-<dd>2.3.21</dd>
-</dl>
-</li>
-</ul>
-<a name="setURLConnectionUsesCaches-java.lang.Boolean-">
-<!--   -->
-</a>
-<ul class="blockList">
-<li class="blockList">
-<h4>setURLConnectionUsesCaches</h4>
-<pre>public&nbsp;void&nbsp;setURLConnectionUsesCaches(java.lang.Boolean&nbsp;urlConnectionUsesCaches)</pre>
-<div class="block">It does the same as <a 
href="../../freemarker/cache/URLTemplateLoader.html#setURLConnectionUsesCaches-java.lang.Boolean-"><code>URLTemplateLoader.setURLConnectionUsesCaches(Boolean)</code></a>;
 see there.</div>
-<dl>
-<dt><span class="simpleTagLabel">Since:</span></dt>
-<dd>2.3.21</dd>
-</dl>
-</li>
-</ul>
-<a name="toString--">
-<!--   -->
-</a>
-<ul class="blockList">
-<li class="blockList">
-<h4>toString</h4>
-<pre>public&nbsp;java.lang.String&nbsp;toString()</pre>
-<div class="block">Show class name and some details that are useful in 
template-not-found errors.</div>
-<dl>
-<dt><span class="overrideSpecifyLabel">Overrides:</span></dt>
-<dd><code>toString</code>&nbsp;in class&nbsp;<code>java.lang.Object</code></dd>
-<dt><span class="simpleTagLabel">Since:</span></dt>
-<dd>2.3.21</dd>
-</dl>
-</li>
-</ul>
-<a name="getAttemptFileAccess--">
-<!--   -->
-</a>
-<ul class="blockList">
-<li class="blockList">
-<h4>getAttemptFileAccess</h4>
-<pre>public&nbsp;boolean&nbsp;getAttemptFileAccess()</pre>
-<div class="block">Getter pair of <a 
href="../../freemarker/cache/WebappTemplateLoader.html#setAttemptFileAccess-boolean-"><code>setAttemptFileAccess(boolean)</code></a>.</div>
-<dl>
-<dt><span class="simpleTagLabel">Since:</span></dt>
-<dd>2.3.23</dd>
-</dl>
-</li>
-</ul>
-<a name="setAttemptFileAccess-boolean-">
-<!--   -->
-</a>
-<ul class="blockListLast">
-<li class="blockList">
-<h4>setAttemptFileAccess</h4>
-<pre>public&nbsp;void&nbsp;setAttemptFileAccess(boolean&nbsp;attemptLoadingFromFile)</pre>
-<div class="block">Specifies that before loading templates with 
<code>ServletContext.getResource(String)</code>, it should try to load
- the template as <code>File</code>; default is <code>true</code>, though it's 
not always recommended anymore. This is a
- workaround for the case when the servlet container doesn't show template 
modifications after the template was
- already loaded earlier. But it's certainly better to counter this problem by 
disabling the URL connection cache
- with <a 
href="../../freemarker/cache/WebappTemplateLoader.html#setURLConnectionUsesCaches-java.lang.Boolean-"><code>setURLConnectionUsesCaches(Boolean)</code></a>,
 which is also the default behavior with
- <a 
href="../../freemarker/template/Configuration.html#setIncompatibleImprovements-freemarker.template.Version-"><code>incompatible_improvements</code></a>
 2.3.21
- and later.</div>
-<dl>
-<dt><span class="simpleTagLabel">Since:</span></dt>
-<dd>2.3.23</dd>
-</dl>
-</li>
-</ul>
-</li>
-</ul>
-</li>
-</ul>
-</div>
-</div>
-<!-- ========= END OF CLASS DATA ========= -->
-<!-- ======= START OF BOTTOM NAVBAR ====== -->
-<div class="bottomNav"><a name="navbar.bottom">
-<!--   -->
-</a>
-<div class="skipNav"><a href="#skip.navbar.bottom" title="Skip navigation 
links">Skip navigation links</a></div>
-<a name="navbar.bottom.firstrow">
-<!--   -->
-</a>
-<ul class="navList" title="Navigation">
-<li><a href="../../overview-summary.html">Overview</a></li>
-<li><a href="package-summary.html">Package</a></li>
-<li class="navBarCell1Rev">Class</li>
-<li><a href="class-use/WebappTemplateLoader.html">Use</a></li>
-<li><a href="package-tree.html">Tree</a></li>
-<li><a href="../../deprecated-list.html">Deprecated</a></li>
-<li><a href="../../index-all.html">Index</a></li>
-<li><a href="../../help-doc.html">Help</a></li>
-</ul>
-</div>
-<div class="subNav">
-<ul class="navList">
-<li><a href="../../freemarker/cache/URLTemplateLoader.html" title="class in 
freemarker.cache"><span class="typeNameLink">Prev&nbsp;Class</span></a></li>
-<li>Next&nbsp;Class</li>
-</ul>
-<ul class="navList">
-<li><a href="../../index.html?freemarker/cache/WebappTemplateLoader.html" 
target="_top">Frames</a></li>
-<li><a href="WebappTemplateLoader.html" target="_top">No&nbsp;Frames</a></li>
-</ul>
-<ul class="navList" id="allclasses_navbar_bottom">
-<li><a href="../../allclasses-noframe.html">All&nbsp;Classes</a></li>
-</ul>
-<div>
-<script type="text/javascript"><!--
-  allClassesLink = document.getElementById("allclasses_navbar_bottom");
-  if(window==top) {
-    allClassesLink.style.display = "block";
-  }
-  else {
-    allClassesLink.style.display = "none";
-  }
-  //-->
-</script>
-</div>
-<div>
-<ul class="subNavList">
-<li>Summary:&nbsp;</li>
-<li>Nested&nbsp;|&nbsp;</li>
-<li>Field&nbsp;|&nbsp;</li>
-<li><a href="#constructor.summary">Constr</a>&nbsp;|&nbsp;</li>
-<li><a href="#method.summary">Method</a></li>
-</ul>
-<ul class="subNavList">
-<li>Detail:&nbsp;</li>
-<li>Field&nbsp;|&nbsp;</li>
-<li><a href="#constructor.detail">Constr</a>&nbsp;|&nbsp;</li>
-<li><a href="#method.detail">Method</a></li>
-</ul>
-</div>
-<a name="skip.navbar.bottom">
-<!--   -->
-</a></div>
-<!-- ======== END OF BOTTOM NAVBAR ======= -->
-</body>
-</html>

Reply via email to