X-Git-Url: https://git.pterodactylus.net/?a=blobdiff_plain;f=src%2Fmain%2Fjava%2Fnet%2Fpterodactylus%2Fsone%2Fcore%2FSoneDownloader.java;h=efd13e4b24068a9c8775e5d2b2a307db4b6a57fd;hb=1c7c9a54dde1c45ea26401ac26837ccf04b01962;hp=4dd634cc32defcd8dd519ce9c5bd198b2c07aeb8;hpb=94041feaf2a141b8c75725301f06d7e4bc617a12;p=Sone.git diff --git a/src/main/java/net/pterodactylus/sone/core/SoneDownloader.java b/src/main/java/net/pterodactylus/sone/core/SoneDownloader.java index 4dd634c..efd13e4 100644 --- a/src/main/java/net/pterodactylus/sone/core/SoneDownloader.java +++ b/src/main/java/net/pterodactylus/sone/core/SoneDownloader.java @@ -137,7 +137,14 @@ public class SoneDownloader extends AbstractService { xmlBucket = fetchResult.asBucket(); xmlInputStream = xmlBucket.getInputStream(); Document document = XML.transformToDocument(xmlInputStream); - SimpleXML soneXml = SimpleXML.fromDocument(document); + SimpleXML soneXml; + try { + soneXml = SimpleXML.fromDocument(document); + } catch (NullPointerException npe1) { + /* for some reason, invalid XML can cause NPEs. */ + logger.log(Level.WARNING, "XML for Sone " + sone + " can not be parsed!", npe1); + return; + } /* check ID. */ String soneId = soneXml.getValue("id", null); @@ -226,6 +233,9 @@ public class SoneDownloader extends AbstractService { /* atomic setter operation on the Sone. */ synchronized (sone) { sone.setProfile(profile); + sone.setPosts(posts); + sone.setReplies(replies); + sone.setModificationCounter(0); } } catch (IOException ioe1) { logger.log(Level.WARNING, "Could not read XML file from " + sone + "!", ioe1);