summaryrefslogtreecommitdiff
diff options
context:
space:
mode:
authorStefan Schweizer <genstef@gentoo.org>2006-02-19 19:07:08 +0000
committerStefan Schweizer <genstef@gentoo.org>2006-02-19 19:07:08 +0000
commitc35172d353ec74229d5f065cc0555107b2441d06 (patch)
treee3e13bdced606a32b5feb9c015528f213f45a5e6 /app-text/xpdf/files
parentInitial commit, ebuild written by me. (diff)
downloadgentoo-2-c35172d353ec74229d5f065cc0555107b2441d06.tar.gz
gentoo-2-c35172d353ec74229d5f065cc0555107b2441d06.tar.bz2
gentoo-2-c35172d353ec74229d5f065cc0555107b2441d06.zip
remove older ebuilds
(Portage version: 2.1_pre4-r1)
Diffstat (limited to 'app-text/xpdf/files')
-rw-r--r--app-text/xpdf/files/digest-xpdf-3.00-r1012
-rw-r--r--app-text/xpdf/files/digest-xpdf-3.01-r512
-rw-r--r--app-text/xpdf/files/xpdf-3.00-64bit.patch55
-rw-r--r--app-text/xpdf/files/xpdf-3.00-PathScanner.patch125
-rw-r--r--app-text/xpdf/files/xpdf-3.00-core.patch13
-rw-r--r--app-text/xpdf/files/xpdf-3.00-empty-bookmark.patch11
-rw-r--r--app-text/xpdf/files/xpdf-3.00-fonts.patch11
-rw-r--r--app-text/xpdf/files/xpdf-3.00-freetype-2.1.7.patch74
-rw-r--r--app-text/xpdf/files/xpdf-3.00-gcc41.patch25
-rw-r--r--app-text/xpdf/files/xpdf-3.00-nodrm.diff39
-rw-r--r--app-text/xpdf/files/xpdf-3.00-overflow.patch296
-rw-r--r--app-text/xpdf/files/xpdf-3.00-pl2.patch54
-rw-r--r--app-text/xpdf/files/xpdf-3.00-pl3.patch14
-rw-r--r--app-text/xpdf/files/xpdf-3.00-scroll-opts.patch185
-rw-r--r--app-text/xpdf/files/xpdf-3.00-security-can-2005-2097.patch57
-rw-r--r--app-text/xpdf/files/xpdf-3.00-truetype-new.diff98
-rw-r--r--app-text/xpdf/files/xpdf-3.01-crash.patch34
-rw-r--r--app-text/xpdf/files/xpdf-3.01-nodrm.patch104
-rw-r--r--app-text/xpdf/files/xpdf-3.01-onlyx.patch82
-rw-r--r--app-text/xpdf/files/xpdf-3.01-pdftoppm.patch33
-rw-r--r--app-text/xpdf/files/xpdf-3.01-resize.patch36
-rw-r--r--app-text/xpdf/files/xpdf-3.01-sec-rollup.patch266
-rw-r--r--app-text/xpdf/files/xpdf-3.01pl1.patch168
-rw-r--r--app-text/xpdf/files/xpdf-goo-sizet.patch57
-rw-r--r--app-text/xpdf/files/xpdfrc.120
25 files changed, 0 insertions, 1881 deletions
diff --git a/app-text/xpdf/files/digest-xpdf-3.00-r10 b/app-text/xpdf/files/digest-xpdf-3.00-r10
deleted file mode 100644
index 5d4918e4839b..000000000000
--- a/app-text/xpdf/files/digest-xpdf-3.00-r10
+++ /dev/null
@@ -1,12 +0,0 @@
-MD5 95294cef3031dd68e65f331e8750b2c2 xpdf-3.00.tar.gz 534697
-MD5 67f05f65bc64bf022b36138c7c26746d xpdf-arabic.tar.gz 1058
-MD5 713659f0282b9e3d169390e246e5eb74 xpdf-chinese-simplified.tar.gz 756127
-MD5 5be730b859f8b01de569eb1bad188426 xpdf-chinese-traditional.tar.gz 698902
-MD5 21f57122247e2e2a63bfed4dc4f6c199 xpdf-cyrillic.tar.gz 1286
-MD5 2240a364b9c28ce09fd8c3107784ce40 xpdf-greek.tar.gz 1124
-MD5 438dd417517641cbb78a94facf2d938e xpdf-hebrew.tar.gz 1314
-MD5 57bb9359437583479b6670e75fa06c31 xpdf-japanese.tar.gz 430478
-MD5 10cd92e4eef065a6a26341d9a2a1b5c2 xpdf-korean.tar.gz 419081
-MD5 ac19ef990cd63afd2837c10dc7e1c3ab xpdf-latin2.tar.gz 1435
-MD5 9af495766ee4eaf3411d1fa74560f0ec xpdf-thai.tar.gz 1876
-MD5 f9233880805e3d8d2cf15a4fe679f25b xpdf-turkish.tar.gz 1140
diff --git a/app-text/xpdf/files/digest-xpdf-3.01-r5 b/app-text/xpdf/files/digest-xpdf-3.01-r5
deleted file mode 100644
index a9aeca0c2984..000000000000
--- a/app-text/xpdf/files/digest-xpdf-3.01-r5
+++ /dev/null
@@ -1,12 +0,0 @@
-MD5 e004c69c7dddef165d768b1362b44268 xpdf-3.01.tar.gz 599778
-MD5 67f05f65bc64bf022b36138c7c26746d xpdf-arabic.tar.gz 1058
-MD5 713659f0282b9e3d169390e246e5eb74 xpdf-chinese-simplified.tar.gz 756127
-MD5 5be730b859f8b01de569eb1bad188426 xpdf-chinese-traditional.tar.gz 698902
-MD5 21f57122247e2e2a63bfed4dc4f6c199 xpdf-cyrillic.tar.gz 1286
-MD5 2240a364b9c28ce09fd8c3107784ce40 xpdf-greek.tar.gz 1124
-MD5 438dd417517641cbb78a94facf2d938e xpdf-hebrew.tar.gz 1314
-MD5 57bb9359437583479b6670e75fa06c31 xpdf-japanese.tar.gz 430478
-MD5 10cd92e4eef065a6a26341d9a2a1b5c2 xpdf-korean.tar.gz 419081
-MD5 ac19ef990cd63afd2837c10dc7e1c3ab xpdf-latin2.tar.gz 1435
-MD5 9af495766ee4eaf3411d1fa74560f0ec xpdf-thai.tar.gz 1876
-MD5 f9233880805e3d8d2cf15a4fe679f25b xpdf-turkish.tar.gz 1140
diff --git a/app-text/xpdf/files/xpdf-3.00-64bit.patch b/app-text/xpdf/files/xpdf-3.00-64bit.patch
deleted file mode 100644
index ec13b7bb261f..000000000000
--- a/app-text/xpdf/files/xpdf-3.00-64bit.patch
+++ /dev/null
@@ -1,55 +0,0 @@
---- xpdf-3.00/goo/gmem.h.me 2005-07-25 10:47:46.000000000 +0200
-+++ xpdf-3.00/goo/gmem.h 2005-07-25 10:49:55.000000000 +0200
-@@ -19,13 +19,13 @@
- * Same as malloc, but prints error message and exits if malloc()
- * returns NULL.
- */
--extern void *gmalloc(int size);
-+extern void *gmalloc(size_t size);
-
- /*
- * Same as realloc, but prints error message and exits if realloc()
- * returns NULL. If <p> is NULL, calls malloc instead of realloc().
- */
--extern void *grealloc(void *p, int size);
-+extern void *grealloc(void *p, size_t size);
-
- /*
- * Same as free, but checks for and ignores NULL pointers.
---- xpdf-3.00/goo/gmem.c.me 2005-07-25 10:47:51.000000000 +0200
-+++ xpdf-3.00/goo/gmem.c 2005-07-25 10:49:30.000000000 +0200
-@@ -53,9 +53,9 @@
-
- #endif /* DEBUG_MEM */
-
--void *gmalloc(int size) {
-+void *gmalloc(size_t size) {
- #ifdef DEBUG_MEM
-- int size1;
-+ size_t size1;
- char *mem;
- GMemHdr *hdr;
- void *data;
-@@ -94,11 +94,11 @@
- #endif
- }
-
--void *grealloc(void *p, int size) {
-+void *grealloc(void *p, size_t size) {
- #ifdef DEBUG_MEM
- GMemHdr *hdr;
- void *q;
-- int oldSize;
-+ size_t oldSize;
-
- if (size == 0) {
- if (p)
-@@ -137,7 +137,7 @@
-
- void gfree(void *p) {
- #ifdef DEBUG_MEM
-- int size;
-+ size_t size;
- GMemHdr *hdr;
- GMemHdr *prevHdr, *q;
- int lst;
diff --git a/app-text/xpdf/files/xpdf-3.00-PathScanner.patch b/app-text/xpdf/files/xpdf-3.00-PathScanner.patch
deleted file mode 100644
index dac7bfa34ad2..000000000000
--- a/app-text/xpdf/files/xpdf-3.00-PathScanner.patch
+++ /dev/null
@@ -1,125 +0,0 @@
---- xpdf-3.00/splash/Splash.cc.orig 2004-10-19 11:50:09.000000000 +0200
-+++ xpdf-3.00/splash/Splash.cc 2004-10-19 11:50:46.000000000 +0200
-@@ -631,6 +631,9 @@
- if (path->length == 0) {
- return splashErrEmptyPath;
- }
-+ if (path->length == 1)
-+ return splashErrBogusPath;
-+
- xPath = new SplashXPath(path, state->flatness, gTrue);
- xPath->sort();
- scanner = new SplashXPathScanner(xPath, eo);
---- xpdf-3.00/splash/SplashXPathScanner.cc.orig 2004-10-21 16:36:41.170525604 +0200
-+++ xpdf-3.00/splash/SplashXPathScanner.cc 2004-10-21 17:34:05.320376896 +0200
-@@ -39,54 +39,60 @@
- xPath = xPathA;
- eo = eoA;
-
-+ xMin = 0;
-+ xMax = 0;
-+ yMin = 0;
-+ yMax = 0;
-+ interY = 0;
-+ xPathIdx = 0;
-+ inter = NULL;
-+ interLen = interSize = 0;
-+
- // compute the bbox
- seg = &xPath->segs[0];
-- if (seg->x0 <= seg->x1) {
-- xMinFP = seg->x0;
-- xMaxFP = seg->x1;
-- } else {
-- xMinFP = seg->x1;
-- xMaxFP = seg->x0;
-- }
-- if (seg->flags & splashXPathFlip) {
-- yMinFP = seg->y1;
-- yMaxFP = seg->y0;
-- } else {
-- yMinFP = seg->y0;
-- yMaxFP = seg->y1;
-- }
-- for (i = 1; i < xPath->length; ++i) {
-- seg = &xPath->segs[i];
-- if (seg->x0 < xMinFP) {
-+ if (seg) {
-+ if (seg->x0 <= seg->x1) {
- xMinFP = seg->x0;
-- } else if (seg->x0 > xMaxFP) {
-- xMaxFP = seg->x0;
-- }
-- if (seg->x1 < xMinFP) {
-- xMinFP = seg->x1;
-- } else if (seg->x1 > xMaxFP) {
- xMaxFP = seg->x1;
-+ } else {
-+ xMinFP = seg->x1;
-+ xMaxFP = seg->x0;
- }
- if (seg->flags & splashXPathFlip) {
-- if (seg->y0 > yMaxFP) {
-- yMaxFP = seg->y0;
-- }
-+ yMinFP = seg->y1;
-+ yMaxFP = seg->y0;
- } else {
-- if (seg->y1 > yMaxFP) {
-- yMaxFP = seg->y1;
-+ yMinFP = seg->y0;
-+ yMaxFP = seg->y1;
-+ }
-+ for (i = 1; i < xPath->length; ++i) {
-+ seg = &xPath->segs[i];
-+ if (seg->x0 < xMinFP) {
-+ xMinFP = seg->x0;
-+ } else if (seg->x0 > xMaxFP) {
-+ xMaxFP = seg->x0;
-+ }
-+ if (seg->x1 < xMinFP) {
-+ xMinFP = seg->x1;
-+ } else if (seg->x1 > xMaxFP) {
-+ xMaxFP = seg->x1;
-+ }
-+ if (seg->flags & splashXPathFlip) {
-+ if (seg->y0 > yMaxFP) {
-+ yMaxFP = seg->y0;
-+ }
-+ } else {
-+ if (seg->y1 > yMaxFP) {
-+ yMaxFP = seg->y1;
-+ }
- }
- }
-+ xMin = splashFloor(xMinFP);
-+ xMax = splashFloor(xMaxFP);
-+ yMin = splashFloor(yMinFP);
-+ yMax = splashFloor(yMaxFP);
-+ computeIntersections(yMin);
- }
-- xMin = splashFloor(xMinFP);
-- xMax = splashFloor(xMaxFP);
-- yMin = splashFloor(yMinFP);
-- yMax = splashFloor(yMaxFP);
--
-- interY = 0;
-- xPathIdx = 0;
-- inter = NULL;
-- interLen = interSize = 0;
-- computeIntersections(yMin);
- }
-
- SplashXPathScanner::~SplashXPathScanner() {
---- xpdf-3.00/splash/SplashFTFont.cc.orig 2004-10-19 11:50:55.000000000 +0200
-+++ xpdf-3.00/splash/SplashFTFont.cc 2004-10-19 11:51:12.000000000 +0200
-@@ -225,6 +225,9 @@
- if (FT_Get_Glyph(slot, &glyph)) {
- return NULL;
- }
-+ if (glyph->format != FT_GLYPH_FORMAT_OUTLINE) {
-+ return NULL;
-+ }
- path = new SplashPath();
- FT_Outline_Decompose(&((FT_OutlineGlyph)glyph)->outline,
- &outlineFuncs, path);
diff --git a/app-text/xpdf/files/xpdf-3.00-core.patch b/app-text/xpdf/files/xpdf-3.00-core.patch
deleted file mode 100644
index 21e614821a71..000000000000
--- a/app-text/xpdf/files/xpdf-3.00-core.patch
+++ /dev/null
@@ -1,13 +0,0 @@
---- xpdf-3.00/xpdf/XPDFCore.cc.ud 2004-10-07 12:44:23.000000000 -0700
-+++ xpdf-3.00/xpdf/XPDFCore.cc 2004-10-07 12:44:26.000000000 -0700
-@@ -1051,6 +1051,10 @@
- GString *msg;
- int i;
-
-+ if (action == NULL)
-+ // Nothing to do.
-+ return;
-+
- switch (kind = action->getKind()) {
-
- // GoTo / GoToR action
diff --git a/app-text/xpdf/files/xpdf-3.00-empty-bookmark.patch b/app-text/xpdf/files/xpdf-3.00-empty-bookmark.patch
deleted file mode 100644
index 3f05bced654a..000000000000
--- a/app-text/xpdf/files/xpdf-3.00-empty-bookmark.patch
+++ /dev/null
@@ -1,11 +0,0 @@
---- xpdf/XPDFViewer.cc 2004-05-18 12:47:11.512305008 +0200
-+++ xpdf/XPDFViewer.cc.new 2004-05-18 12:38:14.558934328 +0200
-@@ -1681,7 +1681,7 @@
- OutlineItem *item;
-
- XtVaGetValues(data->selectedItem, XmNuserData, &item, NULL);
-- if (item) {
-+ if (item && (item->getAction() != 0)) {
- viewer->core->doAction(item->getAction());
- }
- viewer->core->takeFocus();
diff --git a/app-text/xpdf/files/xpdf-3.00-fonts.patch b/app-text/xpdf/files/xpdf-3.00-fonts.patch
deleted file mode 100644
index 1292918f6144..000000000000
--- a/app-text/xpdf/files/xpdf-3.00-fonts.patch
+++ /dev/null
@@ -1,11 +0,0 @@
-diff -ur xpdf.org/xpdf/GlobalParams.cc xpdf-3.00/xpdf/GlobalParams.cc
---- xpdf.org/xpdf/GlobalParams.cc 2004-01-21 17:26:45.000000000 -0800
-+++ xpdf-3.00/xpdf/GlobalParams.cc 2005-03-18 19:52:03.000000000 -0800
-@@ -84,6 +84,7 @@
- "/usr/share/ghostscript/fonts",
- "/usr/local/share/ghostscript/fonts",
- "/usr/share/fonts/default/Type1",
-+ "/usr/share/fonts/default/ghostscript",
- NULL
- };
-
diff --git a/app-text/xpdf/files/xpdf-3.00-freetype-2.1.7.patch b/app-text/xpdf/files/xpdf-3.00-freetype-2.1.7.patch
deleted file mode 100644
index b6f789516ebc..000000000000
--- a/app-text/xpdf/files/xpdf-3.00-freetype-2.1.7.patch
+++ /dev/null
@@ -1,74 +0,0 @@
-diff -Naur xpdf-3.00/configure.in xpdf-3.00.new/configure.in
---- xpdf-3.00/configure.in 2004-01-22 02:26:44.000000000 +0100
-+++ xpdf-3.00.new/configure.in 2004-09-29 19:27:16.089925504 +0200
-@@ -306,10 +306,13 @@
- dnl ##### (Note: FT_Get_Name_Index was added in FT 2.0.5, and is
- dnl ##### the reason that Xpdf requires 2.0.5+.)
- smr_CHECK_LIB(freetype2, freetype, [FreeType2 font rasterizer - version 2.0.5+],
-- FT_Get_Name_Index, freetype/freetype.h, -lm)
-+ FT_Get_Name_Index, freetype/ft2build.h, -lm)
- if test x"$freetype2_LIBS" = x; then
- smr_CHECK_LIB(freetype2, freetype, [FreeType2 font rasterizer - version 2.0.5+],
-- FT_Get_Name_Index, freetype.h, -lm)
-+ FT_Get_Name_Index, ft2build.h, -lm)
-+ if test "x$smr_have_freetype2_library" = xyes; then
-+ AC_DEFINE(HAVE_FREETYPE_H)
-+ fi
- fi
- AC_SUBST(freetype2_LIBS)
- AC_SUBST(freetype2_CFLAGS)
-diff -Naur xpdf-3.00/splash/SplashFTFont.cc xpdf-3.00.new/splash/SplashFTFont.cc
---- xpdf-3.00/splash/SplashFTFont.cc 2004-01-22 02:26:44.000000000 +0100
-+++ xpdf-3.00.new/splash/SplashFTFont.cc 2004-09-29 19:27:46.527298320 +0200
-@@ -12,8 +12,10 @@
- #pragma implementation
- #endif
-
--#include "freetype/ftoutln.h"
--#include "freetype/internal/ftobjs.h" // needed for FT_New_Size decl
-+#include <ft2build.h>
-+#include FT_OUTLINE_H
-+#include FT_GLYPH_H
-+#include FT_SIZES_H // needed for FT_New_Size decl
- #include "gmem.h"
- #include "SplashMath.h"
- #include "SplashGlyphBitmap.h"
-diff -Naur xpdf-3.00/splash/SplashFTFont.h xpdf-3.00.new/splash/SplashFTFont.h
---- xpdf-3.00/splash/SplashFTFont.h 2004-01-22 02:26:44.000000000 +0100
-+++ xpdf-3.00.new/splash/SplashFTFont.h 2004-09-29 19:27:16.091925200 +0200
-@@ -15,7 +15,8 @@
- #pragma interface
- #endif
-
--#include <freetype/freetype.h>
-+#include <ft2build.h>
-+#include FT_FREETYPE_H
- #include "SplashFont.h"
-
- class SplashFTFontFile;
-diff -Naur xpdf-3.00/splash/SplashFTFontEngine.h xpdf-3.00.new/splash/SplashFTFontEngine.h
---- xpdf-3.00/splash/SplashFTFontEngine.h 2004-01-22 02:26:44.000000000 +0100
-+++ xpdf-3.00.new/splash/SplashFTFontEngine.h 2004-09-29 19:27:16.091925200 +0200
-@@ -15,7 +15,8 @@
- #pragma interface
- #endif
-
--#include <freetype/freetype.h>
-+#include <ft2build.h>
-+#include FT_FREETYPE_H
- #include "gtypes.h"
-
- class SplashFontFile;
-diff -Naur xpdf-3.00/splash/SplashFTFontFile.h xpdf-3.00.new/splash/SplashFTFontFile.h
---- xpdf-3.00/splash/SplashFTFontFile.h 2004-01-22 02:26:44.000000000 +0100
-+++ xpdf-3.00.new/splash/SplashFTFontFile.h 2004-09-29 19:27:16.091925200 +0200
-@@ -15,7 +15,8 @@
- #pragma interface
- #endif
-
--#include <freetype/freetype.h>
-+#include <ft2build.h>
-+#include FT_FREETYPE_H
- #include "SplashFontFile.h"
-
- class SplashFontFileID;
diff --git a/app-text/xpdf/files/xpdf-3.00-gcc41.patch b/app-text/xpdf/files/xpdf-3.00-gcc41.patch
deleted file mode 100644
index 6856d492b06f..000000000000
--- a/app-text/xpdf/files/xpdf-3.00-gcc41.patch
+++ /dev/null
@@ -1,25 +0,0 @@
-diff -Naur xpdf-3.00.old/splash/SplashT1Font.h xpdf-3.00/splash/SplashT1Font.h
---- xpdf-3.00.old/splash/SplashT1Font.h 2004-01-22 09:26:44.000000000 +0800
-+++ xpdf-3.00/splash/SplashT1Font.h 2005-06-08 10:09:56.000000000 +0800
-@@ -16,6 +16,7 @@
- #endif
-
- #include "SplashFont.h"
-+#include "SplashT1FontFile.h"
-
- //------------------------------------------------------------------------
- // SplashT1Font
-diff -Naur xpdf-3.00.old/xpdf/TextOutputDev.h xpdf-3.00/xpdf/TextOutputDev.h
---- xpdf-3.00.old/xpdf/TextOutputDev.h 2004-01-22 09:26:45.000000000 +0800
-+++ xpdf-3.00/xpdf/TextOutputDev.h 2005-06-08 10:15:45.000000000 +0800
-@@ -26,6 +26,10 @@
- class GfxState;
- class UnicodeMap;
-
-+class TextBlock;
-+class TextPage;
-+class TextLineFrag;
-+
- //------------------------------------------------------------------------
-
- typedef void (*TextOutputFunc)(void *stream, char *text, int len);
diff --git a/app-text/xpdf/files/xpdf-3.00-nodrm.diff b/app-text/xpdf/files/xpdf-3.00-nodrm.diff
deleted file mode 100644
index 8abf09f45aba..000000000000
--- a/app-text/xpdf/files/xpdf-3.00-nodrm.diff
+++ /dev/null
@@ -1,39 +0,0 @@
-diff -uNr xpdf-3.00-old/xpdf/XRef.cc xpdf-3.00/xpdf/XRef.cc
---- xpdf-3.00-old/xpdf/XRef.cc 2004-01-22 02:26:45.000000000 +0100
-+++ xpdf-3.00/xpdf/XRef.cc 2004-09-01 16:11:32.410396128 +0200
-@@ -822,7 +822,7 @@
-
- GBool XRef::okToPrint(GBool ignoreOwnerPW) {
- #ifndef NO_DECRYPTION
-- return (!ignoreOwnerPW && ownerPasswordOk) || (permFlags & permPrint);
-+ return gTrue;
- #else
- return gTrue;
- #endif
-@@ -830,7 +830,7 @@
-
- GBool XRef::okToChange(GBool ignoreOwnerPW) {
- #ifndef NO_DECRYPTION
-- return (!ignoreOwnerPW && ownerPasswordOk) || (permFlags & permChange);
-+ return gTrue;
- #else
- return gTrue;
- #endif
-@@ -838,7 +838,7 @@
-
- GBool XRef::okToCopy(GBool ignoreOwnerPW) {
- #ifndef NO_DECRYPTION
-- return (!ignoreOwnerPW && ownerPasswordOk) || (permFlags & permCopy);
-+ return gTrue;
- #else
- return gTrue;
- #endif
-@@ -846,7 +846,7 @@
-
- GBool XRef::okToAddNotes(GBool ignoreOwnerPW) {
- #ifndef NO_DECRYPTION
-- return (!ignoreOwnerPW && ownerPasswordOk) || (permFlags & permNotes);
-+ return gTrue;
- #else
- return gTrue;
- #endif
diff --git a/app-text/xpdf/files/xpdf-3.00-overflow.patch b/app-text/xpdf/files/xpdf-3.00-overflow.patch
deleted file mode 100644
index d1b2f584d812..000000000000
--- a/app-text/xpdf/files/xpdf-3.00-overflow.patch
+++ /dev/null
@@ -1,296 +0,0 @@
---- xpdf-3.00/xpdf/Catalog.cc.orig 2004-10-18 16:51:35.824126848 +0200
-+++ xpdf-3.00/xpdf/Catalog.cc 2004-10-18 16:53:06.634620045 +0200
-@@ -64,6 +64,15 @@
- }
- pagesSize = numPages0 = (int)obj.getNum();
- obj.free();
-+ // The gcc doesnt optimize this away, so this check is ok,
-+ // even if it looks like a pagesSize != pagesSize check
-+ if (pagesSize*sizeof(Page *)/sizeof(Page *) != pagesSize ||
-+ pagesSize*sizeof(Ref)/sizeof(Ref) != pagesSize) {
-+ error(-1, "Invalid 'pagesSize'");
-+ ok = gFalse;
-+ return;
-+ }
-+
- pages = (Page **)gmalloc(pagesSize * sizeof(Page *));
- pageRefs = (Ref *)gmalloc(pagesSize * sizeof(Ref));
- for (i = 0; i < pagesSize; ++i) {
-@@ -191,6 +200,11 @@
- }
- if (start >= pagesSize) {
- pagesSize += 32;
-+ if (pagesSize*sizeof(Page *)/sizeof(Page *) != pagesSize ||
-+ pagesSize*sizeof(Ref)/sizeof(Ref) != pagesSize) {
-+ error(-1, "Invalid 'pagesSize' parameter.");
-+ goto err3;
-+ }
- pages = (Page **)grealloc(pages, pagesSize * sizeof(Page *));
- pageRefs = (Ref *)grealloc(pageRefs, pagesSize * sizeof(Ref));
- for (j = pagesSize - 32; j < pagesSize; ++j) {
---- xpdf-3.00/xpdf/XRef.cc.orig 2004-10-11 15:51:14.000000000 +0200
-+++ xpdf-3.00/xpdf/XRef.cc 2004-10-11 15:56:48.000000000 +0200
-@@ -96,7 +96,7 @@
- }
- nObjects = obj1.getInt();
- obj1.free();
-- if (nObjects == 0) {
-+ if (nObjects <= 0) {
- goto err1;
- }
-
-@@ -106,7 +106,15 @@
- }
- first = obj1.getInt();
- obj1.free();
-+ if (first < 0) {
-+ goto err1;
-+ }
-
-+ if (nObjects*sizeof(int)/sizeof(int) != nObjects) {
-+ error(-1, "Invalid 'nObjects'");
-+ goto err1;
-+ }
-+
- objs = new Object[nObjects];
- objNums = (int *)gmalloc(nObjects * sizeof(int));
- offsets = (int *)gmalloc(nObjects * sizeof(int));
-@@ -130,6 +138,12 @@
- offsets[i] = obj2.getInt();
- obj1.free();
- obj2.free();
-+ if (objNums[i] < 0 || offsets[i] < 0 ||
-+ (i > 0 && offsets[i] < offsets[i-1])) {
-+ delete parser;
-+ gfree(offsets);
-+ goto err1;
-+ }
- }
- while (str->getChar() != EOF) ;
- delete parser;
-@@ -369,10 +383,21 @@
- }
- n = obj.getInt();
- obj.free();
-+ if (first < 0 || n < 0 || first + n < 0) {
-+ goto err1;
-+ }
- if (first + n > size) {
- for (newSize = size ? 2 * size : 1024;
-- first + n > newSize;
-+ first + n > newSize && newSize > 0;
- newSize <<= 1) ;
-+ if (newSize < 0) {
-+ goto err1;
-+ }
-+ if (newSize*sizeof(XRefEntry)/sizeof(XRefEntry) != newSize) {
-+ error(-1, "Invalid 'obj' parameters'");
-+ goto err1;
-+ }
-+
- entries = (XRefEntry *)grealloc(entries, newSize * sizeof(XRefEntry));
- for (i = size; i < newSize; ++i) {
- entries[i].offset = 0xffffffff;
-@@ -443,7 +468,7 @@
-
- // check for an 'XRefStm' key
- if (obj.getDict()->lookup("XRefStm", &obj2)->isInt()) {
-- pos2 = obj2.getInt();
-+ pos2 = (Guint)obj2.getInt();
- readXRef(&pos2);
- if (!ok) {
- goto err1;
-@@ -474,7 +499,14 @@
- }
- newSize = obj.getInt();
- obj.free();
-+ if (newSize < 0) {
-+ goto err1;
-+ }
- if (newSize > size) {
-+ if (newSize * sizeof(XRefEntry)/sizeof(XRefEntry) != newSize) {
-+ error(-1, "Invalid 'size' parameter.");
-+ return gFalse;
-+ }
- entries = (XRefEntry *)grealloc(entries, newSize * sizeof(XRefEntry));
- for (i = size; i < newSize; ++i) {
- entries[i].offset = 0xffffffff;
-@@ -494,6 +526,9 @@
- }
- w[i] = obj2.getInt();
- obj2.free();
-+ if (w[i] < 0 || w[i] > 4) {
-+ goto err1;
-+ }
- }
- obj.free();
-
-@@ -513,13 +548,14 @@
- }
- n = obj.getInt();
- obj.free();
-- if (!readXRefStreamSection(xrefStr, w, first, n)) {
-+ if (first < 0 || n < 0 ||
-+ !readXRefStreamSection(xrefStr, w, first, n)) {
- idx.free();
- goto err0;
- }
- }
- } else {
-- if (!readXRefStreamSection(xrefStr, w, 0, size)) {
-+ if (!readXRefStreamSection(xrefStr, w, 0, newSize)) {
- idx.free();
- goto err0;
- }
-@@ -551,10 +587,20 @@
- Guint offset;
- int type, gen, c, newSize, i, j;
-
-+ if (first + n < 0) {
-+ return gFalse;
-+ }
- if (first + n > size) {
- for (newSize = size ? 2 * size : 1024;
-- first + n > newSize;
-+ first + n > newSize && newSize > 0;
- newSize <<= 1) ;
-+ if (newSize < 0) {
-+ return gFalse;
-+ }
-+ if (newSize*sizeof(XRefEntry)/sizeof(XRefEntry) != newSize) {
-+ error(-1, "Invalid 'size' inside xref table.");
-+ return gFalse;
-+ }
- entries = (XRefEntry *)grealloc(entries, newSize * sizeof(XRefEntry));
- for (i = size; i < newSize; ++i) {
- entries[i].offset = 0xffffffff;
-@@ -585,24 +631,26 @@
- }
- gen = (gen << 8) + c;
- }
-- switch (type) {
-- case 0:
-- entries[i].offset = offset;
-- entries[i].gen = gen;
-- entries[i].type = xrefEntryFree;
-- break;
-- case 1:
-- entries[i].offset = offset;
-- entries[i].gen = gen;
-- entries[i].type = xrefEntryUncompressed;
-- break;
-- case 2:
-- entries[i].offset = offset;
-- entries[i].gen = gen;
-- entries[i].type = xrefEntryCompressed;
-- break;
-- default:
-- return gFalse;
-+ if (entries[i].offset == 0xffffffff) {
-+ switch (type) {
-+ case 0:
-+ entries[i].offset = offset;
-+ entries[i].gen = gen;
-+ entries[i].type = xrefEntryFree;
-+ break;
-+ case 1:
-+ entries[i].offset = offset;
-+ entries[i].gen = gen;
-+ entries[i].type = xrefEntryUncompressed;
-+ break;
-+ case 2:
-+ entries[i].offset = offset;
-+ entries[i].gen = gen;
-+ entries[i].type = xrefEntryCompressed;
-+ break;
-+ default:
-+ return gFalse;
-+ }
- }
- }
-
-@@ -664,38 +712,48 @@
- // look for object
- } else if (isdigit(*p)) {
- num = atoi(p);
-- do {
-- ++p;
-- } while (*p && isdigit(*p));
-- if (isspace(*p)) {
-+ if (num > 0) {
- do {
- ++p;
-- } while (*p && isspace(*p));
-- if (isdigit(*p)) {
-- gen = atoi(p);
-+ } while (*p && isdigit(*p));
-+ if (isspace(*p)) {
- do {
- ++p;
-- } while (*p && isdigit(*p));
-- if (isspace(*p)) {
-+ } while (*p && isspace(*p));
-+ if (isdigit(*p)) {
-+ gen = atoi(p);
- do {
- ++p;
-- } while (*p && isspace(*p));
-- if (!strncmp(p, "obj", 3)) {
-- if (num >= size) {
-- newSize = (num + 1 + 255) & ~255;
-- entries = (XRefEntry *)
-- grealloc(entries, newSize * sizeof(XRefEntry));
-- for (i = size; i < newSize; ++i) {
-- entries[i].offset = 0xffffffff;
-- entries[i].type = xrefEntryFree;
-+ } while (*p && isdigit(*p));
-+ if (isspace(*p)) {
-+ do {
-+ ++p;
-+ } while (*p && isspace(*p));
-+ if (!strncmp(p, "obj", 3)) {
-+ if (num >= size) {
-+ newSize = (num + 1 + 255) & ~255;
-+ if (newSize < 0) {
-+ error(-1, "Bad object number");
-+ return gFalse;
-+ }
-+ if (newSize*sizeof(XRefEntry)/sizeof(XRefEntry) != newSize) {
-+ error(-1, "Invalid 'obj' parameters.");
-+ return gFalse;
-+ }
-+ entries = (XRefEntry *)
-+ grealloc(entries, newSize * sizeof(XRefEntry));
-+ for (i = size; i < newSize; ++i) {
-+ entries[i].offset = 0xffffffff;
-+ entries[i].type = xrefEntryFree;
-+ }
-+ size = newSize;
-+ }
-+ if (entries[num].type == xrefEntryFree ||
-+ gen >= entries[num].gen) {
-+ entries[num].offset = pos - start;
-+ entries[num].gen = gen;
-+ entries[num].type = xrefEntryUncompressed;
- }
-- size = newSize;
-- }
-- if (entries[num].type == xrefEntryFree ||
-- gen >= entries[num].gen) {
-- entries[num].offset = pos - start;
-- entries[num].gen = gen;
-- entries[num].type = xrefEntryUncompressed;
- }
- }
- }
-@@ -705,6 +763,10 @@
- } else if (!strncmp(p, "endstream", 9)) {
- if (streamEndsLen == streamEndsSize) {
- streamEndsSize += 64;
-+ if (streamEndsSize*sizeof(int)/sizeof(int) != streamEndsSize) {
-+ error(-1, "Invalid 'endstream' parameter.");
-+ return gFalse;
-+ }
- streamEnds = (Guint *)grealloc(streamEnds,
- streamEndsSize * sizeof(int));
- }
diff --git a/app-text/xpdf/files/xpdf-3.00-pl2.patch b/app-text/xpdf/files/xpdf-3.00-pl2.patch
deleted file mode 100644
index 0b5066a61ee7..000000000000
--- a/app-text/xpdf/files/xpdf-3.00-pl2.patch
+++ /dev/null
@@ -1,54 +0,0 @@
-*** xpdf/Gfx.cc.orig Sun Dec 12 16:04:43 2004
---- xpdf/Gfx.cc Sun Dec 12 16:05:16 2004
-***************
-*** 2654,2660 ****
- haveMask = gFalse;
- dict->lookup("Mask", &maskObj);
- if (maskObj.isArray()) {
-! for (i = 0; i < maskObj.arrayGetLength(); ++i) {
- maskObj.arrayGet(i, &obj1);
- maskColors[i] = obj1.getInt();
- obj1.free();
---- 2654,2662 ----
- haveMask = gFalse;
- dict->lookup("Mask", &maskObj);
- if (maskObj.isArray()) {
-! for (i = 0;
-! i < maskObj.arrayGetLength() && i < 2*gfxColorMaxComps;
-! ++i) {
- maskObj.arrayGet(i, &obj1);
- maskColors[i] = obj1.getInt();
- obj1.free();
-*** xpdf/GfxState.cc.orig Sun Dec 12 16:04:48 2004
---- xpdf/GfxState.cc Sun Dec 12 16:06:38 2004
-***************
-*** 708,713 ****
---- 708,718 ----
- }
- nCompsA = obj2.getInt();
- obj2.free();
-+ if (nCompsA > gfxColorMaxComps) {
-+ error(-1, "ICCBased color space with too many (%d > %d) components",
-+ nCompsA, gfxColorMaxComps);
-+ nCompsA = gfxColorMaxComps;
-+ }
- if (dict->lookup("Alternate", &obj2)->isNull() ||
- !(altA = GfxColorSpace::parse(&obj2))) {
- switch (nCompsA) {
-***************
-*** 1054,1060 ****
- }
- nCompsA = obj1.arrayGetLength();
- if (nCompsA > gfxColorMaxComps) {
-! error(-1, "DeviceN color space with more than %d > %d components",
- nCompsA, gfxColorMaxComps);
- nCompsA = gfxColorMaxComps;
- }
---- 1059,1065 ----
- }
- nCompsA = obj1.arrayGetLength();
- if (nCompsA > gfxColorMaxComps) {
-! error(-1, "DeviceN color space with too many (%d > %d) components",
- nCompsA, gfxColorMaxComps);
- nCompsA = gfxColorMaxComps;
- }
diff --git a/app-text/xpdf/files/xpdf-3.00-pl3.patch b/app-text/xpdf/files/xpdf-3.00-pl3.patch
deleted file mode 100644
index 9000f0b529bf..000000000000
--- a/app-text/xpdf/files/xpdf-3.00-pl3.patch
+++ /dev/null
@@ -1,14 +0,0 @@
-*** xpdf/XRef.cc.orig Wed Jan 12 17:10:53 2005
---- xpdf/XRef.cc Wed Jan 12 17:11:22 2005
-***************
-*** 793,798 ****
---- 793,801 ----
- } else {
- keyLength = 5;
- }
-+ if (keyLength > 16) {
-+ keyLength = 16;
-+ }
- permFlags = permissions.getInt();
- if (encVersion >= 1 && encVersion <= 2 &&
- encRevision >= 2 && encRevision <= 3) {
diff --git a/app-text/xpdf/files/xpdf-3.00-scroll-opts.patch b/app-text/xpdf/files/xpdf-3.00-scroll-opts.patch
deleted file mode 100644
index 9a661ea621c1..000000000000
--- a/app-text/xpdf/files/xpdf-3.00-scroll-opts.patch
+++ /dev/null
@@ -1,185 +0,0 @@
-diff -ur xpdf-3.00.org/xpdf/GlobalParams.cc xpdf-3.00/xpdf/GlobalParams.cc
---- xpdf-3.00.org/xpdf/GlobalParams.cc 2004-01-21 20:26:45.000000000 -0500
-+++ xpdf-3.00/xpdf/GlobalParams.cc 2004-12-01 06:33:25.998677321 -0500
-@@ -234,6 +234,8 @@
- enableT1lib = gTrue;
- enableFreeType = gTrue;
- antialias = gTrue;
-+ scrollLines = 1;
-+ scrollCols = 1;
- urlCommand = NULL;
- movieCommand = NULL;
- mapNumericCharNames = gTrue;
-@@ -445,6 +447,10 @@
- parseYesNo("antialias", &antialias, tokens, fileName, line);
- } else if (!cmd->cmp("urlCommand")) {
- parseCommand("urlCommand", &urlCommand, tokens, fileName, line);
-+ } else if (!cmd->cmp("scrollLines")) {
-+ parseInteger("scrollLines", &scrollLines, tokens, fileName, line);
-+ } else if (!cmd->cmp("scrollCols")) {
-+ parseInteger("scrollCols", &scrollCols, tokens, fileName, line);
- } else if (!cmd->cmp("movieCommand")) {
- parseCommand("movieCommand", &movieCommand, tokens, fileName, line);
- } else if (!cmd->cmp("mapNumericCharNames")) {
-@@ -809,6 +815,38 @@
- *val = ((GString *)tokens->get(1))->copy();
- }
-
-+void GlobalParams::parseInteger(char *cmdName, int *val,
-+ GList *tokens, GString *fileName, int line) {
-+ char *tok;
-+ int value;
-+ GBool invalid = gFalse;
-+
-+ if (tokens->getLength() != 2) {
-+ error(-1, "Bad '%s' config file command (%s:%d)",
-+ cmdName, fileName->getCString(), line);
-+ return;
-+ }
-+ tok = ((GString*) tokens->get(1))->getCString();
-+ value = atoi(tok);
-+ if (value == 0) {
-+ // Verify it's a valid 0 (ie, a string of only '0's)
-+ if (*tok != '0')
-+ invalid = gTrue;
-+ while (!invalid && *tok != '\0')
-+ {
-+ if (*tok != '0')
-+ invalid = gTrue;
-+ tok++;
-+ }
-+ if (invalid) {
-+ error(-1, "Bad '%s' config file command (%s:%d)",
-+ cmdName, fileName->getCString(), line);
-+ return;
-+ }
-+ }
-+ *val = value;
-+}
-+
- void GlobalParams::parseYesNo(char *cmdName, GBool *flag,
- GList *tokens, GString *fileName, int line) {
- GString *tok;
-diff -ur xpdf-3.00.org/xpdf/GlobalParams.h xpdf-3.00/xpdf/GlobalParams.h
---- xpdf-3.00.org/xpdf/GlobalParams.h 2004-01-21 20:26:45.000000000 -0500
-+++ xpdf-3.00/xpdf/GlobalParams.h 2004-12-01 06:38:10.489040100 -0500
-@@ -156,6 +156,8 @@
- GBool getEnableFreeType();
- GBool getAntialias();
- GString *getURLCommand() { return urlCommand; }
-+ int getScrollLines() { return scrollLines; }
-+ int getScrollCols() { return scrollCols; }
- GString *getMovieCommand() { return movieCommand; }
- GBool getMapNumericCharNames();
- GBool getPrintCommands();
-@@ -224,6 +226,8 @@
- void parseInitialZoom(GList *tokens, GString *fileName, int line);
- void parseCommand(char *cmdName, GString **val,
- GList *tokens, GString *fileName, int line);
-+ void parseInteger(char *cmdName, int *val,
-+ GList *tokens, GString *fileName, int line);
- void parseYesNo(char *cmdName, GBool *flag,
- GList *tokens, GString *fileName, int line);
- GBool parseYesNo2(char *token, GBool *flag);
-@@ -290,6 +294,8 @@
- GBool enableT1lib; // t1lib enable flag
- GBool enableFreeType; // FreeType enable flag
- GBool antialias; // anti-aliasing enable flag
-+ int scrollLines; // How many lines to scroll
-+ int scrollCols; // How many columns to scroll
- GString *urlCommand; // command executed for URL links
- GString *movieCommand; // command executed for movie annotations
- GBool mapNumericCharNames; // map numeric char names (from font subsets)?
-diff -ur xpdf-3.00.org/xpdf/XPDFCore.cc xpdf-3.00/xpdf/XPDFCore.cc
---- xpdf-3.00.org/xpdf/XPDFCore.cc 2004-01-21 20:26:45.000000000 -0500
-+++ xpdf-3.00/xpdf/XPDFCore.cc 2004-12-01 06:38:54.614635025 -0500
-@@ -686,19 +686,35 @@
- displayPage(history[historyCur].page, zoom, rotate, gFalse, gFalse);
- }
-
--void XPDFCore::scrollLeft(int nCols) {
-+void XPDFCore::scrollLeft() {
-+ scrollLeft_(globalParams->getScrollCols());
-+}
-+
-+void XPDFCore::scrollLeft_(int nCols) {
- scrollTo(scrollX - nCols * 16, scrollY);
- }
-
--void XPDFCore::scrollRight(int nCols) {
-+void XPDFCore::scrollRight() {
-+ scrollRight_(globalParams->getScrollCols());
-+}
-+
-+void XPDFCore::scrollRight_(int nCols) {
- scrollTo(scrollX + nCols * 16, scrollY);
- }
-
--void XPDFCore::scrollUp(int nLines) {
-+void XPDFCore::scrollUp() {
-+ scrollUp_(globalParams->getScrollLines());
-+}
-+
-+void XPDFCore::scrollUp_(int nLines) {
- scrollTo(scrollX, scrollY - nLines * 16);
- }
-
--void XPDFCore::scrollDown(int nLines) {
-+void XPDFCore::scrollDown() {
-+ scrollDown_(globalParams->getScrollLines());
-+}
-+
-+void XPDFCore::scrollDown_(int nLines) {
- scrollTo(scrollX, scrollY + nLines * 16);
- }
-
-@@ -1613,7 +1629,7 @@
- } else if (core->scrollY == 0) {
- core->gotoPrevPage(1, gFalse, gTrue);
- } else {
-- core->scrollUp(1);
-+ core->scrollUp();
- }
- } else if (data->event->xbutton.button == 5) { // mouse wheel down
- if (core->fullScreen ||
-@@ -1621,15 +1637,15 @@
- core->out->getBitmapHeight() - core->drawAreaHeight) {
- core->gotoNextPage(1, gTrue);
- } else {
-- core->scrollDown(1);
-+ core->scrollDown();
- }
- } else if (data->event->xbutton.button == 6) { // second mouse wheel left
- if (!core->fullScreen) {
-- core->scrollLeft(1);
-+ core->scrollLeft();
- }
- } else if (data->event->xbutton.button == 7) { // second mouse wheel right
- if (!core->fullScreen) {
-- core->scrollRight(1);
-+ core->scrollRight();
- }
- } else {
- if (*core->mouseCbk) {
-diff -ur xpdf-3.00.org/xpdf/XPDFCore.h xpdf-3.00/xpdf/XPDFCore.h
---- xpdf-3.00.org/xpdf/XPDFCore.h 2004-01-21 20:26:45.000000000 -0500
-+++ xpdf-3.00/xpdf/XPDFCore.h 2004-12-01 06:19:08.566433277 -0500
-@@ -126,10 +126,14 @@
- void gotoPrevPage(int dec, GBool top, GBool bottom);
- void goForward();
- void goBackward();
-- void scrollLeft(int nCols = 1);
-- void scrollRight(int nCols = 1);
-- void scrollUp(int nLines = 1);
-- void scrollDown(int nLines = 1);
-+ void scrollLeft();
-+ void scrollRight();
-+ void scrollUp();
-+ void scrollDown();
-+ void scrollLeft_(int nCols = 1);
-+ void scrollRight_(int nCols = 1);
-+ void scrollUp_(int nLines = 1);
-+ void scrollDown_(int nLines = 1);
- void scrollPageUp();
- void scrollPageDown();
- void scrollTo(int x, int y);
diff --git a/app-text/xpdf/files/xpdf-3.00-security-can-2005-2097.patch b/app-text/xpdf/files/xpdf-3.00-security-can-2005-2097.patch
deleted file mode 100644
index 216b05abed98..000000000000
--- a/app-text/xpdf/files/xpdf-3.00-security-can-2005-2097.patch
+++ /dev/null
@@ -1,57 +0,0 @@
---- xpdf-3.00/fofi/FoFiTrueType.cc (revision 439182)
-+++ xpdf-3.00/fofi/FoFiTrueType.cc (working copy)
-@@ -1343,6 +1343,27 @@
- return;
- }
-
-+ // make sure the loca table is sane (correct length and entries are
-+ // in bounds)
-+ i = seekTable("loca");
-+ if (tables[i].len < (nGlyphs + 1) * (locaFmt ? 4 : 2)) {
-+ parsedOk = gFalse;
-+ return;
-+ }
-+ for (j = 0; j <= nGlyphs; ++j) {
-+ if (locaFmt) {
-+ pos = (int)getU32BE(tables[i].offset + j*4, &parsedOk);
-+ } else {
-+ pos = getU16BE(tables[i].offset + j*2, &parsedOk);
-+ }
-+ if (pos < 0 || pos > len) {
-+ parsedOk = gFalse;
-+ }
-+ }
-+ if (!parsedOk) {
-+ return;
-+ }
-+
- // read the post table
- readPostTable();
- if (!parsedOk) {
---- xpdf-3.00/xpdf/SplashOutputDev.cc (revision 439182)
-+++ xpdf-3.00/xpdf/SplashOutputDev.cc (working copy)
-@@ -621,16 +621,19 @@
- }
- break;
- case fontTrueType:
-- if (!(ff = FoFiTrueType::load(fileName->getCString()))) {
-- goto err2;
-+ if ((ff = FoFiTrueType::load(fileName->getCString()))) {
-+ codeToGID = ((Gfx8BitFont *)gfxFont)->getCodeToGIDMap(ff);
-+ n = 256;
-+ delete ff;
-+ } else {
-+ codeToGID = NULL;
-+ n = 0;
- }
-- codeToGID = ((Gfx8BitFont *)gfxFont)->getCodeToGIDMap(ff);
-- delete ff;
- if (!(fontFile = fontEngine->loadTrueTypeFont(
- id,
- fileName->getCString(),
- fileName == tmpFileName,
-- codeToGID, 256))) {
-+ codeToGID, n))) {
- error(-1, "Couldn't create a font for '%s'",
- gfxFont->getName() ? gfxFont->getName()->getCString()
- : "(unnamed)");
diff --git a/app-text/xpdf/files/xpdf-3.00-truetype-new.diff b/app-text/xpdf/files/xpdf-3.00-truetype-new.diff
deleted file mode 100644
index 73d22e81e394..000000000000
--- a/app-text/xpdf/files/xpdf-3.00-truetype-new.diff
+++ /dev/null
@@ -1,98 +0,0 @@
-diff -ruN xpdf.orig/CharCodeToUnicode.h xpdf/CharCodeToUnicode.h
---- xpdf.orig/CharCodeToUnicode.h 2004-01-21 17:26:45.000000000 -0800
-+++ xpdf/CharCodeToUnicode.h 2004-02-12 14:05:30.591633392 -0800
-@@ -67,6 +67,10 @@
- // Map a CharCode to Unicode.
- int mapToUnicode(CharCode c, Unicode *u, int size);
-
-+ // Return the mapping's length, i.e., one more than the max char
-+ // code supported by the mapping.
-+ CharCode getLength() { return mapLen; }
-+
- private:
-
- void parseCMap1(int (*getCharFunc)(void *), void *data, int nBits);
-diff -ruN xpdf.orig/SplashOutputDev.cc xpdf/SplashOutputDev.cc
---- xpdf.orig/SplashOutputDev.cc 2004-01-21 17:26:45.000000000 -0800
-+++ xpdf/SplashOutputDev.cc 2004-02-12 14:05:30.602631720 -0800
-@@ -497,15 +497,18 @@
- FILE *tmpFile;
- Gushort *codeToGID;
- DisplayFontParam *dfp;
-+ CharCodeToUnicode *ctu;
- double m11, m12, m21, m22, w1, w2;
- SplashCoord mat[4];
- char *name;
-- int c, substIdx, n, code;
-+ Unicode uBuf[8];
-+ int c, substIdx, n, code, cmap;
-
- needFontUpdate = gFalse;
- font = NULL;
- tmpFileName = NULL;
- substIdx = -1;
-+ dfp = NULL;
-
- if (!(gfxFont = state->getFont())) {
- goto err1;
-@@ -544,7 +547,6 @@
- } else if (!(fileName = gfxFont->getExtFontFile())) {
-
- // look for a display font mapping or a substitute font
-- dfp = NULL;
- if (gfxFont->isCIDFont()) {
- if (((GfxCIDFont *)gfxFont)->getCollection()) {
- dfp = globalParams->
-@@ -650,10 +652,48 @@
- }
- break;
- case fontCIDType2:
-- n = ((GfxCIDFont *)gfxFont)->getCIDToGIDLen();
-- codeToGID = (Gushort *)gmalloc(n * sizeof(Gushort));
-- memcpy(codeToGID, ((GfxCIDFont *)gfxFont)->getCIDToGID(),
-- n * sizeof(Gushort));
-+ codeToGID = NULL;
-+ n = 0;
-+ if (dfp) {
-+ // create a CID-to-GID mapping, via Unicode
-+ if ((ctu = ((GfxCIDFont *)gfxFont)->getToUnicode())) {
-+ if ((ff = FoFiTrueType::load(fileName->getCString()))) {
-+ // look for a Unicode cmap
-+ for (cmap = 0; cmap < ff->getNumCmaps(); ++cmap) {
-+ if ((ff->getCmapPlatform(cmap) == 3 &&
-+ ff->getCmapEncoding(cmap) == 1) ||
-+ ff->getCmapPlatform(cmap) == 0) {
-+ break;
-+ }
-+ }
-+ if (cmap < ff->getNumCmaps()) {
-+ // map CID -> Unicode -> GID
-+ n = ctu->getLength();
-+ codeToGID = (Gushort *)gmalloc(n * sizeof(Gushort));
-+ for (code = 0; code < n; ++code) {
-+ if (ctu->mapToUnicode(code, uBuf, 8) > 0) {
-+ codeToGID[code] = ff->mapCodeToGID(cmap, uBuf[0]);
-+ } else {
-+ codeToGID[code] = 0;
-+ }
-+ }
-+ }
-+ delete ff;
-+ }
-+ ctu->decRefCnt();
-+ } else {
-+ error(-1, "Couldn't find a mapping to Unicode for font '%s'",
-+ gfxFont->getName() ? gfxFont->getName()->getCString()
-+ : "(unnamed)");
-+ }
-+ } else {
-+ if (((GfxCIDFont *)gfxFont)->getCIDToGID()) {
-+ n = ((GfxCIDFont *)gfxFont)->getCIDToGIDLen();
-+ codeToGID = (Gushort *)gmalloc(n * sizeof(Gushort));
-+ memcpy(codeToGID, ((GfxCIDFont *)gfxFont)->getCIDToGID(),
-+ n * sizeof(Gushort));
-+ }
-+ }
- if (!(fontFile = fontEngine->loadTrueTypeFont(
- id,
- fileName->getCString(),
diff --git a/app-text/xpdf/files/xpdf-3.01-crash.patch b/app-text/xpdf/files/xpdf-3.01-crash.patch
deleted file mode 100644
index 21e60b3bfd7a..000000000000
--- a/app-text/xpdf/files/xpdf-3.01-crash.patch
+++ /dev/null
@@ -1,34 +0,0 @@
---- xpdf-3.00/splash/Splash.cc.tn 2005-07-25 09:59:45.000000000 +0200
-+++ xpdf-3.00/splash/Splash.cc 2005-07-25 10:00:58.000000000 +0200
-@@ -636,6 +641,11 @@
-
- xPath = new SplashXPath(path, state->flatness, gTrue);
- xPath->sort();
-+ if (!&xPath->segs[0])
-+ {
-+ delete xPath;
-+ return splashErrEmptyPath;
-+ }
- scanner = new SplashXPathScanner(xPath, eo);
-
- // get the min and max x and y values
---- xpdf-3.00/fofi/FoFiType1.cc.tn 2005-07-25 10:34:04.000000000 +0200
-+++ xpdf-3.00/fofi/FoFiType1.cc 2005-07-25 10:41:37.000000000 +0200
-@@ -187,9 +187,14 @@
- }
- }
- } else {
-- if (strtok(buf, " \t") &&
-- (p = strtok(NULL, " \t\n\r")) && !strcmp(p, "def")) {
-- break;
-+ p = strtok(buf, " \t\n\r");
-+ if (p)
-+ {
-+ if (!strcmp(p, "def")) break;
-+ if (!strcmp(p, "readonly")) break;
-+ // the spec does not says this but i'm mantaining old xpdf behaviour that accepts "foo def" as end of the encoding array
-+ p = strtok(buf, " \t\n\r");
-+ if (p && !strcmp(p, "def")) break;
- }
- }
- line = line1;
diff --git a/app-text/xpdf/files/xpdf-3.01-nodrm.patch b/app-text/xpdf/files/xpdf-3.01-nodrm.patch
deleted file mode 100644
index c657a2645525..000000000000
--- a/app-text/xpdf/files/xpdf-3.01-nodrm.patch
+++ /dev/null
@@ -1,104 +0,0 @@
-diff -u xpdf-3.01.orig/xpdf/PDFCore.cc xpdf-3.01/xpdf/PDFCore.cc
---- xpdf-3.01.orig/xpdf/PDFCore.cc 2005-10-05 16:29:19.000000000 +0200
-+++ xpdf-3.01/xpdf/PDFCore.cc 2005-10-05 16:29:28.000000000 +0200
-@@ -1273,9 +1273,6 @@
- int x0, y0, x1, y1, t;
- GString *s;
-
-- if (!doc->okToCopy()) {
-- return NULL;
-- }
- if ((page = findPage(pg))) {
- cvtUserToDev(pg, xMin, yMin, &x0, &y0);
- cvtUserToDev(pg, xMax, yMax, &x1, &y1);
-diff -u xpdf-3.01.orig/xpdf/pdfimages.cc xpdf-3.01/xpdf/pdfimages.cc
---- xpdf-3.01.orig/xpdf/pdfimages.cc 2005-10-05 16:29:19.000000000 +0200
-+++ xpdf-3.01/xpdf/pdfimages.cc 2005-10-05 16:29:28.000000000 +0200
-@@ -118,13 +118,6 @@
- goto err1;
- }
-
-- // check for copy permission
-- if (!doc->okToCopy()) {
-- error(-1, "Copying of images from this document is not allowed.");
-- exitCode = 3;
-- goto err1;
-- }
--
- // get page range
- if (firstPage < 1)
- firstPage = 1;
-diff -u xpdf-3.01.orig/xpdf/pdftops.cc xpdf-3.01/xpdf/pdftops.cc
---- xpdf-3.01.orig/xpdf/pdftops.cc 2005-10-05 16:29:19.000000000 +0200
-+++ xpdf-3.01/xpdf/pdftops.cc 2005-10-05 16:29:28.000000000 +0200
-@@ -269,13 +269,6 @@
- goto err1;
- }
-
-- // check for print permission
-- if (!doc->okToPrint()) {
-- error(-1, "Printing this document is not allowed.");
-- exitCode = 3;
-- goto err1;
-- }
--
- // construct PostScript file name
- if (argc == 3) {
- psFileName = new GString(argv[2]);
-diff -u xpdf-3.01.orig/xpdf/pdftotext.cc xpdf-3.01/xpdf/pdftotext.cc
---- xpdf-3.01.orig/xpdf/pdftotext.cc 2005-10-05 16:29:19.000000000 +0200
-+++ xpdf-3.01/xpdf/pdftotext.cc 2005-10-05 16:29:28.000000000 +0200
-@@ -160,13 +160,6 @@
- goto err2;
- }
-
-- // check for copy permission
-- if (!doc->okToCopy()) {
-- error(-1, "Copying of text from this document is not allowed.");
-- exitCode = 3;
-- goto err2;
-- }
--
- // construct text file name
- if (argc == 3) {
- textFileName = new GString(argv[2]);
-diff -u xpdf-3.01.orig/xpdf/XPDFCore.cc xpdf-3.01/xpdf/XPDFCore.cc
---- xpdf-3.01.orig/xpdf/XPDFCore.cc 2005-10-05 16:29:19.000000000 +0200
-+++ xpdf-3.01/xpdf/XPDFCore.cc 2005-10-05 16:29:28.000000000 +0200
-@@ -377,9 +377,6 @@
- int pg;
- double ulx, uly, lrx, lry;
-
-- if (!doc->okToCopy()) {
-- return;
-- }
- if (getSelection(&pg, &ulx, &uly, &lrx, &lry)) {
- //~ for multithreading: need a mutex here
- if (currentSelection) {
-@@ -1108,11 +1105,7 @@
- #ifndef NO_TEXT_SELECT
- if (core->selectULX != core->selectLRX &&
- core->selectULY != core->selectLRY) {
-- if (core->doc->okToCopy()) {
-- core->copySelection();
-- } else {
-- error(-1, "Copying of text from this document is not allowed.");
-- }
-+ core->copySelection();
- }
- #endif
- }
-diff -u xpdf-3.01.orig/xpdf/XPDFViewer.cc xpdf-3.01/xpdf/XPDFViewer.cc
---- xpdf-3.01.orig/xpdf/XPDFViewer.cc 2005-10-05 16:29:19.000000000 +0200
-+++ xpdf-3.01/xpdf/XPDFViewer.cc 2005-10-05 16:29:28.000000000 +0200
-@@ -2391,10 +2391,6 @@
- PSOutputDev *psOut;
-
- doc = viewer->core->getDoc();
-- if (!doc->okToPrint()) {
-- error(-1, "Printing this document is not allowed.");
-- return;
-- }
-
- viewer->core->setBusyCursor(gTrue);
-
diff --git a/app-text/xpdf/files/xpdf-3.01-onlyx.patch b/app-text/xpdf/files/xpdf-3.01-onlyx.patch
deleted file mode 100644
index 37deb68534eb..000000000000
--- a/app-text/xpdf/files/xpdf-3.01-onlyx.patch
+++ /dev/null
@@ -1,82 +0,0 @@
-diff --exclude-from=/home/dang/.diffrc -u -ruN xpdf-3.01.orig/Makefile.in xpdf-3.01/Makefile.in
---- xpdf-3.01.orig/Makefile.in 2005-12-27 12:35:34.000000000 -0500
-+++ xpdf-3.01/Makefile.in 2005-12-27 12:38:00.000000000 -0500
-@@ -37,61 +37,21 @@
- cd @UP_DIR@splash; $(MAKE)
- cd @UP_DIR@xpdf; $(MAKE) xpdf$(EXE)
-
--pdftops: dummy
-- cd goo; $(MAKE)
-- cd @UP_DIR@fofi; $(MAKE)
-- cd @UP_DIR@splash; $(MAKE)
-- cd @UP_DIR@xpdf; $(MAKE) pdftops$(EXE)
--
--pdftotext: dummy
-- cd goo; $(MAKE)
-- cd @UP_DIR@fofi; $(MAKE)
-- cd @UP_DIR@splash; $(MAKE)
-- cd @UP_DIR@xpdf; $(MAKE) pdftotext$(EXE)
--
--pdfinfo:
-- cd goo; $(MAKE)
-- cd @UP_DIR@fofi; $(MAKE)
-- cd @UP_DIR@splash; $(MAKE)
-- cd @UP_DIR@xpdf; $(MAKE) pdfinfo$(EXE)
--
--pdffonts:
-- cd goo; $(MAKE)
-- cd @UP_DIR@fofi; $(MAKE)
-- cd @UP_DIR@splash; $(MAKE)
-- cd @UP_DIR@xpdf; $(MAKE) pdffonts$(EXE)
--
- pdftoppm:
- cd goo; $(MAKE)
- cd @UP_DIR@fofi; $(MAKE)
- cd @UP_DIR@splash; $(MAKE)
- cd @UP_DIR@xpdf; $(MAKE) pdftoppm$(EXE)
-
--pdfimages:
-- cd goo; $(MAKE)
-- cd @UP_DIR@fofi; $(MAKE)
-- cd @UP_DIR@splash; $(MAKE)
-- cd @UP_DIR@xpdf; $(MAKE) pdfimages$(EXE)
--
- dummy:
-
- install: dummy
- -mkdir -p $(DESTDIR)@bindir@
- @X@ $(INSTALL_PROGRAM) xpdf/xpdf$(EXE) $(DESTDIR)@bindir@/xpdf$(EXE)
-- $(INSTALL_PROGRAM) xpdf/pdftops$(EXE) $(DESTDIR)@bindir@/pdftops$(EXE)
-- $(INSTALL_PROGRAM) xpdf/pdftotext$(EXE) $(DESTDIR)@bindir@/pdftotext$(EXE)
-- $(INSTALL_PROGRAM) xpdf/pdfinfo$(EXE) $(DESTDIR)@bindir@/pdfinfo$(EXE)
-- $(INSTALL_PROGRAM) xpdf/pdffonts$(EXE) $(DESTDIR)@bindir@/pdffonts$(EXE)
- $(INSTALL_PROGRAM) xpdf/pdftoppm$(EXE) $(DESTDIR)@bindir@/pdftoppm$(EXE)
-- $(INSTALL_PROGRAM) xpdf/pdfimages$(EXE) $(DESTDIR)@bindir@/pdfimages$(EXE)
- -mkdir -p $(DESTDIR)@mandir@/man1
- @X@ $(INSTALL_DATA) $(srcdir)/doc/xpdf.1 $(DESTDIR)@mandir@/man1/xpdf.1
-- $(INSTALL_DATA) $(srcdir)/doc/pdftops.1 $(DESTDIR)@mandir@/man1/pdftops.1
-- $(INSTALL_DATA) $(srcdir)/doc/pdftotext.1 $(DESTDIR)@mandir@/man1/pdftotext.1
-- $(INSTALL_DATA) $(srcdir)/doc/pdfinfo.1 $(DESTDIR)@mandir@/man1/pdfinfo.1
-- $(INSTALL_DATA) $(srcdir)/doc/pdffonts.1 $(DESTDIR)@mandir@/man1/pdffonts.1
- $(INSTALL_DATA) $(srcdir)/doc/pdftoppm.1 $(DESTDIR)@mandir@/man1/pdftoppm.1
-- $(INSTALL_DATA) $(srcdir)/doc/pdfimages.1 $(DESTDIR)@mandir@/man1/pdfimages.1
- -mkdir -p $(DESTDIR)@mandir@/man5
- $(INSTALL_DATA) $(srcdir)/doc/xpdfrc.5 $(DESTDIR)@mandir@/man5/xpdfrc.5
- -mkdir -p $(DESTDIR)@sysconfdir@
-diff --exclude-from=/home/dang/.diffrc -u -ruN xpdf-3.01.orig/xpdf/Makefile.in xpdf-3.01/xpdf/Makefile.in
---- xpdf-3.01.orig/xpdf/Makefile.in 2005-12-27 12:35:34.000000000 -0500
-+++ xpdf-3.01/xpdf/Makefile.in 2005-12-27 12:39:38.000000000 -0500
-@@ -105,11 +105,9 @@
-
- #------------------------------------------------------------------------
-
--all: xpdf$(EXE) pdftops$(EXE) pdftotext$(EXE) pdfinfo$(EXE) \
-- pdffonts$(EXE) pdftoppm$(EXE) pdfimages$(EXE)
-+all: xpdf$(EXE) pdftoppm$(EXE)
-
--all-no-x: pdftops$(EXE) pdftotext$(EXE) pdfinfo$(EXE) pdffonts$(EXE) \
-- pdftoppm$(EXE) pdfimages$(EXE)
-+all-no-x: pdftoppm$(EXE)
-
- #------------------------------------------------------------------------
-
diff --git a/app-text/xpdf/files/xpdf-3.01-pdftoppm.patch b/app-text/xpdf/files/xpdf-3.01-pdftoppm.patch
deleted file mode 100644
index 7e0dc988309c..000000000000
--- a/app-text/xpdf/files/xpdf-3.01-pdftoppm.patch
+++ /dev/null
@@ -1,33 +0,0 @@
-diff -urN xpdf-3.01/Makefile.in xpdf-3.01-pdftoppm-no_X-patch/Makefile.in
---- xpdf-3.01/Makefile.in 2005-08-17 07:34:30.000000000 +0200
-+++ xpdf-3.01-pdftoppm-no_X-patch/Makefile.in 2005-09-12 23:12:25.272986000 +0200
-@@ -82,7 +82,7 @@
- $(INSTALL_PROGRAM) xpdf/pdftotext$(EXE) $(DESTDIR)@bindir@/pdftotext$(EXE)
- $(INSTALL_PROGRAM) xpdf/pdfinfo$(EXE) $(DESTDIR)@bindir@/pdfinfo$(EXE)
- $(INSTALL_PROGRAM) xpdf/pdffonts$(EXE) $(DESTDIR)@bindir@/pdffonts$(EXE)
--@X@ $(INSTALL_PROGRAM) xpdf/pdftoppm$(EXE) $(DESTDIR)@bindir@/pdftoppm$(EXE)
-+ $(INSTALL_PROGRAM) xpdf/pdftoppm$(EXE) $(DESTDIR)@bindir@/pdftoppm$(EXE)
- $(INSTALL_PROGRAM) xpdf/pdfimages$(EXE) $(DESTDIR)@bindir@/pdfimages$(EXE)
- -mkdir -p $(DESTDIR)@mandir@/man1
- @X@ $(INSTALL_DATA) $(srcdir)/doc/xpdf.1 $(DESTDIR)@mandir@/man1/xpdf.1
-@@ -90,7 +90,7 @@
- $(INSTALL_DATA) $(srcdir)/doc/pdftotext.1 $(DESTDIR)@mandir@/man1/pdftotext.1
- $(INSTALL_DATA) $(srcdir)/doc/pdfinfo.1 $(DESTDIR)@mandir@/man1/pdfinfo.1
- $(INSTALL_DATA) $(srcdir)/doc/pdffonts.1 $(DESTDIR)@mandir@/man1/pdffonts.1
--@X@ $(INSTALL_DATA) $(srcdir)/doc/pdftoppm.1 $(DESTDIR)@mandir@/man1/pdftoppm.1
-+ $(INSTALL_DATA) $(srcdir)/doc/pdftoppm.1 $(DESTDIR)@mandir@/man1/pdftoppm.1
- $(INSTALL_DATA) $(srcdir)/doc/pdfimages.1 $(DESTDIR)@mandir@/man1/pdfimages.1
- -mkdir -p $(DESTDIR)@mandir@/man5
- $(INSTALL_DATA) $(srcdir)/doc/xpdfrc.5 $(DESTDIR)@mandir@/man5/xpdfrc.5
-diff -urN xpdf-3.01/xpdf/Makefile.in xpdf-3.01-pdftoppm-no_X-patch/xpdf/Makefile.in
---- xpdf-3.01/xpdf/Makefile.in 2005-08-17 07:34:31.000000000 +0200
-+++ xpdf-3.01-pdftoppm-no_X-patch/xpdf/Makefile.in 2005-09-12 23:27:53.903705325 +0200
-@@ -109,7 +109,7 @@
- pdffonts$(EXE) pdftoppm$(EXE) pdfimages$(EXE)
-
- all-no-x: pdftops$(EXE) pdftotext$(EXE) pdfinfo$(EXE) pdffonts$(EXE) \
-- pdfimages$(EXE)
-+ pdftoppm$(EXE) pdfimages$(EXE)
-
- #------------------------------------------------------------------------
-
diff --git a/app-text/xpdf/files/xpdf-3.01-resize.patch b/app-text/xpdf/files/xpdf-3.01-resize.patch
deleted file mode 100644
index c1240c3406f0..000000000000
--- a/app-text/xpdf/files/xpdf-3.01-resize.patch
+++ /dev/null
@@ -1,36 +0,0 @@
---- xpdf-3.01/xpdf/XPDFCore.cc.resize 2005-10-06 23:40:10.000000000 +0200
-+++ xpdf-3.01/xpdf/XPDFCore.cc 2005-10-06 23:40:10.000000000 +0200
-@@ -979,6 +979,9 @@
- XPDFCore *core = (XPDFCore *)ptr;
- XEvent event;
- Widget top;
-+ Window rootWin;
-+ int x1, y1;
-+ Guint w1, h1, bw1, depth1;
- Arg args[2];
- int n;
- Dimension w, h;
-@@ -986,15 +989,20 @@
-
- // find the top-most widget which has an associated window, and look
- // for a pending ConfigureNotify in the event queue -- if there is
-- // one, that means we're still resizing, and we want to skip the
-- // current event
-+ // one, and it specifies a different width or height, that means
-+ // we're still resizing, and we want to skip the current event
- for (top = core->parentWidget;
- XtParent(top) && XtWindow(XtParent(top));
- top = XtParent(top)) ;
- if (XCheckTypedWindowEvent(core->display, XtWindow(top),
- ConfigureNotify, &event)) {
- XPutBackEvent(core->display, &event);
-- return;
-+ XGetGeometry(core->display, event.xconfigure.window,
-+ &rootWin, &x1, &y1, &w1, &h1, &bw1, &depth1);
-+ if ((Guint)event.xconfigure.width != w1 ||
-+ (Guint)event.xconfigure.height != h1) {
-+ return;
-+ }
- }
-
- n = 0;
diff --git a/app-text/xpdf/files/xpdf-3.01-sec-rollup.patch b/app-text/xpdf/files/xpdf-3.01-sec-rollup.patch
deleted file mode 100644
index 04d2f5673e90..000000000000
--- a/app-text/xpdf/files/xpdf-3.01-sec-rollup.patch
+++ /dev/null
@@ -1,266 +0,0 @@
-diff --exclude-from=/home/dang/.diffrc -u -ruN xpdf-3.01.orig/xpdf/JBIG2Stream.cc xpdf-3.01/xpdf/JBIG2Stream.cc
---- xpdf-3.01.orig/xpdf/JBIG2Stream.cc 2005-08-17 01:34:31.000000000 -0400
-+++ xpdf-3.01/xpdf/JBIG2Stream.cc 2006-01-05 14:48:26.000000000 -0500
-@@ -7,6 +7,7 @@
- //========================================================================
-
- #include <aconf.h>
-+#include <limits.h>
-
- #ifdef USE_GCC_PRAGMAS
- #pragma implementation
-@@ -681,6 +682,13 @@
- w = wA;
- h = hA;
- line = (wA + 7) >> 3;
-+
-+ if (h < 0 || line <= 0 || h >= (INT_MAX - 1) / line) {
-+ error(-1, "invalid width/height");
-+ data = NULL;
-+ return;
-+ }
-+
- // need to allocate one extra guard byte for use in combine()
- data = (Guchar *)gmalloc(h * line + 1);
- data[h * line] = 0;
-@@ -692,6 +700,13 @@
- w = bitmap->w;
- h = bitmap->h;
- line = bitmap->line;
-+
-+ if (h < 0 || line <= 0 || h >= (INT_MAX - 1) / line) {
-+ error(-1, "invalid width/height");
-+ data = NULL;
-+ return;
-+ }
-+
- // need to allocate one extra guard byte for use in combine()
- data = (Guchar *)gmalloc(h * line + 1);
- memcpy(data, bitmap->data, h * line);
-@@ -720,7 +735,10 @@
- }
-
- void JBIG2Bitmap::expand(int newH, Guint pixel) {
-- if (newH <= h) {
-+ if (newH <= h || line <= 0 || newH >= (INT_MAX - 1) / line) {
-+ error(-1, "invalid width/height");
-+ gfree(data);
-+ data = NULL;
- return;
- }
- // need to allocate one extra guard byte for use in combine()
-@@ -2305,6 +2323,15 @@
- error(getPos(), "Bad symbol dictionary reference in JBIG2 halftone segment");
- return;
- }
-+ if (gridH == 0 || gridW >= INT_MAX / gridH) {
-+ error(getPos(), "Bad size in JBIG2 halftone segment");
-+ return;
-+ }
-+ if (w == 0 || h >= INT_MAX / w) {
-+ error(getPos(), "Bad size in JBIG2 bitmap segment");
-+ return;
-+ }
-+
- patternDict = (JBIG2PatternDict *)seg;
- bpp = 0;
- i = 1;
-@@ -2936,6 +2963,11 @@
- JBIG2BitmapPtr tpgrCXPtr0, tpgrCXPtr1, tpgrCXPtr2;
- int x, y, pix;
-
-+ if (w < 0 || h <= 0 || w >= INT_MAX / h) {
-+ error(-1, "invalid width/height");
-+ return NULL;
-+ }
-+
- bitmap = new JBIG2Bitmap(0, w, h);
- bitmap->clearToZero();
-
-diff --exclude-from=/home/dang/.diffrc -u -ruN xpdf-3.01.orig/xpdf/JPXStream.cc xpdf-3.01/xpdf/JPXStream.cc
---- xpdf-3.01.orig/xpdf/JPXStream.cc 2005-08-17 01:34:31.000000000 -0400
-+++ xpdf-3.01/xpdf/JPXStream.cc 2006-01-05 14:49:33.000000000 -0500
-@@ -7,6 +7,7 @@
- //========================================================================
-
- #include <aconf.h>
-+#include <limits.h>
-
- #ifdef USE_GCC_PRAGMAS
- #pragma implementation
-@@ -783,7 +784,7 @@
- int segType;
- GBool haveSIZ, haveCOD, haveQCD, haveSOT;
- Guint precinctSize, style;
-- Guint segLen, capabilities, comp, i, j, r;
-+ Guint segLen, capabilities, nTiles, comp, i, j, r;
-
- //----- main header
- haveSIZ = haveCOD = haveQCD = haveSOT = gFalse;
-@@ -818,8 +819,19 @@
- / img.xTileSize;
- img.nYTiles = (img.ySize - img.yTileOffset + img.yTileSize - 1)
- / img.yTileSize;
-- img.tiles = (JPXTile *)gmallocn(img.nXTiles * img.nYTiles,
-- sizeof(JPXTile));
-+ // check for overflow before allocating memory
-+ if (img.nXTiles <= 0 || img.nYTiles <= 0 ||
-+ img.nXTiles >= INT_MAX/img.nYTiles) {
-+ error(getPos(), "Bad tile count in JPX SIZ marker segment");
-+ return gFalse;
-+ }
-+ nTiles = img.nXTiles * img.nYTiles;
-+ if (nTiles >= INT_MAX/sizeof(JPXTile)) {
-+ error(getPos(), "Bad tile count in JPX SIZ marker segment");
-+ return gFalse;
-+ }
-+ img.tiles = (JPXTile *)gmalloc(nTiles * sizeof(JPXTile));
-+
- for (i = 0; i < img.nXTiles * img.nYTiles; ++i) {
- img.tiles[i].tileComps = (JPXTileComp *)gmallocn(img.nComps,
- sizeof(JPXTileComp));
-diff --exclude-from=/home/dang/.diffrc -u -ruN xpdf-3.01.orig/xpdf/Stream.cc xpdf-3.01/xpdf/Stream.cc
---- xpdf-3.01.orig/xpdf/Stream.cc 2005-08-17 01:34:31.000000000 -0400
-+++ xpdf-3.01/xpdf/Stream.cc 2006-01-05 14:50:31.000000000 -0500
-@@ -15,6 +15,7 @@
- #include <stdio.h>
- #include <stdlib.h>
- #include <stddef.h>
-+#include <limits.h>
- #ifndef WIN32
- #include <unistd.h>
- #endif
-@@ -406,13 +407,28 @@
- width = widthA;
- nComps = nCompsA;
- nBits = nBitsA;
-+ predLine = NULL;
-+ ok = gFalse;
-
-+ if (width <= 0 || nComps <= 0 || nBits <= 0 ||
-+ nComps >= INT_MAX/nBits ||
-+ width >= INT_MAX/nComps/nBits) {
-+ return;
-+ }
- nVals = width * nComps;
-+ if (nVals * nBits + 7 <= 0) {
-+ return;
-+ }
- pixBytes = (nComps * nBits + 7) >> 3;
- rowBytes = ((nVals * nBits + 7) >> 3) + pixBytes;
-+ if (rowBytes < 0) {
-+ return;
-+ }
- predLine = (Guchar *)gmalloc(rowBytes);
- memset(predLine, 0, rowBytes);
- predIdx = rowBytes;
-+
-+ ok = gTrue;
- }
-
- StreamPredictor::~StreamPredictor() {
-@@ -1004,6 +1020,10 @@
- FilterStream(strA) {
- if (predictor != 1) {
- pred = new StreamPredictor(this, predictor, columns, colors, bits);
-+ if (!pred->isOk()) {
-+ delete pred;
-+ pred = NULL;
-+ }
- } else {
- pred = NULL;
- }
-@@ -1256,8 +1276,9 @@
- endOfLine = endOfLineA;
- byteAlign = byteAlignA;
- columns = columnsA;
-- if (columns < 1) {
-- columns = 1;
-+ if (columns < 1 || columns >= INT_MAX / sizeof(short)) {
-+ error(-1, "invalid number of columns: %d", columns);
-+ exit(1);
- }
- rows = rowsA;
- endOfBlock = endOfBlockA;
-@@ -2899,6 +2920,11 @@
- height = read16();
- width = read16();
- numComps = str->getChar();
-+ if (numComps <= 0 || numComps > 4) {
-+ numComps = 0;
-+ error(getPos(), "Bad number of components in DCT stream");
-+ return gFalse;
-+ }
- if (prec != 8) {
- error(getPos(), "Bad DCT precision %d", prec);
- return gFalse;
-@@ -2925,6 +2951,11 @@
- height = read16();
- width = read16();
- numComps = str->getChar();
-+ if (numComps <= 0 || numComps > 4) {
-+ numComps = 0;
-+ error(getPos(), "Bad number of components in DCT stream");
-+ return gFalse;
-+ }
- if (prec != 8) {
- error(getPos(), "Bad DCT precision %d", prec);
- return gFalse;
-@@ -2947,6 +2978,11 @@
-
- length = read16() - 2;
- scanInfo.numComps = str->getChar();
-+ if (scanInfo.numComps <= 0 || scanInfo.numComps > 4) {
-+ scanInfo.numComps = 0;
-+ error(getPos(), "Bad number of components in DCT stream");
-+ return gFalse;
-+ }
- --length;
- if (length != 2 * scanInfo.numComps + 3) {
- error(getPos(), "Bad DCT scan info block");
-@@ -3031,12 +3067,12 @@
- while (length > 0) {
- index = str->getChar();
- --length;
-- if ((index & 0x0f) >= 4) {
-+ if ((index & ~0x10) >= 4 || (index & ~0x10) < 0) {
- error(getPos(), "Bad DCT Huffman table");
- return gFalse;
- }
- if (index & 0x10) {
-- index &= 0x0f;
-+ index &= 0x03;
- if (index >= numACHuffTables)
- numACHuffTables = index+1;
- tbl = &acHuffTables[index];
-@@ -3827,6 +3863,10 @@
- FilterStream(strA) {
- if (predictor != 1) {
- pred = new StreamPredictor(this, predictor, columns, colors, bits);
-+ if (!pred->isOk()) {
-+ delete pred;
-+ pred = NULL;
-+ }
- } else {
- pred = NULL;
- }
-diff --exclude-from=/home/dang/.diffrc -u -ruN xpdf-3.01.orig/xpdf/Stream.h xpdf-3.01/xpdf/Stream.h
---- xpdf-3.01.orig/xpdf/Stream.h 2005-08-17 01:34:31.000000000 -0400
-+++ xpdf-3.01/xpdf/Stream.h 2006-01-05 14:44:31.000000000 -0500
-@@ -232,6 +232,8 @@
-
- ~StreamPredictor();
-
-+ GBool isOk() { return ok; }
-+
- int lookChar();
- int getChar();
-
-@@ -249,6 +251,7 @@
- int rowBytes; // bytes per line
- Guchar *predLine; // line buffer
- int predIdx; // current index in predLine
-+ GBool ok;
- };
-
- //------------------------------------------------------------------------
diff --git a/app-text/xpdf/files/xpdf-3.01pl1.patch b/app-text/xpdf/files/xpdf-3.01pl1.patch
deleted file mode 100644
index 8b038ad56f0d..000000000000
--- a/app-text/xpdf/files/xpdf-3.01pl1.patch
+++ /dev/null
@@ -1,168 +0,0 @@
-diff -c -r xpdf-3.01-orig/xpdf/JPXStream.cc xpdf-3.01/xpdf/JPXStream.cc
-*** xpdf-3.01-orig/xpdf/JPXStream.cc Tue Aug 16 22:34:31 2005
---- xpdf-3.01/xpdf/JPXStream.cc Thu Nov 3 16:50:39 2005
-***************
-*** 783,789 ****
- int segType;
- GBool haveSIZ, haveCOD, haveQCD, haveSOT;
- Guint precinctSize, style;
-! Guint segLen, capabilities, comp, i, j, r;
-
- //----- main header
- haveSIZ = haveCOD = haveQCD = haveSOT = gFalse;
---- 783,789 ----
- int segType;
- GBool haveSIZ, haveCOD, haveQCD, haveSOT;
- Guint precinctSize, style;
-! Guint segLen, capabilities, nTiles, comp, i, j, r;
-
- //----- main header
- haveSIZ = haveCOD = haveQCD = haveSOT = gFalse;
-***************
-*** 818,825 ****
- / img.xTileSize;
- img.nYTiles = (img.ySize - img.yTileOffset + img.yTileSize - 1)
- / img.yTileSize;
-! img.tiles = (JPXTile *)gmallocn(img.nXTiles * img.nYTiles,
-! sizeof(JPXTile));
- for (i = 0; i < img.nXTiles * img.nYTiles; ++i) {
- img.tiles[i].tileComps = (JPXTileComp *)gmallocn(img.nComps,
- sizeof(JPXTileComp));
---- 818,830 ----
- / img.xTileSize;
- img.nYTiles = (img.ySize - img.yTileOffset + img.yTileSize - 1)
- / img.yTileSize;
-! nTiles = img.nXTiles * img.nYTiles;
-! // check for overflow before allocating memory
-! if (nTiles == 0 || nTiles / img.nXTiles != img.nYTiles) {
-! error(getPos(), "Bad tile count in JPX SIZ marker segment");
-! return gFalse;
-! }
-! img.tiles = (JPXTile *)gmallocn(nTiles, sizeof(JPXTile));
- for (i = 0; i < img.nXTiles * img.nYTiles; ++i) {
- img.tiles[i].tileComps = (JPXTileComp *)gmallocn(img.nComps,
- sizeof(JPXTileComp));
-diff -c -r xpdf-3.01-orig/xpdf/Stream.cc xpdf-3.01/xpdf/Stream.cc
-*** xpdf-3.01-orig/xpdf/Stream.cc Tue Aug 16 22:34:31 2005
---- xpdf-3.01/xpdf/Stream.cc Thu Nov 3 16:50:39 2005
-***************
-*** 401,418 ****
-
- StreamPredictor::StreamPredictor(Stream *strA, int predictorA,
- int widthA, int nCompsA, int nBitsA) {
- str = strA;
- predictor = predictorA;
- width = widthA;
- nComps = nCompsA;
- nBits = nBitsA;
-
- nVals = width * nComps;
- pixBytes = (nComps * nBits + 7) >> 3;
-! rowBytes = ((nVals * nBits + 7) >> 3) + pixBytes;
- predLine = (Guchar *)gmalloc(rowBytes);
- memset(predLine, 0, rowBytes);
- predIdx = rowBytes;
- }
-
- StreamPredictor::~StreamPredictor() {
---- 401,433 ----
-
- StreamPredictor::StreamPredictor(Stream *strA, int predictorA,
- int widthA, int nCompsA, int nBitsA) {
-+ int totalBits;
-+
- str = strA;
- predictor = predictorA;
- width = widthA;
- nComps = nCompsA;
- nBits = nBitsA;
-+ predLine = NULL;
-+ ok = gFalse;
-
- nVals = width * nComps;
-+ totalBits = nVals * nBits;
-+ if (totalBits == 0 ||
-+ (totalBits / nBits) / nComps != width ||
-+ totalBits + 7 < 0) {
-+ return;
-+ }
- pixBytes = (nComps * nBits + 7) >> 3;
-! rowBytes = ((totalBits + 7) >> 3) + pixBytes;
-! if (rowBytes < 0) {
-! return;
-! }
- predLine = (Guchar *)gmalloc(rowBytes);
- memset(predLine, 0, rowBytes);
- predIdx = rowBytes;
-+
-+ ok = gTrue;
- }
-
- StreamPredictor::~StreamPredictor() {
-***************
-*** 1004,1009 ****
---- 1019,1028 ----
- FilterStream(strA) {
- if (predictor != 1) {
- pred = new StreamPredictor(this, predictor, columns, colors, bits);
-+ if (!pred->isOk()) {
-+ delete pred;
-+ pred = NULL;
-+ }
- } else {
- pred = NULL;
- }
-***************
-*** 2899,2904 ****
---- 2918,2931 ----
- height = read16();
- width = read16();
- numComps = str->getChar();
-+ if (numComps <= 0 || numComps > 4) {
-+ error(getPos(), "Bad number of components in DCT stream", prec);
-+ return gFalse;
-+ }
-+ if (numComps <= 0 || numComps > 4) {
-+ error(getPos(), "Bad number of components in DCT stream", prec);
-+ return gFalse;
-+ }
- if (prec != 8) {
- error(getPos(), "Bad DCT precision %d", prec);
- return gFalse;
-***************
-*** 3827,3832 ****
---- 3854,3863 ----
- FilterStream(strA) {
- if (predictor != 1) {
- pred = new StreamPredictor(this, predictor, columns, colors, bits);
-+ if (!pred->isOk()) {
-+ delete pred;
-+ pred = NULL;
-+ }
- } else {
- pred = NULL;
- }
-diff -c -r xpdf-3.01-orig/xpdf/Stream.h xpdf-3.01/xpdf/Stream.h
-*** xpdf-3.01-orig/xpdf/Stream.h Tue Aug 16 22:34:31 2005
---- xpdf-3.01/xpdf/Stream.h Thu Nov 3 16:50:39 2005
-***************
-*** 232,237 ****
---- 232,239 ----
-
- ~StreamPredictor();
-
-+ GBool isOk() { return ok; }
-+
- int lookChar();
- int getChar();
-
-***************
-*** 249,254 ****
---- 251,257 ----
- int rowBytes; // bytes per line
- Guchar *predLine; // line buffer
- int predIdx; // current index in predLine
-+ GBool ok;
- };
-
- //------------------------------------------------------------------------
diff --git a/app-text/xpdf/files/xpdf-goo-sizet.patch b/app-text/xpdf/files/xpdf-goo-sizet.patch
deleted file mode 100644
index 5d90c5120bd4..000000000000
--- a/app-text/xpdf/files/xpdf-goo-sizet.patch
+++ /dev/null
@@ -1,57 +0,0 @@
-diff -ru xpdf-2.02pl1/goo/gmem.c xpdf-2.02pl1/goo/gmem.c
---- xpdf-2.02pl1/goo/gmem.c 2003-06-16 22:01:26.000000000 +0200
-+++ xpdf-2.02pl1/goo/gmem.c 2004-10-29 15:13:34.866919791 +0200
-@@ -53,9 +53,9 @@
-
- #endif /* DEBUG_MEM */
-
--void *gmalloc(int size) {
-+void *gmalloc(size_t size) {
- #ifdef DEBUG_MEM
-- int size1;
-+ size_t size1;
- char *mem;
- GMemHdr *hdr;
- void *data;
-@@ -94,11 +94,11 @@
- #endif
- }
-
--void *grealloc(void *p, int size) {
-+void *grealloc(void *p, size_t size) {
- #ifdef DEBUG_MEM
- GMemHdr *hdr;
- void *q;
-- int oldSize;
-+ size_t oldSize;
-
- if (size == 0) {
- if (p)
-@@ -137,7 +137,7 @@
-
- void gfree(void *p) {
- #ifdef DEBUG_MEM
-- int size;
-+ size_t size;
- GMemHdr *hdr;
- GMemHdr *prevHdr, *q;
- int lst;
-diff -ru xpdf-2.02pl1/goo/gmem.h xpdf-2.02pl1/goo/gmem.h
---- xpdf-2.02pl1/goo/gmem.h 2003-06-16 22:01:26.000000000 +0200
-+++ xpdf-2.02pl1/goo/gmem.h 2004-10-29 15:13:50.864027201 +0200
-@@ -19,13 +19,13 @@
- * Same as malloc, but prints error message and exits if malloc()
- * returns NULL.
- */
--extern void *gmalloc(int size);
-+extern void *gmalloc(size_t size);
-
- /*
- * Same as realloc, but prints error message and exits if realloc()
- * returns NULL. If <p> is NULL, calls malloc instead of realloc().
- */
--extern void *grealloc(void *p, int size);
-+extern void *grealloc(void *p, size_t size);
-
- /*
- * Same as free, but checks for and ignores NULL pointers.
diff --git a/app-text/xpdf/files/xpdfrc.1 b/app-text/xpdf/files/xpdfrc.1
deleted file mode 100644
index cdab040840ea..000000000000
--- a/app-text/xpdf/files/xpdfrc.1
+++ /dev/null
@@ -1,20 +0,0 @@
-displayFontT1 Times-Roman /usr/share/fonts/default/ghostscript/n021003l.pfb
-displayFontT1 Times-Italic /usr/share/fonts/default/ghostscript/n021023l.pfb
-displayFontT1 Times-Bold /usr/share/fonts/default/ghostscript/n021004l.pfb
-displayFontT1 Times-BoldItalic /usr/share/fonts/default/ghostscript/n021024l.pfb
-displayFontT1 Helvetica /usr/share/fonts/default/ghostscript/n019003l.pfb
-displayFontT1 Helvetica-Oblique /usr/share/fonts/default/ghostscript/n019023l.pfb
-displayFontT1 Helvetica-Bold /usr/share/fonts/default/ghostscript/n019004l.pfb
-displayFontT1 Helvetica-BoldOblique /usr/share/fonts/default/ghostscript/n019024l.pfb
-displayFontT1 Courier /usr/share/fonts/default/ghostscript/n022003l.pfb
-displayFontT1 Courier-Oblique /usr/share/fonts/default/ghostscript/n022023l.pfb
-displayFontT1 Courier-Bold /usr/share/fonts/default/ghostscript/n022004l.pfb
-displayFontT1 Courier-BoldOblique /usr/share/fonts/default/ghostscript/n022024l.pfb
-displayFontT1 Symbol /usr/share/fonts/default/ghostscript/s050000l.pfb
-displayFontT1 ZapfDingbats /usr/share/fonts/default/ghostscript/d050000l.pfb
-
-displayCIDFontTT Adobe-Japan1 "/usr/share/fonts/kochi-substitute/kochi-gothic-subst.ttf"
-displayCIDFontTT Adobe-CNS1 "/usr/share/fonts/arphicfonts/bkai00mp.ttf"
-displayCIDFontTT Adobe-GB1 "/usr/share/fonts/arphicfonts/gkai00mp.ttf"
-displayCIDFontTT Adobe-Korea1 "/usr/share/fonts/baekmuk-fonts/batang.ttf"
-displayCIDFontTT Unidocs-Korea1 "/usr/share/fonts/baekmuk-fonts/batang.ttf"