X-Git-Url: http://git.nikiroo.be/?a=blobdiff_plain;f=library%2FWebLibrary.java;h=7381ae368661023aa3ac2a23c643d6f4461ac658;hb=379a497e6fd2b959c57b2ff4023413e2daf36232;hp=7566877cebd48343b47c1764ed31045ee8de78dd;hpb=6d465e886ae46c9da99117cc4302948f700a51c4;p=fanfix.git diff --git a/library/WebLibrary.java b/library/WebLibrary.java index 7566877..7381ae3 100644 --- a/library/WebLibrary.java +++ b/library/WebLibrary.java @@ -133,7 +133,17 @@ public class WebLibrary extends BasicLibrary { * in case of I/O errors */ public void stop() throws IOException { - post(WebLibraryUrls.EXIT_URL, null).close(); + try { + post(WebLibraryUrls.EXIT_URL, null).close(); + } catch (Exception e) { + try { + Thread.sleep(200); + } catch (InterruptedException e1) { + } + if (getStatus() != Status.UNAVAILABLE) { + throw new IOException("Cannot exit the library", e); + } + } } @Override @@ -163,11 +173,12 @@ public class WebLibrary extends BasicLibrary { InputStream in = post(WebLibraryUrls.getStoryUrlCover(luid)); try { Image img = new Image(in); - if (img.getSize() > 0) { - return img; + if (img.getSize() == 0) { + img.close(); + img = null; } - return null; + return img; } finally { in.close(); } @@ -178,11 +189,12 @@ public class WebLibrary extends BasicLibrary { InputStream in = post(WebLibraryUrls.getCoverUrlSource(source)); try { Image img = new Image(in); - if (img.getSize() > 0) { - return img; + if (img.getSize() == 0) { + img.close(); + img = null; } - return null; + return img; } finally { in.close(); } @@ -193,11 +205,12 @@ public class WebLibrary extends BasicLibrary { InputStream in = post(WebLibraryUrls.getCoverUrlAuthor(author)); try { Image img = new Image(in); - if (img.getSize() > 0) { - return img; + if (img.getSize() == 0) { + img.close(); + img = null; } - return null; + return img; } finally { in.close(); }