9ae3ca
From 004e3c10df0abda214f0c293f9e269fdd979c5ee Mon Sep 17 00:00:00 2001
9ae3ca
From: Albert Astals Cid <aacid@kde.org>
9ae3ca
Date: Wed, 18 Jul 2018 20:31:27 +0200
9ae3ca
Subject: Fix crash when Object has negative number
9ae3ca
9ae3ca
Spec says object number has to be > 0 and gen has to be >= 0
9ae3ca
9ae3ca
Reported by email
9ae3ca
9ae3ca
Modified by Marek Kasik for older release
9ae3ca
9ae3ca
diff --git a/poppler/Parser.cc b/poppler/Parser.cc
9ae3ca
index 39c9a967..8b0093e3 100644
9ae3ca
--- a/poppler/Parser.cc
9ae3ca
+++ b/poppler/Parser.cc
9ae3ca
@@ -154,9 +154,14 @@ Object Parser::getObj(GBool simpleOnly,
9ae3ca
     num = buf1.getInt();
9ae3ca
     shift();
9ae3ca
     if (buf1.isInt() && buf2.isCmd("R")) {
9ae3ca
+      const int gen = buf1.getInt();
9ae3ca
-      obj->initRef(num, buf1.getInt());
9ae3ca
+      obj->initRef(num, gen);
9ae3ca
       shift();
9ae3ca
       shift();
9ae3ca
+
9ae3ca
+      if (unlikely(num <= 0 || gen < 0)) {
9ae3ca
+          obj->free();
9ae3ca
+      }
9ae3ca
     } else {
9ae3ca
       obj->initInt(num);
9ae3ca
     }