summaryrefslogtreecommitdiff
path: root/src/main/java/com/c2kernel/persistency
diff options
context:
space:
mode:
authorAndrew Branson <andrew.branson@cern.ch>2013-01-24 16:05:15 +0100
committerAndrew Branson <andrew.branson@cern.ch>2013-01-24 16:05:15 +0100
commit5c2f3fa9ce4e46406cc2d3fa606f28ef153a93b7 (patch)
treeaad651f98c8b6a3b7c6704fc56ef01908ac2160b /src/main/java/com/c2kernel/persistency
parent35e8043542178752ef18d40681c3b3e028b8c35b (diff)
Stop nullpointerexception if a missing resource was requested
Diffstat (limited to 'src/main/java/com/c2kernel/persistency')
-rw-r--r--src/main/java/com/c2kernel/persistency/XMLDBClusterStorage.java23
1 files changed, 14 insertions, 9 deletions
diff --git a/src/main/java/com/c2kernel/persistency/XMLDBClusterStorage.java b/src/main/java/com/c2kernel/persistency/XMLDBClusterStorage.java
index 205876d..8521a17 100644
--- a/src/main/java/com/c2kernel/persistency/XMLDBClusterStorage.java
+++ b/src/main/java/com/c2kernel/persistency/XMLDBClusterStorage.java
@@ -152,15 +152,20 @@ public class XMLDBClusterStorage extends ClusterStorage {
if (itemColl == null) return null; // doesn't exist
try {
- String resource = path.replace('/', '.');
- String objString = (String)itemColl.getResource(resource).getContent();
- itemColl.close();
- if (type.equals("Outcome"))
- return new Outcome(path, objString);
- else {
- C2KLocalObject obj = (C2KLocalObject)Gateway.getMarshaller().unmarshall(objString);
- return obj;
- }
+ String resourceName = path.replace('/', '.');
+ Resource resource = itemColl.getResource(resourceName);
+ if (resource != null) {
+ String objString = (String)resource.getContent();
+ itemColl.close();
+ if (type.equals("Outcome"))
+ return new Outcome(path, objString);
+ else {
+ C2KLocalObject obj = (C2KLocalObject)Gateway.getMarshaller().unmarshall(objString);
+ return obj;
+ }
+ }
+ else
+ return null;
} catch (Exception e) {
Logger.error(e);
throw new ClusterStorageException("XMLDB error");