Blame SOURCES/poppler-20.11.0-bad-generation.patch
|
|
13f96b |
From 4f478daa6a9734b8f269a6586bdce2909844bb6f Mon Sep 17 00:00:00 2001
|
|
|
13f96b |
From: Albert Astals Cid <aacid@kde.org>
|
|
|
13f96b |
Date: Wed, 23 Dec 2020 23:52:58 +0100
|
|
|
13f96b |
Subject: Fix opening files by some generators that are a bit broken
|
|
|
13f96b |
|
|
|
13f96b |
But Adobe opens it and it's easy to fix
|
|
|
13f96b |
|
|
|
13f96b |
diff --git a/poppler/XRef.cc b/poppler/XRef.cc
|
|
|
13f96b |
index 66d3f04a..c36c747a 100644
|
|
|
13f96b |
--- a/poppler/XRef.cc
|
|
|
13f96b |
+++ b/poppler/XRef.cc
|
|
|
13f96b |
@@ -45,6 +45,7 @@
|
|
|
13f96b |
#include <cctype>
|
|
|
13f96b |
#include <climits>
|
|
|
13f96b |
#include <cfloat>
|
|
|
13f96b |
+#include <limits>
|
|
|
13f96b |
#include "goo/gfile.h"
|
|
|
13f96b |
#include "goo/gmem.h"
|
|
|
13f96b |
#include "Object.h"
|
|
|
13f96b |
@@ -793,8 +794,13 @@ bool XRef::readXRefStreamSection(Stream *xrefStr, const int *w, int first, int n
|
|
|
13f96b |
gen = (gen << 8) + c;
|
|
|
13f96b |
}
|
|
|
13f96b |
if (gen > INT_MAX) {
|
|
|
13f96b |
- error(errSyntaxError, -1, "Gen inside xref table too large (bigger than INT_MAX)");
|
|
|
13f96b |
- return false;
|
|
|
13f96b |
+ if (i == 0 && gen == std::numeric_limits<uint32_t>::max()) {
|
|
|
13f96b |
+ // workaround broken generators
|
|
|
13f96b |
+ gen = 65535;
|
|
|
13f96b |
+ } else {
|
|
|
13f96b |
+ error(errSyntaxError, -1, "Gen inside xref table too large (bigger than INT_MAX)");
|
|
|
13f96b |
+ return false;
|
|
|
13f96b |
+ }
|
|
|
13f96b |
}
|
|
|
13f96b |
if (entries[i].offset == -1) {
|
|
|
13f96b |
switch (type) {
|