
com.whaleal.icefrog.extra.template.TemplateConfig Maven / Gradle / Ivy
package com.whaleal.icefrog.extra.template;
import com.whaleal.icefrog.core.util.CharsetUtil;
import java.io.Serializable;
import java.nio.charset.Charset;
import java.util.Objects;
/**
* 模板配置
*
* @author looly
*/
public class TemplateConfig implements Serializable {
public static final TemplateConfig DEFAULT = new TemplateConfig();
private static final long serialVersionUID = 2933113779920339523L;
/**
* 编码
*/
private Charset charset;
/**
* 模板路径,如果ClassPath或者WebRoot模式,则表示相对路径
*/
private String path;
/**
* 模板资源加载方式
*/
private ResourceMode resourceMode;
/**
* 自定义引擎,当多个jar包引入时,可以自定使用的默认引擎
*/
private Class extends TemplateEngine> customEngine;
/**
* 默认构造,使用UTF8编码,默认从ClassPath获取模板
*/
public TemplateConfig() {
this(null);
}
/**
* 构造,默认UTF-8编码
*
* @param path 模板路径,如果ClassPath或者WebRoot模式,则表示相对路径
*/
public TemplateConfig( String path ) {
this(path, ResourceMode.STRING);
}
/**
* 构造,默认UTF-8编码
*
* @param path 模板路径,如果ClassPath或者WebRoot模式,则表示相对路径
* @param resourceMode 模板资源加载方式
*/
public TemplateConfig( String path, ResourceMode resourceMode ) {
this(CharsetUtil.CHARSET_UTF_8, path, resourceMode);
}
/**
* 构造
*
* @param charset 编码
* @param path 模板路径,如果ClassPath或者WebRoot模式,则表示相对路径
* @param resourceMode 模板资源加载方式
*/
public TemplateConfig( Charset charset, String path, ResourceMode resourceMode ) {
this.charset = charset;
this.path = path;
this.resourceMode = resourceMode;
}
/**
* 获取编码
*
* @return 编码
*/
public Charset getCharset() {
return charset;
}
/**
* 设置编码
*
* @param charset 编码
*/
public void setCharset( Charset charset ) {
this.charset = charset;
}
/**
* 获取编码
*
* @return 编码
*/
public String getCharsetStr() {
if (null == this.charset) {
return null;
}
return this.charset.toString();
}
/**
* 获取模板路径,如果ClassPath或者WebRoot模式,则表示相对路径
*
* @return 模板路径
*/
public String getPath() {
return path;
}
/**
* 设置模板路径,如果ClassPath或者WebRoot模式,则表示相对路径
*
* @param path 模板路径
*/
public void setPath( String path ) {
this.path = path;
}
/**
* 获取模板资源加载方式
*
* @return 模板资源加载方式
*/
public ResourceMode getResourceMode() {
return resourceMode;
}
/**
* 设置模板资源加载方式
*
* @param resourceMode 模板资源加载方式
*/
public void setResourceMode( ResourceMode resourceMode ) {
this.resourceMode = resourceMode;
}
/**
* 获取自定义引擎,null表示系统自动判断
*
* @return 自定义引擎,null表示系统自动判断
*/
public Class extends TemplateEngine> getCustomEngine() {
return customEngine;
}
/**
* 设置自定义引擎,null表示系统自动判断
*
* @param customEngine 自定义引擎,null表示系统自动判断
* @return this
*/
public TemplateConfig setCustomEngine( Class extends TemplateEngine> customEngine ) {
this.customEngine = customEngine;
return this;
}
@Override
public boolean equals( Object o ) {
if (this == o) {
return true;
}
if (o == null || getClass() != o.getClass()) {
return false;
}
TemplateConfig that = (TemplateConfig) o;
return Objects.equals(charset, that.charset) &&
Objects.equals(path, that.path) &&
resourceMode == that.resourceMode &&
Objects.equals(customEngine, that.customEngine);
}
@Override
public int hashCode() {
return Objects.hash(charset, path, resourceMode, customEngine);
}
/**
* 资源加载方式枚举
*
* @author looly
*/
public enum ResourceMode {
/**
* 从ClassPath加载模板
*/
CLASSPATH,
/**
* 从File目录加载模板
*/
FILE,
/**
* 从WebRoot目录加载模板
*/
WEB_ROOT,
/**
* 从模板文本加载模板
*/
STRING,
/**
* 复合加载模板(分别从File、ClassPath、Web-root、String方式尝试查找模板)
*/
COMPOSITE
}
}
© 2015 - 2025 Weber Informatics LLC | Privacy Policy