diff options
author | 2012-03-03 12:29:38 +0000 | |
---|---|---|
committer | 2012-03-03 12:29:38 +0000 | |
commit | 24ecf83ec773e7bd3b24d2649a067d0020de4740 (patch) | |
tree | 75a12131c774d2250029720a835c98322898450c /dev-lang/perl/perl-5.14.2.ebuild | |
parent | Fix HOMEPAGE (diff) | |
download | historical-24ecf83ec773e7bd3b24d2649a067d0020de4740.tar.gz historical-24ecf83ec773e7bd3b24d2649a067d0020de4740.tar.bz2 historical-24ecf83ec773e7bd3b24d2649a067d0020de4740.zip |
Revbump of 5.12.4 for Prefix changes, same changes in 5.14.2, transferred Prefix keywords, bug #395685
Package-Manager: portage-2.2.01.20271-prefix/cvs/Darwin i386
Diffstat (limited to 'dev-lang/perl/perl-5.14.2.ebuild')
-rw-r--r-- | dev-lang/perl/perl-5.14.2.ebuild | 144 |
1 files changed, 95 insertions, 49 deletions
diff --git a/dev-lang/perl/perl-5.14.2.ebuild b/dev-lang/perl/perl-5.14.2.ebuild index 48e94651a06a..a325acb04544 100644 --- a/dev-lang/perl/perl-5.14.2.ebuild +++ b/dev-lang/perl/perl-5.14.2.ebuild @@ -1,6 +1,6 @@ # Copyright 1999-2012 Gentoo Foundation # Distributed under the terms of the GNU General Public License v2 -# $Header: /var/cvsroot/gentoo-x86/dev-lang/perl/perl-5.14.2.ebuild,v 1.3 2012/01/02 22:52:21 zmedico Exp $ +# $Header: /var/cvsroot/gentoo-x86/dev-lang/perl/perl-5.14.2.ebuild,v 1.4 2012/03/03 12:29:38 grobian Exp $ EAPI=4 @@ -28,7 +28,7 @@ HOMEPAGE="http://www.perl.org/" LICENSE="|| ( Artistic GPL-1 GPL-2 GPL-3 )" SLOT="0" -KEYWORDS="~alpha ~amd64 ~arm ~hppa ~ia64 ~m68k ~mips ~ppc ~ppc64 ~s390 ~sh ~sparc ~x86 ~x86-fbsd" +KEYWORDS="~alpha ~amd64 ~arm ~hppa ~ia64 ~m68k ~mips ~ppc ~ppc64 ~s390 ~sh ~sparc ~x86 ~x86-fbsd ~ppc-aix ~x64-freebsd ~x86-freebsd ~hppa-hpux ~ia64-hpux ~x86-interix ~amd64-linux ~ia64-linux ~x86-linux ~ppc-macos ~x64-macos ~x86-macos ~m68k-mint ~sparc-solaris ~sparc64-solaris ~x64-solaris ~x86-solaris" IUSE="berkdb build debug doc gdbm ithreads" COMMON_DEPEND=" @@ -38,7 +38,7 @@ COMMON_DEPEND=" sys-libs/zlib " DEPEND="${COMMON_DEPEND} - elibc_FreeBSD? ( sys-freebsd/freebsd-mk-defs ) + !prefix? ( elibc_FreeBSD? ( sys-freebsd/freebsd-mk-defs ) ) " RDEPEND="${COMMON_DEPEND} " @@ -75,6 +75,7 @@ pkg_setup() { *-netbsd*) osname="netbsd" ;; *-openbsd*) osname="openbsd" ;; *-darwin*) osname="darwin" ;; + *-interix*) osname="interix" ;; *) osname="linux" ;; esac @@ -152,8 +153,27 @@ src_prepare() { # pod/perltoc.pod fails # lib/ExtUtils/t/Embed.t fails - ln -s ${LIBPERL} libperl$(get_libname ${SHORT_PV}) || die - ln -s ${LIBPERL} libperl$(get_libname ) || die + if ! tc-is-static-only ; then + ln -s ${LIBPERL} libperl$(get_libname ${SHORT_PV}) || die + ln -s ${LIBPERL} libperl$(get_libname ) || die + fi + + epatch "${FILESDIR}"/${PN}-5.12.3-aix-soname.patch + epatch "${FILESDIR}"/${PN}-5.8.8-solaris-relocation.patch + epatch "${FILESDIR}"/${PN}-5.8.8-solaris11.patch + epatch "${FILESDIR}"/${PN}-5.14.1-cleanup-paths.patch + epatch "${FILESDIR}"/${PN}-5.8.8-usr-local.patch + epatch "${FILESDIR}"/${PN}-5.10.1-hpux.patch + epatch "${FILESDIR}"/${PN}-5.8.8-darwin-cc-ld.patch + epatch "${FILESDIR}"/${PN}-5.12.3-mint.patch + epatch "${FILESDIR}"/${PN}-5.12.3-interix.patch + + # rest of usr-local patch + sed -i \ + -e '/^locincpth=/c\locincpth=""' \ + -e '/^loclibpth=/c\loclibpth=""' \ + -e '/^glibpth=.*\/local\//s: /usr/local/lib.*":":' \ + Configure || die } myconf() { @@ -182,12 +202,12 @@ src_configure() { # 266337 export BUILD_BZIP2=0 - export BZIP2_INCLUDE=/usr/include - export BZIP2_LIB=/usr/$(get_libdir) + export BZIP2_INCLUDE=${EPREFIX}/usr/include + export BZIP2_LIB=${EPREFIX}/usr/$(get_libdir) cat <<-EOF > "${S}/cpan/Compress-Raw-Zlib/config.in" BUILD_ZLIB = False - INCLUDE = /usr/include - LIB = /usr/$(get_libdir) + INCLUDE = ${EPREFIX}/usr/include + LIB = ${EPREFIX}/usr/$(get_libdir) OLD_ZLIB = False GZIP_OS_CODE = AUTO_DETECT @@ -233,11 +253,32 @@ src_configure() { [[ ${ELIBC} == "FreeBSD" ]] && myconf "-Dlibc=/usr/$(get_libdir)/libc.a" - if [[ $(get_libdir) != "lib" ]] ; then + # Prefix: the host system needs not to follow Gentoo multilib stuff, and in + # Prefix itself we don't do multilib either, so make sure perl can find + # something compatible. + if use prefix ; then + local ldir + local llib + local paths="" + echo "int main() {}" > "${T}"/t.c + # need to ensure dirs contain compatible libs, bug #358875 + for ldir in /lib /usr/lib /lib64 /lib/64 /usr/lib64 /usr/lib/64 /lib32 /usr/lib32 ; do + [[ -d ${ldir} ]] || continue + # find a random lib from here + llib=( ${ldir}/*$(get_libname) ) + [[ -e ${llib[0]} ]] || continue + $(tc-getCC) -o "${T}"/t "${T}"/t.c ${llib[0]} >& /dev/null \ + && paths="${paths} ${ldir}" + done + myconf "-Dlibpth=${EPREFIX}/$(get_libdir) ${EPREFIX}/usr/$(get_libdir) ${paths}" + elif [[ $(get_libdir) != "lib" ]] ; then # We need to use " and not ', as the written config.sh use ' ... myconf "-Dlibpth=/usr/local/$(get_libdir) /$(get_libdir) /usr/$(get_libdir)" fi + # don't try building ODBM, bug #354453 + myconf -Dnoextensions=ODBM_File + sh Configure \ -des \ -Duseshrplib \ @@ -245,26 +286,28 @@ src_configure() { -Dcc="$(tc-getCC)" \ -Doptimize="${CFLAGS}" \ -Dldflags="${LDFLAGS}" \ - -Dprefix='/usr' \ - -Dsiteprefix='/usr' \ - -Dvendorprefix='/usr' \ - -Dscriptdir='/usr/bin' \ - -Dprivlib="${PRIV_LIB}" \ - -Darchlib="${ARCH_LIB}" \ - -Dsitelib="${SITE_LIB}" \ - -Dsitearch="${SITE_ARCH}" \ - -Dvendorlib="${VENDOR_LIB}" \ - -Dvendorarch="${VENDOR_ARCH}" \ - -Dman1dir=/usr/share/man/man1 \ - -Dman3dir=/usr/share/man/man3 \ - -Dsiteman1dir=/usr/share/man/man1 \ - -Dsiteman3dir=/usr/share/man/man3 \ - -Dvendorman1dir=/usr/share/man/man1 \ - -Dvendorman3dir=/usr/share/man/man3 \ + -Dprefix="${EPREFIX}"'/usr' \ + -Dinstallprefix="${EPREFIX}"'/usr' \ + -Dsiteprefix="${EPREFIX}"'/usr' \ + -Dvendorprefix="${EPREFIX}"'/usr' \ + -Dscriptdir="${EPREFIX}"'/usr/bin' \ + -Dprivlib="${EPREFIX}${PRIV_LIB}" \ + -Darchlib="${EPREFIX}${ARCH_LIB}" \ + -Dsitelib="${EPREFIX}${SITE_LIB}" \ + -Dsitearch="${EPREFIX}${SITE_ARCH}" \ + -Dvendorlib="${EPREFIX}${VENDOR_LIB}" \ + -Dvendorarch="${EPREFIX}${VENDOR_ARCH}" \ + -Dman1dir="${EPREFIX}"/usr/share/man/man1 \ + -Dman3dir="${EPREFIX}"/usr/share/man/man3 \ + -Dsiteman1dir="${EPREFIX}"/usr/share/man/man1 \ + -Dsiteman3dir="${EPREFIX}"/usr/share/man/man3 \ + -Dvendorman1dir="${EPREFIX}"/usr/share/man/man1 \ + -Dvendorman3dir="${EPREFIX}"/usr/share/man/man3 \ -Dman1ext='1' \ -Dman3ext='3pm' \ -Dlibperl="${LIBPERL}" \ - -Dlocincpth=' ' \ + -Dlocincpth="${EPREFIX}"'/usr/include ' \ + -Dglibpth="${EPREFIX}/$(get_libdir) ${EPREFIX}/usr/$(get_libdir)"' ' \ -Duselargefiles \ -Dd_semctl_semun \ -Dcf_by='Gentoo' \ @@ -296,18 +339,20 @@ src_install() { fi emake DESTDIR="${D}" ${installtarget} - rm -f "${D}"/usr/bin/perl - ln -s perl${MY_PV} "${D}"/usr/bin/perl || die - - dolib.so "${D}"${coredir}/${LIBPERL} - rm -f "${D}"${coredir}/${LIBPERL} - ln -sf ${LIBPERL} "${D}"/usr/$(get_libdir)/libperl$(get_libname ${SHORT_PV}) || die - ln -sf ${LIBPERL} "${D}"/usr/$(get_libdir)/libperl$(get_libname) || die - ln -sf ../../../../../$(get_libdir)/${LIBPERL} "${D}"${coredir}/${LIBPERL} || die - ln -sf ../../../../../$(get_libdir)/${LIBPERL} "${D}"${coredir}/libperl$(get_libname ${SHORT_PV}) || die - ln -sf ../../../../../$(get_libdir)/${LIBPERL} "${D}"${coredir}/libperl$(get_libname) || die + rm -f "${ED}"/usr/bin/perl + ln -s perl${MY_PV} "${ED}"/usr/bin/perl || die + + if ! tc-is-static-only ; then + dolib.so "${ED}"${coredir}/${LIBPERL} + rm -f "${ED}"${coredir}/${LIBPERL} + ln -sf ${LIBPERL} "${ED}"/usr/$(get_libdir)/libperl$(get_libname ${SHORT_PV}) || die + ln -sf ${LIBPERL} "${ED}"/usr/$(get_libdir)/libperl$(get_libname) || die + ln -sf ../../../../../$(get_libdir)/${LIBPERL} "${ED}"${coredir}/${LIBPERL} || die + ln -sf ../../../../../$(get_libdir)/${LIBPERL} "${ED}"${coredir}/libperl$(get_libname ${SHORT_PV}) || die + ln -sf ../../../../../$(get_libdir)/${LIBPERL} "${ED}"${coredir}/libperl$(get_libname) || die + fi - rm -rf "${D}"/usr/share/man/man3 || die "Unable to remove module man pages" + rm -rf "${ED}"/usr/share/man/man3 || die "Unable to remove module man pages" # # A poor fix for the miniperl issues # dosed 's:./miniperl:/usr/bin/perl:' /usr/$(get_libdir)/perl5/${MY_PV}/ExtUtils/xsubpp @@ -321,11 +366,11 @@ src_install() { sed -i -e "s:${D}::" "${i}" || die "Sed failed" done - find "${D}" -type f -name .packlist -delete || die + find "${ED}" -type f -name .packlist -delete || die # Note: find out from psm why we would need/want this. # ( use berkdb && has_version '=sys-libs/db-1*' ) || - # find "${D}" -name "*NDBM*" | xargs rm -f + # find "${ED}" -name "*NDBM*" | xargs rm -f dodoc Changes* README AUTHORS @@ -338,7 +383,7 @@ src_install() { --podroot='.' \ --podpath='lib:ext:pod:vms' \ --recurse \ - --htmldir="${D}/usr/share/doc/${PF}/html" \ + --htmldir="${ED}/usr/share/doc/${PF}/html" \ --libpods='perlfunc:perlguts:perlvar:perlrun:perlop' fi @@ -376,8 +421,9 @@ pkg_postinst() { # fi einfo "Converting C header files to the corresponding Perl format (ignore any error)" + # Prefix note: unprefixed as this is all kernel/libc stuff that we never provide pushd /usr/include >/dev/null - h2ph -Q -a -d ${ARCH_LIB} \ + h2ph -Q -a -d "${EPREFIX}"${ARCH_LIB} \ asm/termios.h syscall.h syslimits.h syslog.h sys/ioctl.h \ sys/socket.h sys/time.h wait.h sysexits.h popd >/dev/null @@ -435,7 +481,7 @@ src_remove_dual_file() { ;; setup) for i in "$@" ; do - if [[ -f ${ROOT}${i} && ! -h ${ROOT}${i} ]] ; then + if [[ -f ${EROOT}${i} && ! -h ${EROOT}${i} ]] ; then has_version ${pkg} && ewarn "You must reinstall ${pkg} !" break fi @@ -443,11 +489,11 @@ src_remove_dual_file() { ;; install) for i in "$@" ; do - if ! [[ -f "${D}"${i} ]] ; then + if ! [[ -f "${ED}"${i} ]] ; then use build || ewarn "${i} does not exist!" continue fi - mv "${D}"${i}{,-${ver}-${P}} || die + mv "${ED}"${i}{,-${ver}-${P}} || die done ;; esac @@ -461,18 +507,18 @@ src_remove_dual_man() { case "${EBUILD_PHASE:-none}" in postinst|postrm) for i in "$@" ; do - ff=`echo "${ROOT}${i%.[0-9]}-${ver}-${P}${i#${i%.[0-9]}}"*` + ff=`echo "${EROOT}${i%.[0-9]}-${ver}-${P}${i#${i%.[0-9]}}"*` ff=${ff##*${i#${i%.[0-9]}}} alternatives_auto_makesym "${i}${ff}" "${i%.[0-9]}-[0-9]*" done ;; install) for i in "$@" ; do - if ! [[ -f "${D}"${i} ]] ; then + if ! [[ -f "${ED}"${i} ]] ; then use build || ewarn "${i} does not exist!" continue fi - mv "${D}"${i} "${D}"${i%.[0-9]}-${ver}-${P}${i#${i%.[0-9]}} || die + mv "${ED}"${i} "${ED}"${i%.[0-9]}-${ver}-${P}${i#${i%.[0-9]}} || die done ;; esac @@ -653,7 +699,7 @@ src_remove_extra_files() { .${ARCH_LIB}/threads.pm " - pushd "${D}" > /dev/null + pushd "${ED}" > /dev/null # Remove cruft einfo "Removing files that are not in the minimal install" echo "${MINIMAL_PERL_INSTALL}" |