summaryrefslogtreecommitdiffstats
path: root/source/ap/ghostscript/9b6fe6e1008f1b9b7fc3109b5f94db8d970fbcaa.patch
diff options
context:
space:
mode:
Diffstat (limited to 'source/ap/ghostscript/9b6fe6e1008f1b9b7fc3109b5f94db8d970fbcaa.patch')
-rw-r--r--source/ap/ghostscript/9b6fe6e1008f1b9b7fc3109b5f94db8d970fbcaa.patch52
1 files changed, 52 insertions, 0 deletions
diff --git a/source/ap/ghostscript/9b6fe6e1008f1b9b7fc3109b5f94db8d970fbcaa.patch b/source/ap/ghostscript/9b6fe6e1008f1b9b7fc3109b5f94db8d970fbcaa.patch
new file mode 100644
index 000000000..352dbd866
--- /dev/null
+++ b/source/ap/ghostscript/9b6fe6e1008f1b9b7fc3109b5f94db8d970fbcaa.patch
@@ -0,0 +1,52 @@
+From 9b6fe6e1008f1b9b7fc3109b5f94db8d970fbcaa Mon Sep 17 00:00:00 2001
+From: Ken Sharp <Ken.Sharp@artifex.com>
+Date: Mon, 18 Sep 2023 15:47:12 +0100
+Subject: [PATCH] PDF interpreter - fix PageList processing
+
+Bug #707137 "Error processing PDF while using the parameter -sPageList"
+
+There are actually 2 problems; firstly a copy/paste error of the
+operand stack index when returning the page list meant that the values
+were returned in reverse order.
+
+Secondly the PageList string wasn't actually being passed as an operand
+at all.
+
+This only affects the PDF interpreter because it (unfortunately) uses a
+different mechanism from the PostScript interpreter.
+---
+ Resource/Init/pdf_main.ps | 3 +--
+ psi/zpdfops.c | 2 +-
+ 2 files changed, 2 insertions(+), 3 deletions(-)
+
+diff --git a/Resource/Init/pdf_main.ps b/Resource/Init/pdf_main.ps
+index e541835ae..73097f1a7 100644
+--- a/Resource/Init/pdf_main.ps
++++ b/Resource/Init/pdf_main.ps
+@@ -710,8 +710,7 @@ currentdict /PDFSwitches undef
+ {
+ /PageList where {
+ pop
+- pdfpagecount
+- .PDFparsePageList
++ PageList pdfpagecount .PDFparsePageList
+ dup 0 eq { % No ranges, error
+ (\n **** Error: Invalid PageList: ) print
+ PageList print
+diff --git a/psi/zpdfops.c b/psi/zpdfops.c
+index 207130f1a..e7e0a42ee 100644
+--- a/psi/zpdfops.c
++++ b/psi/zpdfops.c
+@@ -1447,7 +1447,7 @@ static int zPDFparsePageList(i_ctx_t *i_ctx_p)
+ }
+ /* push the even/odd, start, end triples on the stack */
+ for (i=0; i < size; i++) {
+- o = ref_stack_index(&o_stack, 0);
++ o = ref_stack_index(&o_stack, size - i);
+ if (o == NULL)
+ return_error(gs_error_stackunderflow);
+ /* skip the initial "ordered" flag */
+--
+2.34.1
+
+