/[gentoo-x86]/eclass/perl-module.eclass
Gentoo

Diff of /eclass/perl-module.eclass

Parent Directory Parent Directory | Revision Log Revision Log | View Patch Patch

Revision 1.66 Revision 1.67
1# Copyright 1999-2004 Gentoo Foundation 1# Copyright 1999-2004 Gentoo Foundation
2# Distributed under the terms of the GNU General Public License v2 2# Distributed under the terms of the GNU General Public License v2
3# $Header: /var/cvsroot/gentoo-x86/eclass/perl-module.eclass,v 1.66 2005/03/14 15:09:14 mcummings Exp $ 3# $Header: /var/cvsroot/gentoo-x86/eclass/perl-module.eclass,v 1.67 2005/03/14 18:28:04 mcummings Exp $
4# 4#
5# Author: Seemant Kulleen <seemant@gentoo.org> 5# Author: Seemant Kulleen <seemant@gentoo.org>
6# Maintained by the Perl herd <perl@gentoo.org> 6# Maintained by the Perl herd <perl@gentoo.org>
7# 7#
8# The perl-module eclass is designed to allow easier installation of perl 8# The perl-module eclass is designed to allow easier installation of perl
35# Updated eclass to include a specific function for dealing with perlocal.pods - 35# Updated eclass to include a specific function for dealing with perlocal.pods -
36# this should avoid the conflicts we've been running into with the introduction 36# this should avoid the conflicts we've been running into with the introduction
37# of file collision features by giving us a single exportable function to deal 37# of file collision features by giving us a single exportable function to deal
38# with the pods. Modifications to the eclass provided by Yaakov S 38# with the pods. Modifications to the eclass provided by Yaakov S
39# <yselkowitz@hotmail.com> in bug 83622 39# <yselkowitz@hotmail.com> in bug 83622
40#
41# <later the same day>
42# The long awaited (by me) fix for automagically detecting and dealing
43# with module-build dependancies. I've chosen not to make it a default dep since
44# this adds overhead to people that might not otherwise need it, and instead
45# modified the eclass to detect the existence of a Build.PL and behave
46# accordingly. This will fix issues with g-cpan builds that needs module-build
47# support, as well as get rid of the (annoying) style=builder vars. I know of
48# only one module that needed to be hacked for this, Class-MethodMaker-2.05, but
49# that module has a bad Build.PL to begin with. Ebuilds should continue to
50# DEPEND on module-build<-version> as needed, but there should be no need for
51# the style directive any more (especially since it isn't in the eclass
52# anymore). Enjoy!
53
40 54
41 55
42DEPEND=">=dev-lang/perl-5.8.2 !<dev-perl/ExtUtils-MakeMaker-6.17" 56DEPEND=">=dev-lang/perl-5.8.2 !<dev-perl/ExtUtils-MakeMaker-6.17"
43SRC_PREP="no" 57SRC_PREP="no"
44SRC_TEST="skip" 58SRC_TEST="skip"
48SITE_LIB="" 62SITE_LIB=""
49VENDOR_LIB="" 63VENDOR_LIB=""
50VENDOR_ARCH="" 64VENDOR_ARCH=""
51ARCH_LIB="" 65ARCH_LIB=""
52POD_DIR="" 66POD_DIR=""
67BUILDER_VER=""
53 68
54perl-module_src_prep() { 69perl-module_src_prep() {
55 70
56 perlinfo 71 perlinfo
57 72
58 export PERL_MM_USE_DEFAULT=1 73 export PERL_MM_USE_DEFAULT=1
59 74
75
60 SRC_PREP="yes" 76 SRC_PREP="yes"
61 if [ "${style}" == "builder" ]; then 77 if [ -f ${S}/Build.PL ]; then
78 if [ -z ${BUILDER_VER} ]; then
79 eerror
80 eerror "Please post a bug on http://bugs.gentoo.org assigned to"
81 eerror "perl@gentoo.org - ${P} was added without a dependancy"
82 eerror "on dev-perl/module-build"
83 eerror "${BUILDER_VER}"
84 eerror
85 die
86 else
62 perl ${S}/Build.PL installdirs=vendor destdir=${D} 87 perl ${S}/Build.PL installdirs=vendor destdir=${D}
88 fi
63 else 89 else
64 perl Makefile.PL ${myconf} \ 90 perl Makefile.PL ${myconf} \
65 PREFIX=/usr INSTALLDIRS=vendor DESTDIR=${D} 91 PREFIX=/usr INSTALLDIRS=vendor DESTDIR=${D}
66 fi 92 fi
67} 93}
68 94
69perl-module_src_compile() { 95perl-module_src_compile() {
70 96
97 perlinfo
71 [ "${SRC_PREP}" != "yes" ] && perl-module_src_prep 98 [ "${SRC_PREP}" != "yes" ] && perl-module_src_prep
72 if [ "${style}" != "builder" ]; then 99 if [ -z ${BUILDER_VER} ]; then
73 make ${mymake} || die "compilation failed" 100 make ${mymake} || die "compilation failed"
74 fi 101 fi
75 102
76 if [ "${SRC_TEST}" == "do" ]; then 103 if [ "${SRC_TEST}" == "do" ]; then
77 perl-module_src_test || die "test failed" 104 perl-module_src_test || die "test failed"
78 SRC_TEST="done" 105 SRC_TEST="done"
79 fi 106 fi
80} 107}
81 108
82perl-module_src_test() { 109perl-module_src_test() {
83 if [ "${style}" == "builder" ]; then 110 perlinfo
111 if [ -z ${BUILDER_VER} ]; then
112 make test
113 else
84 perl ${S}/Build test 114 perl ${S}/Build test
85 else
86 make test
87 fi 115 fi
88} 116}
89 117
90perl-module_src_install() { 118perl-module_src_install() {
91 119
92 perlinfo 120 perlinfo
93 121
94 test -z ${mytargets} && mytargets="install" 122 test -z ${mytargets} && mytargets="install"
95 123
96 if [ "${style}" == "builder" ]; then 124 if [ -z ${BUILDER_VER} ]; then
125 make ${myinst} ${mytargets} || die
126 else
97 perl ${S}/Build install 127 perl ${S}/Build install
98 else
99 make ${myinst} ${mytargets} || die
100 fi 128 fi
101 129
102 fixlocalpod 130 fixlocalpod
103 131
104 for FILE in `find ${D} -type f |grep -v '.so'`; do 132 for FILE in `find ${D} -type f |grep -v '.so'`; do
159 VENDOR_LIB=${installvendorlib} 187 VENDOR_LIB=${installvendorlib}
160 188
161 eval `perl '-V:installvendorarch'` 189 eval `perl '-V:installvendorarch'`
162 VENDOR_ARCH=${installvendorarch} 190 VENDOR_ARCH=${installvendorarch}
163 191
192 if [ -f ${S}/Build.PL ]; then
193 if [ ${PN} == "module-build" ]; then
194 BUILDER_VER="1" # A bootstrapping if you will
195 else
196 BUILDER_VER=`perl -MModule::Build -e 'print "$Module::Build::VERSION;"' `
197 fi
198 fi
199
164 if [ -f /usr/bin/perl ] 200 if [ -f /usr/bin/perl ]
165 then 201 then
166 POD_DIR="/usr/share/perl/gentoo-pods/${version}" 202 POD_DIR="/usr/share/perl/gentoo-pods/${version}"
167 fi 203 fi
168} 204}

Legend:
Removed from v.1.66  
changed lines
  Added in v.1.67

  ViewVC Help
Powered by ViewVC 1.1.20