Commit dd748eda authored by Andy Wilkinson's avatar Andy Wilkinson

Use the configured charset, if any, in MustacheViewResolver

Closes gh-2670
parent 2cf23e08
...@@ -108,6 +108,7 @@ public class MustacheAutoConfiguration { ...@@ -108,6 +108,7 @@ public class MustacheAutoConfiguration {
resolver.setCache(this.mustache.isCache()); resolver.setCache(this.mustache.isCache());
resolver.setViewNames(this.mustache.getViewNames()); resolver.setViewNames(this.mustache.getViewNames());
resolver.setContentType(this.mustache.getContentType()); resolver.setContentType(this.mustache.getContentType());
resolver.setCharset(this.mustache.getCharset());
resolver.setCompiler(mustacheCompiler); resolver.setCompiler(mustacheCompiler);
resolver.setOrder(Ordered.LOWEST_PRECEDENCE - 10); resolver.setOrder(Ordered.LOWEST_PRECEDENCE - 10);
return resolver; return resolver;
......
...@@ -34,12 +34,15 @@ import com.samskivert.mustache.Template; ...@@ -34,12 +34,15 @@ import com.samskivert.mustache.Template;
* Spring MVC {@link ViewResolver} for Mustache. * Spring MVC {@link ViewResolver} for Mustache.
* *
* @author Dave Syer * @author Dave Syer
* @author Andy Wilkinson
* @since 1.2.2 * @since 1.2.2
*/ */
public class MustacheViewResolver extends UrlBasedViewResolver { public class MustacheViewResolver extends UrlBasedViewResolver {
private Compiler compiler = Mustache.compiler(); private Compiler compiler = Mustache.compiler();
private String charset;
public MustacheViewResolver() { public MustacheViewResolver() {
setViewClass(MustacheView.class); setViewClass(MustacheView.class);
} }
...@@ -51,6 +54,13 @@ public class MustacheViewResolver extends UrlBasedViewResolver { ...@@ -51,6 +54,13 @@ public class MustacheViewResolver extends UrlBasedViewResolver {
this.compiler = compiler; this.compiler = compiler;
} }
/**
* @param charset the charset to set
*/
public void setCharset(String charset) {
this.charset = charset;
}
@Override @Override
protected View loadView(String viewName, Locale locale) throws Exception { protected View loadView(String viewName, Locale locale) throws Exception {
Resource resource = resolveResource(viewName, locale); Resource resource = resolveResource(viewName, locale);
...@@ -64,7 +74,9 @@ public class MustacheViewResolver extends UrlBasedViewResolver { ...@@ -64,7 +74,9 @@ public class MustacheViewResolver extends UrlBasedViewResolver {
} }
private Template createTemplate(Resource resource) throws IOException { private Template createTemplate(Resource resource) throws IOException {
return this.compiler.compile(new InputStreamReader(resource.getInputStream())); return this.charset == null ? this.compiler.compile(new InputStreamReader(
resource.getInputStream())) : this.compiler
.compile(new InputStreamReader(resource.getInputStream(), this.charset));
} }
private Resource resolveResource(String viewName, Locale locale) { private Resource resolveResource(String viewName, Locale locale) {
......
Markdown is supported
0% or
You are about to add 0 people to the discussion. Proceed with caution.
Finish editing this message first!
Please register or to comment