diff options
author | Torsten Veller <tove@gentoo.org> | 2009-09-27 07:00:32 +0000 |
---|---|---|
committer | Torsten Veller <tove@gentoo.org> | 2009-09-27 07:00:32 +0000 |
commit | 91d7b594bd49f51ab79b612d441177b593a7c373 (patch) | |
tree | 38521b8c0536883963287308f12e01d218215a57 /eclass/perl-module.eclass | |
parent | restore threads to IUSE #286560 by David Hallas (diff) | |
download | historical-91d7b594bd49f51ab79b612d441177b593a7c373.tar.gz historical-91d7b594bd49f51ab79b612d441177b593a7c373.tar.bz2 historical-91d7b594bd49f51ab79b612d441177b593a7c373.zip |
Uses alternatives.eclass for dual life scripts, SRC_TEST=parallel for parallel testing and TEST_VERBOSE=1 to show details of test execution
Diffstat (limited to 'eclass/perl-module.eclass')
-rw-r--r-- | eclass/perl-module.eclass | 105 |
1 files changed, 83 insertions, 22 deletions
diff --git a/eclass/perl-module.eclass b/eclass/perl-module.eclass index 98849d80829d..91615dc84a91 100644 --- a/eclass/perl-module.eclass +++ b/eclass/perl-module.eclass @@ -1,6 +1,6 @@ -# Copyright 1999-2004 Gentoo Foundation +# Copyright 1999-2009 Gentoo Foundation # Distributed under the terms of the GNU General Public License v2 -# $Header: /var/cvsroot/gentoo-x86/eclass/perl-module.eclass,v 1.116 2009/03/29 17:32:31 tove Exp $ +# $Header: /var/cvsroot/gentoo-x86/eclass/perl-module.eclass,v 1.117 2009/09/27 07:00:32 tove Exp $ # # Author: Seemant Kulleen <seemant@gentoo.org> @@ -13,13 +13,18 @@ # modules, and their incorporation into the Gentoo Linux system. inherit eutils base +[[ ${CATEGORY} == "perl-core" ]] && inherit alternatives + +PERL_EXPF="src_unpack src_compile src_test src_install" case "${EAPI:-0}" in 0|1) - EXPORT_FUNCTIONS pkg_setup pkg_preinst pkg_postinst pkg_prerm pkg_postrm src_compile src_install src_test src_unpack + PERL_EXPF="${PERL_EXPF} pkg_setup pkg_preinst pkg_postinst pkg_prerm pkg_postrm" ;; 2) - EXPORT_FUNCTIONS src_unpack src_prepare src_configure src_compile src_test src_install + PERL_EXPF="${PERL_EXPF} src_prepare src_configure" + [[ ${CATEGORY} == "perl-core" ]] && \ + PERL_EXPF="${PERL_EXPF} pkg_postinst pkg_postrm" case "${GENTOO_DEPEND_ON_PERL:-yes}" in yes) @@ -30,6 +35,8 @@ case "${EAPI:-0}" in ;; esac +EXPORT_FUNCTIONS ${PERL_EXPF} + DESCRIPTION="Based on the $ECLASS eclass" LICENSE="${LICENSE:-|| ( Artistic GPL-2 )}" @@ -56,7 +63,7 @@ perlinfo_done=false perl-module_src_unpack() { base_src_unpack unpack - has "${EAPI:-0}" 0 1 && perl-module_src_prepare + has src_prepare ${PERL_EXPF} || perl-module_src_prepare } perl-module_src_prepare() { @@ -71,7 +78,7 @@ perl-module_src_configure() { } perl-module_src_prep() { - [[ "${SRC_PREP}" = "yes" ]] && return 0 + [[ ${SRC_PREP} = yes ]] && return 0 SRC_PREP="yes" ${perlinfo_done} || perlinfo @@ -80,7 +87,7 @@ perl-module_src_prep() { # Disable ExtUtils::AutoInstall from prompting export PERL_EXTUTILS_AUTOINSTALL="--skipdeps" - if [[ "${PREFER_BUILDPL}" == "yes" && -f Build.PL ]] ; then + if [[ ${PREFER_BUILDPL} == yes && -f Build.PL ]] ; then einfo "Using Module::Build" perl Build.PL \ --installdirs=vendor \ @@ -110,7 +117,7 @@ perl-module_src_prep() { perl-module_src_compile() { ${perlinfo_done} || perlinfo - has "${EAPI:-0}" 0 1 && perl-module_src_prep + has src_configure ${PERL_EXPF} || perl-module_src_prep if [[ -f Build ]] ; then ./Build build \ @@ -124,13 +131,38 @@ perl-module_src_compile() { fi } +# For testers: +# This code attempts to work out your threadingness from MAKEOPTS +# and apply them to Test::Harness. +# +# If you want more verbose testing, set TEST_VERBOSE=1 +# in your bashrc | /etc/make.conf | ENV +# +# For ebuild writers: +# If you wish to enable default tests w/ 'make test' , +# +# SRC_TEST="do" +# +# If you wish to have threads run in parallel ( using the users makeopts ) +# all of the following have been tested to work. +# +# SRC_TEST="do parallel" +# SRC_TEST="parallel" +# SRC_TEST="parallel do" +# SRC_TEST=parallel +# + perl-module_src_test() { - if [[ "${SRC_TEST}" == "do" ]] ; then + if has 'do' ${SRC_TEST} || has 'parallel' ${SRC_TEST} ; then + if has "${TEST_VERBOSE:-0}" 0 && has 'parallel' ${SRC_TEST} ; then + export HARNESS_OPTIONS=j$(echo -j1 ${MAKEOPTS} | sed -r "s/.*(-j\s*|--jobs=)([0-9]+).*/\2/" ) + einfo "Test::Harness Jobs=${HARNESS_OPTIONS}" + fi ${perlinfo_done} || perlinfo if [[ -f Build ]] ; then - ./Build test || die "test failed" + ./Build test verbose=${TEST_VERBOSE:-0} || die "test failed" elif [[ -f Makefile ]] ; then - emake test || die "test failed" + emake test TEST_VERBOSE=${TEST_VERBOSE:-0} || die "test failed" fi fi } @@ -162,11 +194,11 @@ perl-module_src_install() { fixlocalpod - for f in Change* CHANGES README* ${mydoc}; do - [[ -s "${f}" ]] && dodoc ${f} + for f in Change* CHANGES README* TODO ${mydoc}; do + [[ -s ${f} ]] && dodoc ${f} done - if [[ -d "${D}/${VENDOR_LIB}" ]] ; then + if [[ -d ${D}/${VENDOR_LIB} ]] ; then find "${D}/${VENDOR_LIB}" -type f -a \( -name .packlist \ -o \( -name '*.bs' -a -empty \) \) -delete find "${D}/${VENDOR_LIB}" -depth -mindepth 1 -type d -empty -delete @@ -174,10 +206,12 @@ perl-module_src_install() { find "${D}" -type f -not -name '*.so' -print0 | while read -rd '' f ; do if file "${f}" | grep -q -i " text" ; then -if grep -q "${D}" "${f}" ; then ewarn "QA: File contains a temporary path ${f}" ;fi + grep -q "${D}" "${f}" && ewarn "QA: File contains a temporary path ${f}" sed -i -e "s:${D}:/:g" "${f}" fi done + + linkduallifescripts } perl-module_pkg_setup() { @@ -188,20 +222,21 @@ perl-module_pkg_preinst() { ${perlinfo_done} || perlinfo } -perl-module_pkg_postinst() { : ; } -# einfo "Man pages are not installed for most modules now." -# einfo "Please use perldoc instead." -#} +perl-module_pkg_postinst() { + linkduallifescripts +} perl-module_pkg_prerm() { : ; } -perl-module_pkg_postrm() { : ; } +perl-module_pkg_postrm() { + linkduallifescripts +} perlinfo() { perlinfo_done=true - local f version install{site{arch,lib},archlib,vendor{arch,lib}} - for f in version install{site{arch,lib},archlib,vendor{arch,lib}} ; do + local f version install{{site,vendor}{arch,lib},archlib} + for f in version install{{site,vendor}{arch,lib},archlib} ; do eval "$(perl -V:${f} )" done PERL_VERSION=${version} @@ -216,3 +251,29 @@ fixlocalpod() { find "${D}" -type f -name perllocal.pod -delete find "${D}" -depth -mindepth 1 -type d -empty -delete } + +linkduallifescripts() { + if [[ ${CATEGORY} != perl-core ]] || ! has_version ">=dev-lang/perl-5.10.1" ; then + return 0 + fi + + local i ff + if has "${EBUILD_PHASE:-none}" "postinst" "postrm" ; then + for i in "${DUALLIFESCRIPTS[@]}" ; do + alternatives_auto_makesym "/usr/bin/${i}" "/usr/bin/${i}-[0-9]*" + ff=`echo "${ROOT}"/usr/share/man/man1/${i}-${PV}-${P}.1*` + ff=${ff##*.1} + alternatives_auto_makesym "/usr/share/man/man1/${i}.1${ff}" "/usr/share/man/man1/${i}-[0-9]*" + done + else + pushd "${D}" > /dev/null + for i in $(find usr/bin -maxdepth 1 -type f 2>/dev/null) ; do + mv ${i}{,-${PV}-${P}} || die + DUALLIFESCRIPTS[${#DUALLIFESCRIPTS[*]}]=${i##*/} + if [[ -f usr/share/man/man1/${i##*/}.1 ]] ; then + mv usr/share/man/man1/${i##*/}{.1,-${PV}-${P}.1} || die + fi + done + popd > /dev/null + fi +} |