Commit d913a858 authored by Dave Cridland's avatar Dave Cridland

OF-1156 Make storing null in caches non-fatal by default

parent ebc579ea
...@@ -28,6 +28,7 @@ import java.util.Map; ...@@ -28,6 +28,7 @@ import java.util.Map;
import java.util.NoSuchElementException; import java.util.NoSuchElementException;
import java.util.Set; import java.util.Set;
import org.jivesoftware.util.JiveGlobals;
import org.jivesoftware.util.LinkedListNode; import org.jivesoftware.util.LinkedListNode;
import org.slf4j.Logger; import org.slf4j.Logger;
import org.slf4j.LoggerFactory; import org.slf4j.LoggerFactory;
...@@ -61,6 +62,7 @@ public class DefaultCache<K, V> implements Cache<K, V> { ...@@ -61,6 +62,7 @@ public class DefaultCache<K, V> implements Cache<K, V> {
private static final String NULL_KEY_IS_NOT_ALLOWED = "Null key is not allowed!"; private static final String NULL_KEY_IS_NOT_ALLOWED = "Null key is not allowed!";
private static final String NULL_VALUE_IS_NOT_ALLOWED = "Null value is not allowed!"; private static final String NULL_VALUE_IS_NOT_ALLOWED = "Null value is not allowed!";
private static final boolean allowNull = JiveGlobals.getBooleanProperty("cache.allow.null", true);
private static final Logger Log = LoggerFactory.getLogger(DefaultCache.class); private static final Logger Log = LoggerFactory.getLogger(DefaultCache.class);
...@@ -701,8 +703,16 @@ public class DefaultCache<K, V> implements Cache<K, V> { ...@@ -701,8 +703,16 @@ public class DefaultCache<K, V> implements Cache<K, V> {
} }
private void checkNotNull(final Object argument, final String message) { private void checkNotNull(final Object argument, final String message) {
if (argument == null) { try {
throw new NullPointerException(message); if (argument == null) {
throw new NullPointerException(message);
}
} catch (NullPointerException e) {
if (allowNull) {
Log.error("Ignoring null store in Cache: ", e); // Gives us a trace for debugging.
} else {
throw e;
}
} }
} }
} }
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