treat empty list as null

This commit is contained in:
Reinhard Pointner 2017-03-27 21:24:01 +08:00
parent 3511f08344
commit b496882c05
2 changed files with 31 additions and 29 deletions

View File

@ -4,7 +4,6 @@ import static net.filebot.util.ExceptionUtilities.*;
import java.lang.reflect.Method;
import java.util.AbstractMap;
import java.util.Collection;
import java.util.HashSet;
import java.util.Map;
import java.util.Set;
@ -43,21 +42,7 @@ public class ExpressionBindings extends AbstractMap<String, Object> implements B
}
protected boolean isUndefined(Object value) {
if (value == null) {
return true;
}
// treat empty string as null
if (value instanceof CharSequence && value.toString().isEmpty()) {
return true;
}
// treat empty list as null
if (value instanceof Collection && ((Collection) value).isEmpty()) {
return true;
}
return false;
return value == null || ExpressionFormatFunctions.isEmptyValue(value);
}
public Object getBindingBean() {

View File

@ -28,31 +28,40 @@ import net.filebot.util.FileUtilities;
*/
public class ExpressionFormatFunctions {
/**
/*
* General helpers and utilities
*/
public static Object call(Object object) {
if (object instanceof Closure<?>) {
if (object instanceof Closure) {
try {
return ((Closure<?>) object).call();
return call(((Closure) object).call());
} catch (Exception e) {
return null;
}
}
// treat empty string as null
if (object instanceof CharSequence && object.toString().isEmpty()) {
return null;
}
// treat empty list as null
if (object instanceof Collection && ((Collection) object).isEmpty()) {
if (isEmptyValue(object)) {
return null;
}
return object;
}
public static boolean isEmptyValue(Object object) {
// treat empty string as null
if (object instanceof CharSequence && object.toString().isEmpty()) {
return true;
}
// treat empty list as null
if (object instanceof Collection && ((Collection) object).isEmpty()) {
return true;
}
return false;
}
public static Object any(Object c1, Object c2, Object... cN) {
return stream(c1, c2, cN).findFirst().orElse(null);
}
@ -69,18 +78,26 @@ public class ExpressionFormatFunctions {
return Stream.concat(Stream.of(c1, c2), Stream.of(cN)).map(ExpressionFormatFunctions::call).filter(Objects::nonNull);
}
/*
* Unix Shell / Windows PowerShell utilities
*/
public static String quote(Object c1, Object... cN) {
return Platform.isWindows() ? quote_ps(c1, cN) : quote_sh(c1, cN);
return Platform.isWindows() ? quotePowerShell(c1, cN) : quoteBash(c1, cN);
}
public static String quote_sh(Object c1, Object... cN) {
public static String quoteBash(Object c1, Object... cN) {
return stream(c1, null, cN).map(Objects::toString).map(s -> "'" + s.replace("'", "'\"'\"'") + "'").collect(joining(" "));
}
public static String quote_ps(Object c1, Object... cN) {
public static String quotePowerShell(Object c1, Object... cN) {
return stream(c1, null, cN).map(Objects::toString).map(s -> "@'\n" + s + "\n'@").collect(joining(" "));
}
/*
* I/O utilities
*/
public static Map<String, String> csv(Object path) throws IOException {
Pattern[] delimiter = { TAB, SEMICOLON };
Map<String, String> map = new LinkedHashMap<String, String>();