summaryrefslogtreecommitdiff
path: root/org.fox.ttcomics/src/main/java/org/fox/ttcomics2/archive/CbzComicArchive.java
diff options
context:
space:
mode:
Diffstat (limited to 'org.fox.ttcomics/src/main/java/org/fox/ttcomics2/archive/CbzComicArchive.java')
-rwxr-xr-xorg.fox.ttcomics/src/main/java/org/fox/ttcomics2/archive/CbzComicArchive.java35
1 files changed, 24 insertions, 11 deletions
diff --git a/org.fox.ttcomics/src/main/java/org/fox/ttcomics2/archive/CbzComicArchive.java b/org.fox.ttcomics/src/main/java/org/fox/ttcomics2/archive/CbzComicArchive.java
index 8757353..c3dae4c 100755
--- a/org.fox.ttcomics/src/main/java/org/fox/ttcomics2/archive/CbzComicArchive.java
+++ b/org.fox.ttcomics/src/main/java/org/fox/ttcomics2/archive/CbzComicArchive.java
@@ -3,22 +3,24 @@ package org.fox.ttcomics2.archive;
import android.os.Parcel;
import android.os.Parcelable;
+import net.lingala.zip4j.core.ZipFile;
+import net.lingala.zip4j.exception.ZipException;
+import net.lingala.zip4j.model.FileHeader;
+
import org.fox.ttcomics2.utils.NaturalOrderComparator;
import java.io.IOException;
import java.io.InputStream;
import java.util.ArrayList;
import java.util.Collections;
-import java.util.Enumeration;
-import java.util.zip.ZipEntry;
-import java.util.zip.ZipFile;
+import java.util.List;
public class CbzComicArchive extends ComicArchive {
private final String TAG = this.getClass().getSimpleName();
private String m_fileName;
private ZipFile m_zipFile;
- private ArrayList<ZipEntry> m_entries = new ArrayList<ZipEntry>();
+ private ArrayList<FileHeader> m_entries = new ArrayList<>();
@Override
public int getCount() {
@@ -27,19 +29,30 @@ public class CbzComicArchive extends ComicArchive {
@Override
public InputStream getItem(int index) throws IOException {
- return m_zipFile.getInputStream(m_entries.get(index));
+ try {
+ return m_zipFile.getInputStream(m_entries.get(index));
+ } catch (ZipException e) {
+ throw new IOException(e.getMessage());
+ }
}
private void initialize() throws IOException {
- m_zipFile = new ZipFile(m_fileName);
+ try {
+ m_zipFile = new ZipFile(m_fileName);
- Enumeration<? extends ZipEntry> e = m_zipFile.entries();
+ List<FileHeader> fileHeaders = m_zipFile.getFileHeaders();
- while (e.hasMoreElements()) {
- ZipEntry ze = e.nextElement();
- if (!ze.isDirectory() && isValidComic(ze.getName())) {
- m_entries.add(ze);
+ for (int i = 0; i < fileHeaders.size(); i++) {
+ FileHeader fh = fileHeaders.get(i);
+
+ if (fh != null) {
+ if (!fh.isDirectory() && isValidComic(fh.getFileName())) {
+ m_entries.add(fh);
+ }
+ }
}
+ } catch (ZipException e) {
+ throw new IOException(e.getMessage());
}
Collections.sort(m_entries, new NaturalOrderComparator());