Compare commits
9 Commits
Author | SHA1 | Date | |
---|---|---|---|
|
34c1a9e53a | ||
|
f6a855b6bf | ||
|
4377d19e2f | ||
|
820f2806ec | ||
|
808bdf6079 | ||
|
eac1d8d055 | ||
|
d5a88b8be4 | ||
|
fd5d554171 | ||
|
6d18be3df8 |
2
pom.xml
2
pom.xml
@@ -4,7 +4,7 @@
|
|||||||
<artifactId>enjoy</artifactId>
|
<artifactId>enjoy</artifactId>
|
||||||
<packaging>jar</packaging>
|
<packaging>jar</packaging>
|
||||||
<name>enjoy</name>
|
<name>enjoy</name>
|
||||||
<version>3.7</version>
|
<version>4.0</version>
|
||||||
<url>http://www.jfinal.com</url>
|
<url>http://www.jfinal.com</url>
|
||||||
<description>Enjoy is a simple, light, rapid, independent, extensible Java Template Engine.</description>
|
<description>Enjoy is a simple, light, rapid, independent, extensible Java Template Engine.</description>
|
||||||
|
|
||||||
|
@@ -30,11 +30,6 @@ import java.util.Map;
|
|||||||
@SuppressWarnings({"serial", "rawtypes", "unchecked"})
|
@SuppressWarnings({"serial", "rawtypes", "unchecked"})
|
||||||
public class Kv extends HashMap {
|
public class Kv extends HashMap {
|
||||||
|
|
||||||
@Deprecated
|
|
||||||
private static final String STATE_OK = "isOk";
|
|
||||||
@Deprecated
|
|
||||||
private static final String STATE_FAIL = "isFail";
|
|
||||||
|
|
||||||
public Kv() {
|
public Kv() {
|
||||||
}
|
}
|
||||||
|
|
||||||
@@ -46,68 +41,6 @@ public class Kv extends HashMap {
|
|||||||
return new Kv();
|
return new Kv();
|
||||||
}
|
}
|
||||||
|
|
||||||
@Deprecated
|
|
||||||
public static Kv ok() {
|
|
||||||
return new Kv().setOk();
|
|
||||||
}
|
|
||||||
|
|
||||||
@Deprecated
|
|
||||||
public static Kv ok(Object key, Object value) {
|
|
||||||
return ok().set(key, value);
|
|
||||||
}
|
|
||||||
|
|
||||||
@Deprecated
|
|
||||||
public static Kv fail() {
|
|
||||||
return new Kv().setFail();
|
|
||||||
}
|
|
||||||
|
|
||||||
@Deprecated
|
|
||||||
public static Kv fail(Object key, Object value) {
|
|
||||||
return fail().set(key, value);
|
|
||||||
}
|
|
||||||
|
|
||||||
@Deprecated
|
|
||||||
public Kv setOk() {
|
|
||||||
super.put(STATE_OK, Boolean.TRUE);
|
|
||||||
super.put(STATE_FAIL, Boolean.FALSE);
|
|
||||||
return this;
|
|
||||||
}
|
|
||||||
|
|
||||||
@Deprecated
|
|
||||||
public Kv setFail() {
|
|
||||||
super.put(STATE_FAIL, Boolean.TRUE);
|
|
||||||
super.put(STATE_OK, Boolean.FALSE);
|
|
||||||
return this;
|
|
||||||
}
|
|
||||||
|
|
||||||
@Deprecated
|
|
||||||
public boolean isOk() {
|
|
||||||
Boolean isOk = (Boolean)get(STATE_OK);
|
|
||||||
if (isOk != null) {
|
|
||||||
return isOk;
|
|
||||||
}
|
|
||||||
Boolean isFail = (Boolean)get(STATE_FAIL);
|
|
||||||
if (isFail != null) {
|
|
||||||
return !isFail;
|
|
||||||
}
|
|
||||||
|
|
||||||
throw new IllegalStateException("调用 isOk() 之前,必须先调用 ok()、fail() 或者 setOk()、setFail() 方法");
|
|
||||||
}
|
|
||||||
|
|
||||||
@Deprecated
|
|
||||||
public boolean isFail() {
|
|
||||||
Boolean isFail = (Boolean)get(STATE_FAIL);
|
|
||||||
if (isFail != null) {
|
|
||||||
return isFail;
|
|
||||||
}
|
|
||||||
Boolean isOk = (Boolean)get(STATE_OK);
|
|
||||||
if (isOk != null) {
|
|
||||||
return !isOk;
|
|
||||||
}
|
|
||||||
|
|
||||||
throw new IllegalStateException("调用 isFail() 之前,必须先调用 ok()、fail() 或者 setOk()、setFail() 方法");
|
|
||||||
}
|
|
||||||
|
|
||||||
public Kv set(Object key, Object value) {
|
public Kv set(Object key, Object value) {
|
||||||
super.put(key, value);
|
super.put(key, value);
|
||||||
return this;
|
return this;
|
||||||
|
@@ -16,6 +16,9 @@
|
|||||||
|
|
||||||
package com.jfinal.kit;
|
package com.jfinal.kit;
|
||||||
|
|
||||||
|
import java.lang.reflect.Method;
|
||||||
|
import java.lang.reflect.Parameter;
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* 反射工具类
|
* 反射工具类
|
||||||
*/
|
*/
|
||||||
@@ -29,6 +32,45 @@ public class ReflectKit {
|
|||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
|
public static String getMethodSignature(Method method) {
|
||||||
|
StringBuilder ret = new StringBuilder()
|
||||||
|
.append(method.getDeclaringClass().getName())
|
||||||
|
.append(".")
|
||||||
|
.append(method.getName())
|
||||||
|
.append("(");
|
||||||
|
|
||||||
|
int index = 0;
|
||||||
|
Parameter[] paras = method.getParameters();
|
||||||
|
for (Parameter p : paras) {
|
||||||
|
if (index++ > 0) {
|
||||||
|
ret.append(", ");
|
||||||
|
}
|
||||||
|
ret.append(p.getParameterizedType().getTypeName());
|
||||||
|
}
|
||||||
|
|
||||||
|
return ret.append(")").toString();
|
||||||
|
}
|
||||||
|
|
||||||
|
/*
|
||||||
|
public static String getMethodSignature(Method method) {
|
||||||
|
StringBuilder ret = new StringBuilder()
|
||||||
|
.append(method.getDeclaringClass().getName())
|
||||||
|
.append(".")
|
||||||
|
.append(method.getName())
|
||||||
|
.append("(");
|
||||||
|
|
||||||
|
int index = 0;
|
||||||
|
java.lang.reflect.Type[] paraTypes = method.getGenericParameterTypes();
|
||||||
|
for (java.lang.reflect.Type type : paraTypes) {
|
||||||
|
if (index++ > 0) {
|
||||||
|
ret.append(", ");
|
||||||
|
}
|
||||||
|
ret.append(type.getTypeName());
|
||||||
|
}
|
||||||
|
|
||||||
|
return ret.append(")").toString();
|
||||||
|
}*/
|
||||||
|
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
||||||
|
@@ -17,7 +17,6 @@
|
|||||||
package com.jfinal.template;
|
package com.jfinal.template;
|
||||||
|
|
||||||
import java.io.File;
|
import java.io.File;
|
||||||
import java.io.FileNotFoundException;
|
|
||||||
import java.io.FileOutputStream;
|
import java.io.FileOutputStream;
|
||||||
import java.io.IOException;
|
import java.io.IOException;
|
||||||
import java.io.OutputStream;
|
import java.io.OutputStream;
|
||||||
@@ -117,16 +116,10 @@ public class Template {
|
|||||||
* 适用于代码生成器类似应用场景
|
* 适用于代码生成器类似应用场景
|
||||||
*/
|
*/
|
||||||
public void render(Map<?, ?> data, File file) {
|
public void render(Map<?, ?> data, File file) {
|
||||||
FileOutputStream fos = null;
|
try (FileOutputStream fos = new FileOutputStream(file)) {
|
||||||
try {
|
|
||||||
fos = new FileOutputStream(file);
|
|
||||||
render(data, fos);
|
render(data, fos);
|
||||||
} catch (FileNotFoundException e) {
|
} catch (IOException e) {
|
||||||
throw new RuntimeException(e);
|
throw new RuntimeException(e);
|
||||||
} finally {
|
|
||||||
if (fos != null) {
|
|
||||||
try {fos.close();} catch (IOException e) {e.printStackTrace(System.err);}
|
|
||||||
}
|
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@@ -28,10 +28,10 @@ import com.jfinal.template.stat.Scope;
|
|||||||
*
|
*
|
||||||
* field 表达式取值优先次序,以 user.name 为例
|
* field 表达式取值优先次序,以 user.name 为例
|
||||||
* 1:假如 user.getName() 存在,则优先调用
|
* 1:假如 user.getName() 存在,则优先调用
|
||||||
* 2:假如 user 为 Model 子类,则调用 user.get("name")
|
* 2:假如 user 具有 public name 属性,则取 user.name 属性值
|
||||||
* 3:假如 user 为 Record,则调用 user.get("name")
|
* 3:假如 user 为 Model 子类,则调用 user.get("name")
|
||||||
* 4:假如 user 为 Map,则调用 user.get("name")
|
* 4:假如 user 为 Record,则调用 user.get("name")
|
||||||
* 5:假如 user 具有 public name 属性,则取 user.name 属性值
|
* 5:假如 user 为 Map,则调用 user.get("name")
|
||||||
*/
|
*/
|
||||||
public class Field extends Expr {
|
public class Field extends Expr {
|
||||||
|
|
||||||
|
@@ -44,10 +44,13 @@ public class FieldKit {
|
|||||||
LinkedList<FieldGetter> ret = new LinkedList<FieldGetter>();
|
LinkedList<FieldGetter> ret = new LinkedList<FieldGetter>();
|
||||||
|
|
||||||
ret.addLast(new GetterMethodFieldGetter(null));
|
ret.addLast(new GetterMethodFieldGetter(null));
|
||||||
|
ret.addLast(new RealFieldGetter(null));
|
||||||
// ret.addLast(new ModelFieldGetter());
|
// ret.addLast(new ModelFieldGetter());
|
||||||
// ret.addLast(new RecordFieldGetter());
|
// ret.addLast(new RecordFieldGetter());
|
||||||
ret.addLast(new MapFieldGetter());
|
ret.addLast(new MapFieldGetter());
|
||||||
ret.addLast(new RealFieldGetter(null));
|
|
||||||
|
// 挪到第二的位置,addSharedObject(..., modelObj) 用法可以获取到 model 中的 public 属性
|
||||||
|
// ret.addLast(new RealFieldGetter(null));
|
||||||
ret.addLast(new ArrayLengthGetter());
|
ret.addLast(new ArrayLengthGetter());
|
||||||
// ret.addLast(new IsMethodFieldGetter());
|
// ret.addLast(new IsMethodFieldGetter());
|
||||||
|
|
||||||
|
@@ -18,7 +18,6 @@ package com.jfinal.template.source;
|
|||||||
|
|
||||||
import java.io.BufferedReader;
|
import java.io.BufferedReader;
|
||||||
import java.io.File;
|
import java.io.File;
|
||||||
import java.io.IOException;
|
|
||||||
import java.io.InputStream;
|
import java.io.InputStream;
|
||||||
import java.io.InputStreamReader;
|
import java.io.InputStreamReader;
|
||||||
import java.net.URL;
|
import java.net.URL;
|
||||||
@@ -141,9 +140,8 @@ public class ClassPathSource implements ISource {
|
|||||||
|
|
||||||
public static StringBuilder loadFile(InputStream inputStream, String encoding) {
|
public static StringBuilder loadFile(InputStream inputStream, String encoding) {
|
||||||
StringBuilder ret = new StringBuilder();
|
StringBuilder ret = new StringBuilder();
|
||||||
BufferedReader br = null;
|
|
||||||
try {
|
try (BufferedReader br = new BufferedReader(new InputStreamReader(inputStream, encoding))) {
|
||||||
br = new BufferedReader(new InputStreamReader(inputStream, encoding));
|
|
||||||
// br = new BufferedReader(new FileReader(fileName));
|
// br = new BufferedReader(new FileReader(fileName));
|
||||||
String line = br.readLine();
|
String line = br.readLine();
|
||||||
if (line != null) {
|
if (line != null) {
|
||||||
@@ -159,16 +157,6 @@ public class ClassPathSource implements ISource {
|
|||||||
} catch (Exception e) {
|
} catch (Exception e) {
|
||||||
throw new RuntimeException(e);
|
throw new RuntimeException(e);
|
||||||
}
|
}
|
||||||
finally {
|
|
||||||
if (br != null) {
|
|
||||||
try {
|
|
||||||
br.close();
|
|
||||||
} catch (IOException e) {
|
|
||||||
// com.jfinal.kit.LogKit.error(e.getMessage(), e);
|
|
||||||
e.printStackTrace();
|
|
||||||
}
|
|
||||||
}
|
|
||||||
}
|
|
||||||
}
|
}
|
||||||
|
|
||||||
public String toString() {
|
public String toString() {
|
||||||
|
@@ -19,7 +19,6 @@ package com.jfinal.template.source;
|
|||||||
import java.io.BufferedReader;
|
import java.io.BufferedReader;
|
||||||
import java.io.File;
|
import java.io.File;
|
||||||
import java.io.FileInputStream;
|
import java.io.FileInputStream;
|
||||||
import java.io.IOException;
|
|
||||||
import java.io.InputStreamReader;
|
import java.io.InputStreamReader;
|
||||||
import com.jfinal.template.EngineConfig;
|
import com.jfinal.template.EngineConfig;
|
||||||
|
|
||||||
@@ -92,9 +91,8 @@ public class FileSource implements ISource {
|
|||||||
|
|
||||||
public static StringBuilder loadFile(File file, String encoding) {
|
public static StringBuilder loadFile(File file, String encoding) {
|
||||||
StringBuilder ret = new StringBuilder((int)file.length() + 3);
|
StringBuilder ret = new StringBuilder((int)file.length() + 3);
|
||||||
BufferedReader br = null;
|
|
||||||
try {
|
try (BufferedReader br = new BufferedReader(new InputStreamReader(new FileInputStream(file), encoding))) {
|
||||||
br = new BufferedReader(new InputStreamReader(new FileInputStream(file), encoding));
|
|
||||||
// br = new BufferedReader(new FileReader(fileName));
|
// br = new BufferedReader(new FileReader(fileName));
|
||||||
String line = br.readLine();
|
String line = br.readLine();
|
||||||
if (line != null) {
|
if (line != null) {
|
||||||
@@ -110,16 +108,6 @@ public class FileSource implements ISource {
|
|||||||
} catch (Exception e) {
|
} catch (Exception e) {
|
||||||
throw new RuntimeException(e);
|
throw new RuntimeException(e);
|
||||||
}
|
}
|
||||||
finally {
|
|
||||||
if (br != null) {
|
|
||||||
try {
|
|
||||||
br.close();
|
|
||||||
} catch (IOException e) {
|
|
||||||
// com.jfinal.kit.LogKit.error(e.getMessage(), e);
|
|
||||||
e.printStackTrace();
|
|
||||||
}
|
|
||||||
}
|
|
||||||
}
|
|
||||||
}
|
}
|
||||||
|
|
||||||
public String toString() {
|
public String toString() {
|
||||||
|
Reference in New Issue
Block a user