summaryrefslogtreecommitdiff
path: root/apps
diff options
context:
space:
mode:
authorTor Andersson <tor.andersson@artifex.com>2012-01-30 15:12:00 +0100
committerTor Andersson <tor.andersson@artifex.com>2012-01-30 15:12:00 +0100
commit1e3461a02021fba4d27c4f7678f0ad21d8954eee (patch)
tree23317b77247c45c204016907e09e3a84e2ddfc25 /apps
parent99401f12b3969404996dbbeb5a6bff58e3451781 (diff)
downloadmupdf-1e3461a02021fba4d27c4f7678f0ad21d8954eee.tar.xz
Add CBZ (comic book zip-file) parser.
Diffstat (limited to 'apps')
-rw-r--r--apps/pdfapp.c57
-rw-r--r--apps/pdfapp.h1
-rw-r--r--apps/win_main.c3
-rw-r--r--apps/x11_main.c1
4 files changed, 61 insertions, 1 deletions
diff --git a/apps/pdfapp.c b/apps/pdfapp.c
index 9a3b9d0f..74479a1c 100644
--- a/apps/pdfapp.c
+++ b/apps/pdfapp.c
@@ -1,6 +1,7 @@
#include "fitz.h"
#include "mupdf.h"
#include "muxps.h"
+#include "mucbz.h"
#include "pdfapp.h"
#include <ctype.h> /* for tolower() */
@@ -189,10 +190,32 @@ static void pdfapp_open_xps(pdfapp_t *app, char *filename, int fd)
app->pagecount = xps_count_pages(app->xps);
}
+static void pdfapp_open_cbz(pdfapp_t *app, char *filename, int fd)
+{
+ fz_stream *file;
+
+ file = fz_open_fd(app->ctx, fd);
+ fz_try(app->ctx)
+ {
+ app->cbz = cbz_open_document_with_stream(file);
+ }
+ fz_catch(app->ctx)
+ {
+ pdfapp_error(app, "cannot open document");
+ }
+ fz_close(file);
+
+ app->doctitle = fz_strdup(app->ctx, filename);
+
+ app->pagecount = cbz_count_pages(app->cbz);
+}
+
void pdfapp_open(pdfapp_t *app, char *filename, int fd, int reload)
{
if (strstr(filename, ".xps") || strstr(filename, ".XPS") || strstr(filename, ".rels"))
pdfapp_open_xps(app, filename, fd);
+ else if (strstr(filename, ".cbz") || strstr(filename, ".CBZ"))
+ pdfapp_open_cbz(app, filename, fd);
else
pdfapp_open_pdf(app, filename, fd);
@@ -254,6 +277,12 @@ void pdfapp_close(pdfapp_t *app)
app->xps = NULL;
}
+ if (app->cbz)
+ {
+ cbz_close_document(app->cbz);
+ app->cbz = NULL;
+ }
+
fz_flush_warnings(app->ctx);
}
@@ -349,6 +378,32 @@ static void pdfapp_loadpage_xps(pdfapp_t *app)
xps_free_page(app->xps, page);
}
+static void pdfapp_loadpage_cbz(pdfapp_t *app)
+{
+ cbz_page *page;
+ fz_device *mdev;
+
+ fz_try(app->ctx)
+ {
+ page = cbz_load_page(app->cbz, app->pageno - 1);
+ }
+ fz_catch(app->ctx)
+ {
+ pdfapp_error(app, "cannot load page");
+ }
+
+ app->page_bbox = cbz_bound_page(app->cbz, page);
+ app->page_links = NULL;
+
+ /* Create display list */
+ app->page_list = fz_new_display_list(app->ctx);
+ mdev = fz_new_list_device(app->ctx, app->page_list);
+ cbz_run_page(app->cbz, page, mdev, fz_identity, NULL);
+ fz_free_device(mdev);
+
+ cbz_free_page(app->cbz, page);
+}
+
static void pdfapp_showpage(pdfapp_t *app, int loadpage, int drawpage, int repaint)
{
char buf[256];
@@ -373,6 +428,8 @@ static void pdfapp_showpage(pdfapp_t *app, int loadpage, int drawpage, int repai
pdfapp_loadpage_pdf(app);
if (app->xps)
pdfapp_loadpage_xps(app);
+ if (app->cbz)
+ pdfapp_loadpage_cbz(app);
/* Zero search hit position */
app->hit = -1;
diff --git a/apps/pdfapp.h b/apps/pdfapp.h
index c1b03be2..2dffb14e 100644
--- a/apps/pdfapp.h
+++ b/apps/pdfapp.h
@@ -32,6 +32,7 @@ struct pdfapp_s
/* current document params */
pdf_document *pdf;
xps_document *xps;
+ cbz_document *cbz;
char *doctitle;
fz_outline *outline;
diff --git a/apps/win_main.c b/apps/win_main.c
index dcc2d0a6..fc929a14 100644
--- a/apps/win_main.c
+++ b/apps/win_main.c
@@ -1,6 +1,7 @@
#include "fitz.h"
#include "mupdf.h"
#include "muxps.h"
+#include "mucbz.h"
#include "pdfapp.h"
#ifndef UNICODE
@@ -110,7 +111,7 @@ int winfilename(wchar_t *buf, int len)
ofn.nMaxFile = len;
ofn.lpstrInitialDir = NULL;
ofn.lpstrTitle = L"MuPDF: Open PDF file";
- ofn.lpstrFilter = L"Documents (*.pdf;*.xps)\0*.xps;*.pdf\0PDF Files (*.pdf)\0*.pdf\0XPS Files (*.xps)\0*.xps\0All Files\0*\0\0";
+ ofn.lpstrFilter = L"Documents (*.pdf;*.xps;*.cbz)\0*.cbz;*.xps;*.pdf\0PDF Files (*.pdf)\0*.pdf\0XPS Files (*.xps)\0*.xps\0CBZ Files (*cbz)\0*.cbz\0All Files\0*\0\0";
ofn.Flags = OFN_FILEMUSTEXIST|OFN_HIDEREADONLY;
return GetOpenFileNameW(&ofn);
}
diff --git a/apps/x11_main.c b/apps/x11_main.c
index 907b843c..6815037a 100644
--- a/apps/x11_main.c
+++ b/apps/x11_main.c
@@ -1,6 +1,7 @@
#include "fitz.h"
#include "mupdf.h"
#include "muxps.h"
+#include "mucbz.h"
#include "pdfapp.h"
#include <X11/Xlib.h>