summaryrefslogtreecommitdiff
diff options
context:
space:
mode:
-rw-r--r--source/pdf/pdf-annot.c13
-rw-r--r--source/pdf/pdf-page.c5
2 files changed, 16 insertions, 2 deletions
diff --git a/source/pdf/pdf-annot.c b/source/pdf/pdf-annot.c
index bfc31e9a..c571a0a1 100644
--- a/source/pdf/pdf-annot.c
+++ b/source/pdf/pdf-annot.c
@@ -57,11 +57,22 @@ pdf_parse_link_dest(pdf_document *doc, pdf_obj *dest)
ld.kind = FZ_LINK_NONE;
return ld;
}
+
obj = pdf_array_get(dest, 0);
if (pdf_is_int(obj))
ld.ld.gotor.page = pdf_to_int(obj);
else
- ld.ld.gotor.page = pdf_lookup_page_number(doc, obj);
+ {
+ fz_try(doc->ctx)
+ {
+ ld.ld.gotor.page = pdf_lookup_page_number(doc, obj);
+ }
+ fz_catch(doc->ctx)
+ {
+ ld.kind = FZ_LINK_NONE;
+ return ld;
+ }
+ }
ld.kind = FZ_LINK_GOTO;
ld.ld.gotor.flags = 0;
diff --git a/source/pdf/pdf-page.c b/source/pdf/pdf-page.c
index 9f802927..66e72bc7 100644
--- a/source/pdf/pdf-page.c
+++ b/source/pdf/pdf-page.c
@@ -129,11 +129,14 @@ pdf_lookup_page_number(pdf_document *doc, pdf_obj *node)
int total = 0;
pdf_obj *parent, *parent2;
+ if (strcmp(pdf_to_name(pdf_dict_gets(node, "Type")), "Page") != 0)
+ fz_throw(ctx, FZ_ERROR_GENERIC, "invalid page object");
+
parent2 = parent = pdf_dict_gets(node, "Parent");
fz_var(parent);
fz_try(ctx)
{
- while (parent)
+ while (pdf_is_dict(parent))
{
if (pdf_mark_obj(parent))
fz_throw(ctx, FZ_ERROR_GENERIC, "cycle in page tree (parents)");