Fix CBZ importer, improve GUI
[fanfix.git] / src / be / nikiroo / fanfix / supported / Cbz.java
index 012c0474a95df1a05cae162a9518e322f9099a80..1080ad2755adebb174ad7a3e04f4053c9e0b35f4 100644 (file)
@@ -5,6 +5,8 @@ import java.io.IOException;
 import java.io.InputStream;
 import java.net.URL;
 import java.util.ArrayList;
+import java.util.Collections;
+import java.util.List;
 import java.util.zip.ZipEntry;
 import java.util.zip.ZipInputStream;
 
@@ -39,18 +41,18 @@ class Cbz extends Epub {
        protected boolean requireInfo() {
                return false;
        }
-       
-       @Override
-       public boolean isImageDocument(URL source, InputStream in)
-                       throws IOException {
-               return true;
-       }
 
        @Override
        protected boolean getCover() {
                return false;
        }
 
+       @Override
+       protected void preprocess(URL source, InputStream in) throws IOException {
+               super.preprocess(source, in);
+               meta.setImageDocument(true);
+       }
+
        @Override
        public Story process(URL url) throws IOException {
                Story story = processMeta(url, false, true);
@@ -60,6 +62,7 @@ class Cbz extends Epub {
 
                ZipInputStream zipIn = new ZipInputStream(getInput());
 
+               List<String> images = new ArrayList<String>();
                for (ZipEntry entry = zipIn.getNextEntry(); entry != null; entry = zipIn
                                .getNextEntry()) {
                        if (!entry.isDirectory()
@@ -73,14 +76,10 @@ class Cbz extends Epub {
                                }
 
                                if (imageEntry) {
+                                       String uuid = meta.getUuid() + "_" + entry.getName();
+                                       images.add(uuid);
                                        try {
-                                               // we assume that we can get the UUID without a stream
-                                               String uuid = getUuid(url, null) + "_"
-                                                               + entry.getName();
-
                                                Instance.getCache().addToCache(zipIn, uuid);
-                                               chap.getParagraphs().add(
-                                                               new Paragraph(new File(uuid).toURI().toURL()));
                                        } catch (Exception e) {
                                                Instance.syserr(e);
                                        }
@@ -88,6 +87,18 @@ class Cbz extends Epub {
                        }
                }
 
+               // ZIP order is not sure
+               Collections.sort(images);
+
+               for (String uuid : images) {
+                       try {
+                               chap.getParagraphs().add(
+                                               new Paragraph(new File(uuid).toURI().toURL()));
+                       } catch (Exception e) {
+                               Instance.syserr(e);
+                       }
+               }
+
                return story;
        }
 }