diff options
author | Mike Frysinger <vapier@gentoo.org> | 2005-10-11 00:43:05 +0000 |
---|---|---|
committer | Mike Frysinger <vapier@gentoo.org> | 2005-10-11 00:43:05 +0000 |
commit | 6685a7e54626575ed6a758d1e54652c682b667af (patch) | |
tree | 5d1c87b189c7357d91ba4010ed7a3bb31b704235 /media-libs/libpng | |
parent | Remove old versions. (diff) | |
download | historical-6685a7e54626575ed6a758d1e54652c682b667af.tar.gz historical-6685a7e54626575ed6a758d1e54652c682b667af.tar.bz2 historical-6685a7e54626575ed6a758d1e54652c682b667af.zip |
Clean up build system for cross-compile sake.
Package-Manager: portage-2.0.53_rc4
Diffstat (limited to 'media-libs/libpng')
-rw-r--r-- | media-libs/libpng/ChangeLog | 9 | ||||
-rw-r--r-- | media-libs/libpng/Manifest | 22 | ||||
-rw-r--r-- | media-libs/libpng/files/digest-libpng-1.2.8-r1 | 2 | ||||
-rw-r--r-- | media-libs/libpng/files/libpng-1.2.8-build.patch | 74 | ||||
-rw-r--r-- | media-libs/libpng/files/libpng-1.2.8-strnlen.patch | 21 | ||||
-rw-r--r-- | media-libs/libpng/libpng-1.2.8-r1.ebuild | 60 |
6 files changed, 183 insertions, 5 deletions
diff --git a/media-libs/libpng/ChangeLog b/media-libs/libpng/ChangeLog index 50b6d0191ad8..391828d7b583 100644 --- a/media-libs/libpng/ChangeLog +++ b/media-libs/libpng/ChangeLog @@ -1,6 +1,13 @@ # ChangeLog for media-libs/libpng # Copyright 1999-2005 Gentoo Foundation; Distributed under the GPL v2 -# $Header: /var/cvsroot/gentoo-x86/media-libs/libpng/ChangeLog,v 1.68 2005/05/27 21:57:50 vapier Exp $ +# $Header: /var/cvsroot/gentoo-x86/media-libs/libpng/ChangeLog,v 1.69 2005/10/11 00:43:05 vapier Exp $ + +*libpng-1.2.8-r1 (11 Oct 2005) + + 11 Oct 2005; Mike Frysinger <vapier@gentoo.org> + +files/libpng-1.2.8-build.patch, +files/libpng-1.2.8-strnlen.patch, + +libpng-1.2.8-r1.ebuild: + Clean up build system for cross-compile sake. 27 May 2005; Mike Frysinger <vapier@gentoo.org> libpng-1.2.8.ebuild: Add support for USE=doc to pull in the manual #94029 by Laurence Withers. diff --git a/media-libs/libpng/Manifest b/media-libs/libpng/Manifest index 73c79c31e6c1..adbf18048c2c 100644 --- a/media-libs/libpng/Manifest +++ b/media-libs/libpng/Manifest @@ -1,6 +1,20 @@ -MD5 a6553f135165f9b702985e52f58ed3c1 ChangeLog 10869 -MD5 9a09f8d531c582e78977dbfd96edc1f2 metadata.xml 164 -MD5 67b7ae796734a04480c98efbb6ee7c06 libpng-1.2.8.ebuild 1813 +-----BEGIN PGP SIGNED MESSAGE----- +Hash: SHA1 + +MD5 3dc3e31fcdf329242bc180444a57f30b ChangeLog 11097 +MD5 3338fff0166374e14ae138e6a1f4cd21 files/1.2.7-gentoo.diff 464 MD5 cfc3cad1942561090fafce6a25a23bf0 files/digest-libpng-1.2.8 127 +MD5 cfc3cad1942561090fafce6a25a23bf0 files/digest-libpng-1.2.8-r1 127 +MD5 f13493ee891ede4548a44ad32d56552f files/libpng-1.2.8-build.patch 1857 +MD5 029ec280f20678b76004c1a0a0270111 files/libpng-1.2.8-strnlen.patch 580 MD5 7443cfcd027ad293e56ec7bed76ee21c files/macos.patch 589 -MD5 3338fff0166374e14ae138e6a1f4cd21 files/1.2.7-gentoo.diff 464 +MD5 0897ccaeb4909330e541daf8e1da5938 libpng-1.2.8-r1.ebuild 1691 +MD5 67b7ae796734a04480c98efbb6ee7c06 libpng-1.2.8.ebuild 1813 +MD5 9a09f8d531c582e78977dbfd96edc1f2 metadata.xml 164 +-----BEGIN PGP SIGNATURE----- +Version: GnuPG v1.4.2 (GNU/Linux) + +iD8DBQFDSwsMgIKl8Uu19MoRAiTMAJ4zHMjNLzYyQSJhZ0Ae8NMwb2Q84gCfWWaG +F39Qy55pKonW2ZRrG7fsJlU= +=feRS +-----END PGP SIGNATURE----- diff --git a/media-libs/libpng/files/digest-libpng-1.2.8-r1 b/media-libs/libpng/files/digest-libpng-1.2.8-r1 new file mode 100644 index 000000000000..af445994947a --- /dev/null +++ b/media-libs/libpng/files/digest-libpng-1.2.8-r1 @@ -0,0 +1,2 @@ +MD5 00cea4539bea4bd34cbf8b82ff9589cd libpng-1.2.8.tar.bz2 384970 +MD5 3c9069aa836541dc0e075187dcb21899 libpng-manual.txt 127770 diff --git a/media-libs/libpng/files/libpng-1.2.8-build.patch b/media-libs/libpng/files/libpng-1.2.8-build.patch new file mode 100644 index 000000000000..77d186d2057d --- /dev/null +++ b/media-libs/libpng/files/libpng-1.2.8-build.patch @@ -0,0 +1,74 @@ +Clean up build system to make cross-compiling easy + +--- scripts/makefile.linux ++++ scripts/makefile.linux +@@ -8,12 +8,12 @@ + PNGMIN = 1.2.8 + PNGVER = $(PNGMAJ).$(PNGMIN) + +-CC=gcc ++CC?=gcc + + # where "make install" puts libpng12.a, libpng12.so*, + # libpng12/png.h and libpng12/pngconf.h + # Prefix must be a full pathname. +-prefix=/usr/local ++prefix=/usr + + # Where the zlib library and include files are located. + #ZLIBLIB=/usr/local/lib +@@ -31,18 +31,25 @@ + + # for pgcc version 2.95.1, -O3 is buggy; don't use it. + +-CFLAGS=-I$(ZLIBINC) -Wall -O3 -funroll-loops \ +- $(ALIGN) # $(WARNMORE) -g -DPNG_DEBUG=5 ++CFLAGS += -Wall $(ALIGN) ++ifneq ($(ZLIBINC),) ++CFLAGS += -I$(ZLIBINC) ++endif ++ ++ifneq ($(ZLIBLIB),) ++LDFLAGS += -L$(ZLIBLIB) -Wl,-rpath,$(ZLIBLIB) ++endif ++LDFLAGS += -lz -lm ++LDFLAGS_A = $(LDFLAGS) libpng.a ++LDFLAGS_SO = $(LDFLAGS) -L. -Wl,-rpath,. -lpng12 + +-LDFLAGS=-L. -Wl,-rpath,. -L$(ZLIBLIB) -Wl,-rpath,$(ZLIBLIB) -lpng12 -lz -lm +-LDFLAGS_A=-L$(ZLIBLIB) -Wl,-rpath,$(ZLIBLIB) libpng.a -lz -lm +- +-RANLIB=ranlib ++AR?=ar ++RANLIB?=ranlib + #RANLIB=echo + + INCPATH=$(prefix)/include + LIBPATH=$(prefix)/lib +-MANPATH=$(prefix)/man ++MANPATH=$(prefix)/share/man + BINPATH=$(prefix)/bin + + # override DESTDIR= on the make install command line to easily support +@@ -74,7 +81,7 @@ + all: libpng.a $(LIBNAME).so pngtest pngtest-static libpng.pc libpng-config + + libpng.a: $(OBJS) +- ar rc $@ $(OBJS) ++ $(AR) rc $@ $(OBJS) + $(RANLIB) $@ + + libpng.pc: +@@ -104,10 +111,10 @@ + libpng.so.3.$(PNGMIN): $(OBJSDLL) + $(CC) -shared -Wl,-soname,libpng.so.3 \ + -o libpng.so.3.$(PNGMIN) \ +- $(OBJSDLL) ++ $(OBJSDLL) $(LDFLAGS) + + pngtest: pngtest.o $(LIBNAME).so +- $(CC) -o pngtest $(CFLAGS) pngtest.o $(LDFLAGS) ++ $(CC) -o pngtest $(CFLAGS) pngtest.o $(LDFLAGS_SO) + + pngtest-static: pngtest.o libpng.a + $(CC) -o pngtest-static $(CFLAGS) pngtest.o $(LDFLAGS_A) diff --git a/media-libs/libpng/files/libpng-1.2.8-strnlen.patch b/media-libs/libpng/files/libpng-1.2.8-strnlen.patch new file mode 100644 index 000000000000..aed2610539cc --- /dev/null +++ b/media-libs/libpng/files/libpng-1.2.8-strnlen.patch @@ -0,0 +1,21 @@ +strnlen is a GNU extension + +--- libpng/pngerror.c ++++ libpng/pngerror.c +@@ -23,6 +23,16 @@ + png_default_warning PNGARG((png_structp png_ptr, + png_const_charp warning_message)); + ++#ifndef _GNU_SOURCE ++size_t strnlen(const char *s, size_t limit) ++{ ++ size_t len = 0; ++ while ((len < limit) && (*s++)) ++ len++; ++ return len; ++} ++#endif ++ + /* This function is called whenever there is a fatal error. This function + * should not be changed. If there is a need to handle errors differently, + * you should supply a replacement error function and use png_set_error_fn() diff --git a/media-libs/libpng/libpng-1.2.8-r1.ebuild b/media-libs/libpng/libpng-1.2.8-r1.ebuild new file mode 100644 index 000000000000..07660c681935 --- /dev/null +++ b/media-libs/libpng/libpng-1.2.8-r1.ebuild @@ -0,0 +1,60 @@ +# Copyright 1999-2005 Gentoo Foundation +# Distributed under the terms of the GNU General Public License v2 +# $Header: /var/cvsroot/gentoo-x86/media-libs/libpng/libpng-1.2.8-r1.ebuild,v 1.1 2005/10/11 00:43:05 vapier Exp $ + +inherit flag-o-matic eutils toolchain-funcs + +DESCRIPTION="Portable Network Graphics library" +HOMEPAGE="http://www.libpng.org/" +SRC_URI="mirror://sourceforge/libpng/${P}.tar.bz2 + doc? ( http://www.libpng.org/pub/png/libpng-manual.txt )" + +LICENSE="as-is" +SLOT="1.2" +KEYWORDS="~alpha ~amd64 ~arm ~hppa ~ia64 ~mips ~ppc ~ppc-macos ~ppc64 ~s390 ~sh ~sparc ~x86" +IUSE="doc" + +DEPEND="sys-libs/zlib" + +src_unpack() { + unpack ${P}.tar.bz2 + cd "${S}" + use doc && cp "${DISTDIR}"/libpng-manual.txt . + + epatch "${FILESDIR}"/1.2.7-gentoo.diff + epatch "${FILESDIR}"/${PN}-1.2.8-strnlen.patch + epatch "${FILESDIR}"/${PN}-1.2.8-build.patch + + [[ $(gcc-version) == "3.3" || $(gcc-version) == "3.2" ]] \ + && replace-cpu-flags k6 k6-2 k6-3 i586 + + local makefilein + case ${CHOST} in + *-darwin*) makefilein="scripts/makefile.darwin";; + *) makefilein="scripts/makefile.linux";; + esac + sed \ + -e "/^ZLIBLIB=/s:=.*:=:" \ + -e "/^ZLIBINC=/s:=.*:=:" \ + -e "/^LIBPATH=/s:/lib:/$(get_libdir):" \ + -e 's:mkdir:mkdir -p:' \ + ${makefilein} > Makefile || die +} + +src_compile() { + tc-export CC RANLIB AR + emake || die "emake failed" +} + +src_install() { + make DESTDIR="${D}" install || die + dodoc ANNOUNCE CHANGES KNOWNBUG README TODO Y2KINFO + use doc && dodoc libpng-manual.txt +} + +pkg_postinst() { + # the libpng authors really screwed around between 1.2.1 and 1.2.3 + if [[ -f ${ROOT}/usr/$(get_libdir)/libpng.so.3.1.2.1 ]] ; then + rm -f "${ROOT}"/usr/$(get_libdir)/libpng.so.3.1.2.1 + fi +} |