From fe01358a4e3cf8e8c1d625937f89ddb9c1a7d8dc Mon Sep 17 00:00:00 2001 From: Matt Holgate Date: Wed, 2 Jul 2014 18:05:43 +0100 Subject: Pass mimetype when opening a document from a stream. Fixes opening non-PDF files from email programs that use a ContentProvider to supply attachments. --- platform/android/jni/mupdf.c | 16 ++++++++++++++-- 1 file changed, 14 insertions(+), 2 deletions(-) (limited to 'platform/android/jni/mupdf.c') diff --git a/platform/android/jni/mupdf.c b/platform/android/jni/mupdf.c index 04f1ceff..b9578d44 100644 --- a/platform/android/jni/mupdf.c +++ b/platform/android/jni/mupdf.c @@ -408,13 +408,14 @@ static void bufferStreamSeek(fz_stream *stream, int offset, int whence) } JNIEXPORT jlong JNICALL -JNI_FN(MuPDFCore_openBuffer)(JNIEnv * env, jobject thiz) +JNI_FN(MuPDFCore_openBuffer)(JNIEnv * env, jobject thiz, jstring jmagic) { globals *glo; fz_context *ctx; jclass clazz; fz_stream *stream = NULL; buffer_state *bs; + const char *magic; #ifdef NDK_PROFILER monstartup("libmupdf.so"); @@ -432,11 +433,20 @@ JNI_FN(MuPDFCore_openBuffer)(JNIEnv * env, jobject thiz) glo->thiz = thiz; buffer_fid = (*env)->GetFieldID(env, clazz, "fileBuffer", "[B"); + magic = (*env)->GetStringUTFChars(env, jmagic, NULL); + if (magic == NULL) + { + LOGE("Failed to get magic"); + free(glo); + return 0; + } + /* 128 MB store for low memory devices. Tweak as necessary. */ glo->ctx = ctx = fz_new_context(NULL, NULL, 128 << 20); if (!ctx) { LOGE("Failed to initialise context"); + (*env)->ReleaseStringUTFChars(env, jmagic, magic); free(glo); return 0; } @@ -458,7 +468,7 @@ JNI_FN(MuPDFCore_openBuffer)(JNIEnv * env, jobject thiz) fz_try(ctx) { glo->current_path = NULL; - glo->doc = fz_open_document_with_stream(ctx, "", stream); + glo->doc = fz_open_document_with_stream(ctx, magic, stream); alerts_init(glo); } fz_catch(ctx) @@ -482,6 +492,8 @@ JNI_FN(MuPDFCore_openBuffer)(JNIEnv * env, jobject thiz) glo = NULL; } + (*env)->ReleaseStringUTFChars(env, jmagic, magic); + return (jlong)(intptr_t)glo; } -- cgit v1.2.3