X-Git-Url: http://git.nikiroo.be/?a=blobdiff_plain;f=src%2Fbe%2Fnikiroo%2Ffanfix%2Fsupported%2FEpub.java;h=c71ba1785ea9db20e6d10bc5b5a72f6612057d53;hb=727108fef9dcc661d45fa69ebf8b76f5128a2b6f;hp=7ac3efc78703f7fb9e4a27fc2668c04c541965ad;hpb=4ec79417fe5bd4344ac12b39ac8c98db8f9276f6;p=fanfix.git diff --git a/src/be/nikiroo/fanfix/supported/Epub.java b/src/be/nikiroo/fanfix/supported/Epub.java index 7ac3efc..c71ba17 100644 --- a/src/be/nikiroo/fanfix/supported/Epub.java +++ b/src/be/nikiroo/fanfix/supported/Epub.java @@ -27,8 +27,6 @@ import be.nikiroo.utils.StringUtils; * @author niki */ class Epub extends InfoText { - private File sourceFileOriginal; - private MetaData meta; private File tmpDir; private String desc; @@ -36,13 +34,8 @@ class Epub extends InfoText { private URL fakeSource; private InputStream fakeIn; - @Override - public String getSourceName() { - return "epub"; - } - public File getSourceFileOriginal() { - return sourceFileOriginal; + return super.getSourceFile(); } @Override @@ -61,7 +54,19 @@ class Epub extends InfoText { @Override protected InputStream getInput() { - return fakeIn; + if (fakeIn != null) { + try { + fakeIn.reset(); + } catch (IOException e) { + Instance.getTraceHandler() + .error(new IOException( + "Cannot reset the Epub Text stream", e)); + } + + return fakeIn; + } + + return null; } @Override @@ -175,9 +180,6 @@ class Epub extends InfoText { if (tmpInfo.exists()) { meta = InfoReader.readMeta(tmpInfo, true); - if (cover != null) { - meta.setCover(cover); - } tmpInfo.delete(); } else { if (title == null || title.isEmpty()) { @@ -191,13 +193,23 @@ class Epub extends InfoText { meta = new MetaData(); meta.setLang("en"); meta.setTags(new ArrayList()); - meta.setSource(getSourceName()); + meta.setSource(getType().getSourceName()); meta.setUuid(url); meta.setUrl(url); meta.setTitle(title); meta.setAuthor(author); meta.setImageDocument(isImagesDocumentByDefault()); } + + if (meta.getCover() == null) { + if (cover != null) { + meta.setCover(cover); + } else { + meta.setCover(InfoReader + .getCoverByName(getSourceFileOriginal().toURI() + .toURL())); + } + } } finally { if (zipIn != null) { zipIn.close();