diff options
7 files changed, 340 insertions, 1 deletions
diff --git a/app-text/ghostscript/ChangeLog b/app-text/ghostscript/ChangeLog index c164b6501012..4a3821858e4f 100644 --- a/app-text/ghostscript/ChangeLog +++ b/app-text/ghostscript/ChangeLog @@ -1,6 +1,16 @@ # ChangeLog for app-text/ghostscript # Copyright 2002 Gentoo Technologies, Inc.; Distributed under the GPL -# $Header: /var/cvsroot/gentoo-x86/app-text/ghostscript/ChangeLog,v 1.5 2002/04/04 06:37:10 spider Exp $ +# $Header: /var/cvsroot/gentoo-x86/app-text/ghostscript/ChangeLog,v 1.6 2002/04/28 18:40:09 jnelson Exp $ + +*ghostscript-6.53-r2 (28 Apr 2002) + 28 Apr 2002; Jon Nelson <jnelson@gentoo.org>: ghostscript-6.53-r2.ebuild + + Remove dependency on downloading zlib and png - use shared versions! + (Can't do that for libjpeg - see ghostscript docs) + Update to gimp-print 4.2.1 + Use shared zlib and libpng + Patch ghostscript with a few additional patches + Closes #2010 *ghostscript-6.53 (04 Apr 2002) 04 Apr 2002 Spider <spider@gentoo.org> diff --git a/app-text/ghostscript/files/digest-ghostscript-6.53-r2 b/app-text/ghostscript/files/digest-ghostscript-6.53-r2 new file mode 100644 index 000000000000..1541c6b91453 --- /dev/null +++ b/app-text/ghostscript/files/digest-ghostscript-6.53-r2 @@ -0,0 +1,4 @@ +MD5 fc61954bddd6252f992b8bc1f4cc8761 ghostscript-6.53.tar.bz2 3899811 +MD5 8250132d6fcc6eb1419f505f06c7690b ghostscript-fonts-std-6.0.tar.gz 1881034 +MD5 62f59f0bf0b4d2843cc9953f3b4f894f gimp-print-4.2.1.tar.gz 4691313 +MD5 dbd5f3b47ed13132f04c685d608a7547 jpegsrc.v6b.tar.gz 613261 diff --git a/app-text/ghostscript/files/ghostscript-6.53-hpdj_margins.patch b/app-text/ghostscript/files/ghostscript-6.53-hpdj_margins.patch new file mode 100644 index 000000000000..81f75b08a258 --- /dev/null +++ b/app-text/ghostscript/files/ghostscript-6.53-hpdj_margins.patch @@ -0,0 +1,16 @@ +diff -ur ghostscript-6.53.orig/src/gdevijs.c ghostscript-6.53/src/gdevijs.c +--- ghostscript-6.53.orig/src/gdevijs.c 2002-04-28 13:10:09.000000000 -0500 ++++ ghostscript-6.53/src/gdevijs.c 2002-04-28 13:10:46.000000000 -0500 +@@ -401,10 +401,10 @@ + + if (code == 0) { + m[0] = printable_left; +- m[1] = printable_top; ++ m[3] = printable_top; + m[2] = ijsdev->MediaSize[0] * (1.0 / 72) - + printable_left - printable_width; +- m[3] = ijsdev->MediaSize[1] * (1.0 / 72) - ++ m[1] = ijsdev->MediaSize[1] * (1.0 / 72) - + printable_top - printable_height; + gx_device_set_margins((gx_device *)ijsdev, m, true); + sprintf (buf, "%gx%g", printable_left, printable_top); diff --git a/app-text/ghostscript/files/ghostscript-6.53-missquotes.patch b/app-text/ghostscript/files/ghostscript-6.53-missquotes.patch new file mode 100644 index 000000000000..9370f85ba998 --- /dev/null +++ b/app-text/ghostscript/files/ghostscript-6.53-missquotes.patch @@ -0,0 +1,90 @@ +diff -Nur gs7.00.orig/lib/dvipdf gs7.00/lib/dvipdf +--- gs7.00.orig/lib/dvipdf Thu Mar 9 09:40:39 2000 ++++ gs7.00/lib/dvipdf Sun Apr 15 23:31:36 2001 +@@ -22,7 +22,7 @@ + exit 1 + fi + +-infile=$1; ++infile="$1"; + + if [ $# -eq 1 ] + then +@@ -33,7 +33,7 @@ + esac + outfile="${base}.pdf" + else +- outfile=$2 ++ outfile="$2" + fi + + # Doing an initial 'save' helps keep fonts from being flushed between pages. +diff -Nur gs7.00.orig/lib/pdf2dsc gs7.00/lib/pdf2dsc +--- gs7.00.orig/lib/pdf2dsc Fri Dec 29 06:03:49 2000 ++++ gs7.00/lib/pdf2dsc Sun Apr 15 23:32:43 2001 +@@ -20,7 +20,7 @@ + + pdffile=$1 + dscfile=$2 +-: ${dscfile:=`echo $pdffile | sed 's,\.[^/.]*,,'`.dsc} ++: ${dscfile:=`echo "$pdffile" | sed 's,\.[^/.]*,,'`.dsc} + + exec gs -q -dNODISPLAY -dSAFER -dDELAYSAFER\ + -sPDFname="$pdffile" -sDSCname="$dscfile" pdf2dsc.ps -c quit +diff -Nur gs7.00.orig/lib/pdf2ps gs7.00/lib/pdf2ps +--- gs7.00.orig/lib/pdf2ps Fri May 19 08:38:25 2000 ++++ gs7.00/lib/pdf2ps Sun Apr 15 23:33:20 2001 +@@ -14,7 +14,7 @@ + + if [ $# -eq 2 ] + then +- outfile=$2 ++ outfile="$2" + elif [ $# -eq 1 ] + then + outfile=`basename "$1" \.pdf`.ps +diff -Nur gs7.00.orig/lib/pfbtopfa gs7.00/lib/pfbtopfa +--- gs7.00.orig/lib/pfbtopfa Wed Apr 12 19:41:41 2000 ++++ gs7.00/lib/pfbtopfa Sun Apr 15 23:33:52 2001 +@@ -4,7 +4,7 @@ + + if [ $# -eq 2 ] + then +- outfile=$2 ++ outfile="$2" + elif [ $# -eq 1 ] + then + outfile=`basename "$1" \.pfb`.pfa +diff -Nur gs7.00.orig/lib/ps2epsi gs7.00/lib/ps2epsi +--- gs7.00.orig/lib/ps2epsi Wed Apr 4 23:05:00 2001 ++++ gs7.00/lib/ps2epsi Sun Apr 15 23:36:15 2001 +@@ -1,7 +1,7 @@ + #!/bin/sh + # $Id: ghostscript-6.53-missquotes.patch,v 1.1 2002/04/28 18:40:09 jnelson Exp $ + +-tmpfile=/tmp/ps2epsi$$ ++tmpfile=`mktemp /tmp/$0.XXXXXX` || exit 1 + + export outfile + +@@ -10,7 +10,7 @@ + exit 1 + fi + +-infile=$1; ++infile="$1"; + + if [ $# -eq 1 ] + then +@@ -22,9 +22,9 @@ + *.epsf) base=`basename "${infile}" .epsf` ;; + *) base=`basename "${infile}"` ;; + esac +- outfile=${base}.epsi ++ outfile="${base}.epsi" + else +- outfile=$2 ++ outfile="$2" + fi + + ls -l "${infile}" | diff --git a/app-text/ghostscript/files/ghostscript-6.53-r2-gimpprint-gentoo.diff b/app-text/ghostscript/files/ghostscript-6.53-r2-gimpprint-gentoo.diff new file mode 100644 index 000000000000..b99f38d13c8b --- /dev/null +++ b/app-text/ghostscript/files/ghostscript-6.53-r2-gimpprint-gentoo.diff @@ -0,0 +1,12 @@ +--- ghostscript-6.53/src/unixlink.mak_orig 2002-03-07 13:40:11.000000000 +0100 ++++ ghostscript-6.53/src/unixlink.mak 2002-03-07 13:40:22.000000000 +0100 +@@ -67,6 +67,9 @@ + $(ECHOGS_XE) -w $(ldt_tr) -n - $(CCLD) $(LDFLAGS) -o $(GS_XE) + $(ECHOGS_XE) -a $(ldt_tr) -n -s $(PSOBJ)gs.$(OBJ) -s + cat $(ld_tr) >>$(ldt_tr) ++ cp $(ldt_tr) $(ldt_tr)_orig ++ sed -e "s#-lXt#-L${BUILD_PREFIX}/ghostscript-6.53-r2/work/gimp-print-4.2.1/src/main/.libs/ -lgimpprint -lXt#g" \ ++ $(ldt_tr)_orig > $(ldt_tr) + $(ECHOGS_XE) -a $(ldt_tr) -s - $(EXTRALIBS) $(STDLIBS) + if [ x$(XLIBDIR) != x ]; then LD_RUN_PATH=$(XLIBDIR); export LD_RUN_PATH; fi; \ + XCFLAGS= XINCLUDE= XLDFLAGS= XLIBDIRS= XLIBS= \ diff --git a/app-text/ghostscript/files/ghostscript-6.53-setuid.patch b/app-text/ghostscript/files/ghostscript-6.53-setuid.patch new file mode 100644 index 000000000000..09afeee093dd --- /dev/null +++ b/app-text/ghostscript/files/ghostscript-6.53-setuid.patch @@ -0,0 +1,82 @@ +--- gs/src/imainarg.c.orig Mon Dec 6 08:11:52 1999 ++++ gs/src/imainarg.c Thu Mar 30 23:01:34 2000 +@@ -48,6 +48,18 @@ + #include "iutil.h" + #include "ivmspace.h" + ++/* Change by Torsten Landschoff <torsten@debian.org>: ++ * We need to store the original rights when run with setuid so we can ++ * regain privileges when opening the vga library for instance. ++ * -- Thu, 30 Mar 2000 22:47:22 +0200 */ ++ ++#include <unistd.h> ++ ++uid_t privileged_uid; ++gid_t privileged_gid; ++ ++/* --- end change --- */ ++ + /* Import operator procedures */ + extern int zflush(P1(i_ctx_t *)); + extern int zflushpage(P1(i_ctx_t *)); +@@ -127,6 +139,20 @@ + arg_list args; + FILE *stdfiles[3]; + int code; ++ ++ /* Change by Torsten Landschoff <torsten@debian.org>: ++ * We want to give up privileges as soon as possible when running suid. ++ * Right, you would not want to run a piece of software as complex as ++ * Ghostscript with setuid but you need to if you want to use the ++ * svgalib as ordinary user. ++ * -- Thu, 30 Mar 2000 22:46:19 +0200 */ ++ ++ /* save privileges */ ++ privileged_uid = geteuid(); privileged_gid = getegid(); ++ /* give up privileges */ ++ seteuid( getuid() ); setegid( getgid() ); ++ ++ /* --- end change --- */ + + gs_get_real_stdio(stdfiles); + arg_init(&args, (const char **)argv, argc, +--- gs/src/gdevl256.c.orig Mon Jan 11 07:38:07 1999 ++++ gs/src/gdevl256.c Thu Mar 30 23:03:57 2000 +@@ -38,6 +38,17 @@ + #include <vga.h> + #include <vgagl.h> + ++/* Change by Torsten Landschoff <torsten@debian.org>: ++ * I changed imainarg.c to drop privileges as soon as possible when ++ * running setuid. We need to get back elevated rights when we want ++ * to open the vga library. Declare the two variables from imainarg.c ++ * holding the privileges and include unistd.h for user management. ++ * -- Thu, 30 Mar 2000 22:59:53 +0200 */ ++ ++#include <unistd.h> ++extern uid_t privileged_uid; ++extern gid_t privileged_gid; ++ + /* The color map for dynamically assignable colors. */ + #define first_dc_index 64 + private int next_dc_index; +@@ -107,7 +118,19 @@ + int vgamode; + int width, height; + ++ /* Change by Torsten Landschoff <torsten@debian.org>: ++ * We need to restore the privileges we gave up in imainarg.c to open ++ * the vga device. ++ * -- Thu, 30 Mar 2000 23:03:12 +0200 */ ++ ++ /* re-obtain privileges */ ++ seteuid( privileged_uid ); setegid( privileged_gid ); + vga_init(); ++ /* give away privileges */ ++ seteuid( getuid() ); setegid( getgid() ); ++ ++ /* --- end change --- */ ++ + vgamode = vga_getdefaultmode(); + if (vgamode == -1) + vgamode = G320x200x256; diff --git a/app-text/ghostscript/ghostscript-6.53-r2.ebuild b/app-text/ghostscript/ghostscript-6.53-r2.ebuild new file mode 100644 index 000000000000..33ece56d9fcd --- /dev/null +++ b/app-text/ghostscript/ghostscript-6.53-r2.ebuild @@ -0,0 +1,125 @@ +# Copyright 1999-2002 Gentoo Technologies, Inc. +# Distributed under the terms of the GNU General Public License, v2 or later +# Maintainer: Achim Gottinger <achim@gentoo.org>, Daniel Robbins <drobbins@gentoo.org>, Geert Bevin <gbevin@gentoo.org> +# $Header: /var/cvsroot/gentoo-x86/app-text/ghostscript/ghostscript-6.53-r2.ebuild,v 1.1 2002/04/28 18:40:09 jnelson Exp $ + +GPV="4.2.1" + +JPEG=jpegsrc.v6b.tar.gz +S=${WORKDIR}/${P} +DESCRIPTION="GNU Ghostscript" +SRC_URI="http://download.sourceforge.net/ghostscript/${P}.tar.bz2 + http://download.sourceforge.net/gs-fonts/ghostscript-fonts-std-6.0.tar.gz + http://download.sourceforge.net/gimp-print/gimp-print-${GPV}.tar.gz + ftp://ftp.uu.net/graphics/jpeg/${JPEG}" + +# NOTES: +# Why aren't we using configure (for ghostscript)? + +# When I run configure (for gimp-print), there are some questions: +# +# Which of the following do we want to say 'yes'? +# checking whether to build CUPS driver... no +# checking whether to build translated CUPS PPD files... yes +# checking whether to use level 3 PostScript... no +# checking whether to build ghostscript driver... no +# checking whether to build foomatic data files... no +# checking whether to build GIMP plugin... no +# +# and no? +# checking whether to build escputil... yes +# checking whether to build libgimpprint... yes + +DEPEND="virtual/glibc + virtual/x11 + sys-libs/zlib + media-libs/libpng + media-libs/jpeg" +RDEPEND="${DEPEND}" + +src_unpack() { + + unpack ${A} + + cd ${S} + patch -p1 < ${FILESDIR}/${P}-gdi-gentoo.diff || die + patch -p1 < ${FILESDIR}/${P}-r2-gimpprint-gentoo.diff || die + cp ${FILESDIR}/gdevgdi.c ${S}/src || die + + # additional patches taken from the PLD SRPM + # fix some shellscripts to wrap their filename arguments in double-quotes + patch -p1 < ${FILESDIR}/${P}-missquotes.patch || die + # when using svga output, save and restore the uid because + # ghostscript needs to be setuid. This make gs only be suid + # only as long as necessary. + patch -p1 < ${FILESDIR}/${P}-setuid.patch || die + + # a patch right from HP to fix some margin issues with deskjets + patch -p1 < ${FILESDIR}/${P}-hpdj_margins.patch || die + + local tmpdir=${JPEG/src.v/-} + tmpdir=${tmpdir/.tar.gz/} + mv ${WORKDIR}/${tmpdir} ${S}/jpeg || die + +# tmpdir=${ZLIB/.tar.bz2/} +# mv ${WORKDIR}/${tmpdir} ${S}/zlib || die + +# tmpdir=${LIBPNG/.tar.bz2/} +# mv ${WORKDIR}/${tmpdir} ${S}/libpng || die + + cd ${WORKDIR}/gimp-print-${GPV} + ./configure --without-gimp --enable-static --disable-shared || die + cd ${WORKDIR}/gimp-print-${GPV}/src/ghost + cp *.c ${S}/src || die + cd ${WORKDIR}/gimp-print-${GPV}/include/gimp-print + mkdir ${S}/src/gimp-print + cp *.h ${S}/src/gimp-print || die + cat contrib.mak.addon >> ${S}/src/contrib.mak + + cd ${S}/src + cp unix-gcc.mak unix-gcc.mak.orig + sed -e "s:^DEVICE_DEVS6=:DEVICE_DEVS6=\$\(DD\)stp\.dev :" \ + -e "s:SHARE_LIBPNG=0:SHARE_LIBPNG=1:" \ + -e "s:SHARE_ZLIB=0:SHARE_ZLIB=1:" \ + -e "s:CFLAGS_STANDARD=-O2:CFLAGS_STANDARD=${CFLAGS}:" \ + -e "s:XLIBDIRS=-L/usr/X11/lib:XLIBDIRS=-L/usr/X11R6/lib:" \ + -e "s:XLIBS=Xt Xext X11:XLIBS=Xt SM ICE Xext X11:" \ + unix-gcc.mak.orig > unix-gcc.mak +} + +src_compile() { + + cd ${WORKDIR}/gimp-print-${GPV} + emake || die + + cd ${S} + ln -sf src/unix-gcc.mak Makefile + emake prefix=/usr || die +} + +src_install() { + + dodir /usr/{bin,share/man/man1} + make prefix=${D}/usr \ + mandir=${D}/usr/share/man \ + install || die + + mv ${D}/usr/bin/gs ${D}/usr/bin/gs-${PV} + dosym /usr/bin/gs-${PV} /usr/bin/gs + + cd ${WORKDIR} + cp -a fonts ${D}/usr/share/ghostscript + cd ${S} + + dodir /usr/share/doc/${PF} + rm -rf ${D}/usr/share/ghostscript/${PV}/doc + dodoc doc/README doc/PUBLIC doc/COPYING* + dohtml doc/* + insinto /usr/share/emacs/site-lisp + doins doc/gsdoc.el + + cd ${WORKDIR}/gimp-print-${GPV} + dobin src/escputil/escputil + docinto stp + dodoc README* COPYING ChangeLog +} |