/[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.83 Revision 1.123
1# Copyright 1999-2004 Gentoo Foundation 1# Copyright 1999-2009 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.83 2006/02/28 02:56:48 vapier Exp $ 3# $Header: /var/cvsroot/gentoo-x86/eclass/perl-module.eclass,v 1.123 2010/04/17 19:56:27 tove 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
7# 7# @ECLASS: perl-module.eclass
8# @MAINTAINER:
9# perl@gentoo.org
10# @BLURB: eclass for perl modules
11# @DESCRIPTION:
8# The perl-module eclass is designed to allow easier installation of perl 12# The perl-module eclass is designed to allow easier installation of perl
9# modules, and their incorporation into the Gentoo Linux system. 13# modules, and their incorporation into the Gentoo Linux system.
10 14
15inherit perl-helper eutils base
11 16
12EXPORT_FUNCTIONS pkg_setup pkg_preinst pkg_postinst pkg_prerm pkg_postrm src_compile src_install src_test perlinfo fixlocalpod updatepod 17PERL_EXPF="src_unpack src_compile src_test src_install"
13 18
14# 2005.04.28 mcummings 19case "${EAPI:-0}" in
15# Mounting problems with src_test functions has forced me to make the 20 0|1)
16# compilation of perl modules honor the FEATURES maketest flag rather than what 21 PERL_EXPF="${PERL_EXPF} pkg_setup pkg_preinst pkg_postinst pkg_prerm pkg_postrm"
17# is generally necessary. I've left a block to make sure we still need to set 22 ;;
18# the SRC_TEST="do" flag on the suspicion that otherwise we will face 10 times 23 2|3)
19# as many bug reports as we have lately. 24 PERL_EXPF="${PERL_EXPF} src_prepare src_configure"
25 [[ ${CATEGORY} == "perl-core" ]] && \
26 PERL_EXPF="${PERL_EXPF} pkg_postinst pkg_postrm"
20 27
21# 2004.05.10 rac 28 case "${GENTOO_DEPEND_ON_PERL:-yes}" in
22# block on makemaker versions earlier than that in the 5.8.2 core. in 29 yes)
23# actuality, this should be handled in the perl ebuild, so every perl 30 DEPEND="dev-lang/perl[-build]"
24# ebuild should block versions of MakeMaker older than the one it 31 RDEPEND="${DEPEND}"
25# carries. in the meantime, since we have dumped support for MakeMaker 32 ;;
26# <6.11 and the associated broken DESTDIR handling, block here to save 33 esac
27# people from sandbox trouble. 34 ;;
28# 35 *)
29# 2004.05.25 rac 36 DEPEND="EAPI-UNSUPPORTED"
30# for the same reasons, make the perl dep >=5.8.2 to get everybody 37 ;;
31# with 5.8.0 and its 6.03 makemaker up to a version that can 38esac
32# understand DESTDIR
33#
34# 2004.10.01 mcummings
35# noticed a discrepancy in how we were sed fixing references to ${D}
36#
37# 2005.03.14 mcummings
38# Updated eclass to include a specific function for dealing with perlocal.pods -
39# this should avoid the conflicts we've been running into with the introduction
40# of file collision features by giving us a single exportable function to deal
41# with the pods. Modifications to the eclass provided by Yaakov S
42# <yselkowitz@hotmail.com> in bug 83622
43#
44# <later the same day>
45# The long awaited (by me) fix for automagically detecting and dealing
46# with module-build dependancies. I've chosen not to make it a default dep since
47# this adds overhead to people that might not otherwise need it, and instead
48# modified the eclass to detect the existence of a Build.PL and behave
49# accordingly. This will fix issues with g-cpan builds that needs module-build
50# support, as well as get rid of the (annoying) style=builder vars. I know of
51# only one module that needed to be hacked for this, Class-MethodMaker-2.05, but
52# that module has a bad Build.PL to begin with. Ebuilds should continue to
53# DEPEND on module-build<-version> as needed, but there should be no need for
54# the style directive any more (especially since it isn't in the eclass
55# anymore). Enjoy!
56#
57# 2005.07.18 mcummings
58# Fix for proper handling of $mydoc - thanks to stkn for noticing we were
59# bombing out there
60#
61# 2005.07.19 mcummings
62# Providing an override var for the use of Module::Build. While it is being
63# incorporated in more and more modules, not module authors have working
64# Build.PL's in place. The override is to allow for a fallback to the "classic"
65# Makfile.PL - example is Class::MethodMaker, which provides a Build.PL that is
66# severely broken.
67#
68# 2006.02.11 mcummings
69# Per a conversation with solar, adding a change to the dep/rdep lines for
70# minimal. Should fix bug 68367 and bug 83622, as well as other embedded builds
71# that use perl components without providing perl
72 39
40EXPORT_FUNCTIONS ${PERL_EXPF}
73 41
74IUSE="minimal" 42DESCRIPTION="Based on the $ECLASS eclass"
75DEPEND=">=dev-lang/perl-5.8.2 !<perl-core/ExtUtils-MakeMaker-6.17" 43
76RDEPEND="!minimal? ( ${DEPEND} )" 44LICENSE="${LICENSE:-|| ( Artistic GPL-1 GPL-2 GPL-3 )}"
45
46[[ -z "${SRC_URI}" && -z "${MODULE_A}" ]] && MODULE_A="${MY_P:-${P}}.tar.gz"
47[[ -z "${SRC_URI}" && -n "${MODULE_AUTHOR}" ]] && \
48 SRC_URI="mirror://cpan/authors/id/${MODULE_AUTHOR:0:1}/${MODULE_AUTHOR:0:2}/${MODULE_AUTHOR}/${MODULE_SECTION:+${MODULE_SECTION}/}${MODULE_A}"
49[[ -z "${HOMEPAGE}" ]] && \
50 HOMEPAGE="http://search.cpan.org/dist/${MY_PN:-${PN}}/"
51
77SRC_PREP="no" 52SRC_PREP="no"
78SRC_TEST="skip" 53SRC_TEST="skip"
79USE_BUILDER="yes" 54PREFER_BUILDPL="yes"
80 55
81PERL_VERSION="" 56pm_echovar=""
82SITE_ARCH="" 57perlinfo_done=false
83SITE_LIB="" 58
84VENDOR_LIB="" 59perl-module_src_unpack() {
85VENDOR_ARCH="" 60 debug-print-function $FUNCNAME "$@"
86ARCH_LIB="" 61 base_src_unpack
87POD_DIR="" 62 has src_prepare ${PERL_EXPF} || perl-module_src_prepare
88BUILDER_VER="" 63}
64
65perl-module_src_prepare() {
66 debug-print-function $FUNCNAME "$@"
67 has src_prepare ${PERL_EXPF} && base_src_prepare
68 perl_fix_osx_extra
69 esvn_clean
70}
71
72perl-module_src_configure() {
73 debug-print-function $FUNCNAME "$@"
74 perl-module_src_prep
75}
89 76
90perl-module_src_prep() { 77perl-module_src_prep() {
78 debug-print-function $FUNCNAME "$@"
79 [[ ${SRC_PREP} = yes ]] && return 0
80 SRC_PREP="yes"
91 81
92 perlinfo 82 perl_set_version
83 perl_set_eprefix
93 84
94 export PERL_MM_USE_DEFAULT=1 85 export PERL_MM_USE_DEFAULT=1
86 # Disable ExtUtils::AutoInstall from prompting
87 export PERL_EXTUTILS_AUTOINSTALL="--skipdeps"
95 88
96 89 if [[ ${PREFER_BUILDPL} == yes && -f Build.PL ]] ; then
97 SRC_PREP="yes"
98 if [ -f ${S}/Build.PL ] && [ "${USE_BUILDER}" == "yes" ]; then
99 einfo "Using Module::Build" 90 einfo "Using Module::Build"
100 if [ -z ${BUILDER_VER} ]; then 91 if [[ ${DEPEND} != *virtual/perl-Module-Build* && ${PN} != Module-Build ]] ; then
101 eerror 92 ewarn "QA Notice: The ebuild uses Module::Build but doesn't depend on it."
102 eerror "Please post a bug on http://bugs.gentoo.org assigned to" 93 ewarn " Add virtual/perl-Module-Build to DEPEND!"
103 eerror "perl@gentoo.org - ${P} was added without a dependancy"
104 eerror "on dev-perl/module-build"
105 eerror "${BUILDER_VER}"
106 eerror
107 die
108 else
109 perl ${S}/Build.PL installdirs=vendor destdir=${D} libdoc=
110 fi 94 fi
111 else 95 set -- \
96 --installdirs=vendor \
97 --libdoc= \
98 --destdir="${D}" \
99 --create_packlist=0 \
100 ${myconf}
101 einfo "perl Build.PL" "$@"
102 perl Build.PL "$@" <<< "${pm_echovar}" \
103 || die "Unable to build! (are you using USE=\"build\"?)"
104 elif [[ -f Makefile.PL ]] ; then
112 einfo "Using ExtUtils::MakeMaker" 105 einfo "Using ExtUtils::MakeMaker"
113 #perl Makefile.PL ${myconf} \ 106 set -- \
114 perl Makefile.PL ${myconf} INSTALLMAN3DIR='none'\ 107 PREFIX=${EPREFIX}/usr \
115 PREFIX=/usr INSTALLDIRS=vendor DESTDIR=${D} 108 INSTALLDIRS=vendor \
109 INSTALLMAN3DIR='none' \
110 DESTDIR="${D}" \
111 ${myconf}
112 einfo "perl Makefile.PL" "$@"
113 perl Makefile.PL "$@" <<< "${pm_echovar}" \
114 || die "Unable to build! (are you using USE=\"build\"?)"
115 fi
116 if [[ ! -f Build.PL && ! -f Makefile.PL ]] ; then
117 einfo "No Make or Build file detected..."
118 return
116 fi 119 fi
117} 120}
118 121
119perl-module_src_compile() { 122perl-module_src_compile() {
123 debug-print-function $FUNCNAME "$@"
124 perl_set_version
120 125
121 perlinfo 126 has src_configure ${PERL_EXPF} || perl-module_src_prep
122 [ "${SRC_PREP}" != "yes" ] && perl-module_src_prep 127
123 if [ -z ${BUILDER_VER} ]; then 128 if [[ -f Build ]] ; then
129 ./Build build \
124 make ${mymake} || die "compilation failed" 130 || die "compilation failed"
125 else 131 elif [[ -f Makefile ]] ; then
126 perl ${S}/Build build 132 emake \
133 OTHERLDFLAGS="${LDFLAGS}" \
134 ${mymake} \
135 || die "compilation failed"
136# OPTIMIZE="${CFLAGS}" \
127 fi 137 fi
128
129} 138}
139
140# For testers:
141# This code attempts to work out your threadingness from MAKEOPTS
142# and apply them to Test::Harness.
143#
144# If you want more verbose testing, set TEST_VERBOSE=1
145# in your bashrc | /etc/make.conf | ENV
146#
147# For ebuild writers:
148# If you wish to enable default tests w/ 'make test' ,
149#
150# SRC_TEST="do"
151#
152# If you wish to have threads run in parallel ( using the users makeopts )
153# all of the following have been tested to work.
154#
155# SRC_TEST="do parallel"
156# SRC_TEST="parallel"
157# SRC_TEST="parallel do"
158# SRC_TEST=parallel
159#
130 160
131perl-module_src_test() { 161perl-module_src_test() {
132 if [ "${SRC_TEST}" == "do" ]; then 162 debug-print-function $FUNCNAME "$@"
133 perlinfo 163 if has 'do' ${SRC_TEST} || has 'parallel' ${SRC_TEST} ; then
134 if [ -z ${BUILDER_VER} ]; then 164 if has "${TEST_VERBOSE:-0}" 0 && has 'parallel' ${SRC_TEST} ; then
135 make test || die "test failed" 165 export HARNESS_OPTIONS=j$(echo -j1 ${MAKEOPTS} | sed -r "s/.*(-j\s*|--jobs=)([0-9]+).*/\2/" )
136 else 166 einfo "Test::Harness Jobs=${HARNESS_OPTIONS}"
137 perl ${S}/Build test || die "test failed"
138 fi 167 fi
168 ${perlinfo_done} || perl_set_version
169 if [[ -f Build ]] ; then
170 ./Build test verbose=${TEST_VERBOSE:-0} || die "test failed"
171 elif [[ -f Makefile ]] ; then
172 emake test TEST_VERBOSE=${TEST_VERBOSE:-0} || die "test failed"
173 fi
139 fi 174 fi
140} 175}
141 176
142perl-module_src_install() { 177perl-module_src_install() {
178 debug-print-function $FUNCNAME "$@"
143 179
144 perlinfo 180 perl_set_version
181 perl_set_eprefix
145 182
146 test -z ${mytargets} && mytargets="install" 183 local f
147 184
148 if [ -z ${BUILDER_VER} ]; then 185 if [[ -z ${mytargets} ]] ; then
186 case "${CATEGORY}" in
187 dev-perl|perl-core) mytargets="pure_install" ;;
188 *) mytargets="install" ;;
189 esac
190 fi
191
192 if [[ -f Build ]] ; then
193 ./Build ${mytargets} \
194 || die "./Build ${mytargets} failed"
195 elif [[ -f Makefile ]] ; then
149 make ${myinst} ${mytargets} || die 196 emake ${myinst} ${mytargets} \
150 else 197 || die "emake ${myinst} ${mytargets} failed"
151 perl ${S}/Build install
152 fi
153
154 fixlocalpod
155
156 for FILE in `find ${D} -type f |grep -v '.so'`; do
157 STAT=`file $FILE| grep -i " text"`
158 if [ "${STAT}x" != "x" ]; then
159 sed -i -e "s:${D}:/:g" ${FILE}
160 fi 198 fi
199
200 perl_delete_module_manpages
201 perl_delete_localpod
202 perl_delete_packlist
203 perl_remove_temppath
204
205 for f in Change* CHANGES README* TODO FAQ ${mydoc}; do
206 [[ -s ${f} ]] && dodoc ${f}
161 done 207 done
162 208
163 for doc in Change* MANIFEST* README* ${mydoc}; do 209 perl_link_duallife_scripts
164 [ -s "$doc" ] && dodoc $doc
165 done
166} 210}
167
168 211
169perl-module_pkg_setup() { 212perl-module_pkg_setup() {
170 213 debug-print-function $FUNCNAME "$@"
171 perlinfo 214 perl_set_version
172} 215}
173
174 216
175perl-module_pkg_preinst() { 217perl-module_pkg_preinst() {
176 218 debug-print-function $FUNCNAME "$@"
177 perlinfo 219 perl_set_version
178} 220}
179 221
180perl-module_pkg_postinst() { 222perl-module_pkg_postinst() {
181 223 debug-print-function $FUNCNAME "$@"
182 updatepod 224 perl_link_duallife_scripts
183} 225}
184 226
185perl-module_pkg_prerm() { 227perl-module_pkg_prerm() {
186 228 debug-print-function $FUNCNAME "$@"
187 updatepod
188} 229}
189 230
190perl-module_pkg_postrm() { 231perl-module_pkg_postrm() {
191 232 debug-print-function $FUNCNAME "$@"
192 updatepod 233 perl_link_duallife_scripts
193} 234}
194
195perlinfo() {
196
197 local version
198 eval `perl '-V:version'`
199 PERL_VERSION=${version}
200
201 local installsitearch
202 eval `perl '-V:installsitearch'`
203 SITE_ARCH=${installsitearch}
204
205 local installsitelib
206 eval `perl '-V:installsitelib'`
207 SITE_LIB=${installsitelib}
208
209 local installarchlib
210 eval `perl '-V:installarchlib'`
211 ARCH_LIB=${installarchlib}
212
213 local installvendorlib
214 eval `perl '-V:installvendorlib'`
215 VENDOR_LIB=${installvendorlib}
216
217 local installvendorarch
218 eval `perl '-V:installvendorarch'`
219 VENDOR_ARCH=${installvendorarch}
220
221 if [ "${USE_BUILDER}" == "yes" ]; then
222 if [ -f ${S}/Build.PL ]; then
223 if [ ${PN} == "module-build" ]; then
224 BUILDER_VER="1" # A bootstrapping if you will
225 else
226 BUILDER_VER=`perl -MModule::Build -e 'print "$Module::Build::VERSION;"' `
227 fi
228 fi
229 fi
230
231 if [ -f /usr/bin/perl ]
232 then
233 POD_DIR="/usr/share/perl/gentoo-pods/${version}"
234 fi
235}
236
237fixlocalpod() {
238 perlinfo
239 dodir ${POD_DIR}
240
241 if [ -f ${D}${ARCH_LIB}/perllocal.pod ];
242 then
243 touch ${D}/${POD_DIR}/${P}.pod
244 sed -e "s:${D}::g" \
245 ${D}${ARCH_LIB}/perllocal.pod >> ${D}/${POD_DIR}/${P}.pod
246 touch ${D}/${POD_DIR}/${P}.pod.arch
247 cat ${D}/${POD_DIR}/${P}.pod >>${D}/${POD_DIR}/${P}.pod.arch
248 rm -f ${D}/${ARCH_LIB}/perllocal.pod
249 fi
250
251 if [ -f ${D}${SITE_LIB}/perllocal.pod ];
252 then
253 touch ${D}/${POD_DIR}/${P}.pod
254 sed -e "s:${D}::g" \
255 ${D}${SITE_LIB}/perllocal.pod >> ${D}/${POD_DIR}/${P}.pod
256 touch ${D}/${POD_DIR}/${P}.pod.site
257 cat ${D}/${POD_DIR}/${P}.pod >>${D}/${POD_DIR}/${P}.pod.site
258 rm -f ${D}/${SITE_LIB}/perllocal.pod
259 fi
260
261 if [ -f ${D}${VENDOR_LIB}/perllocal.pod ];
262 then
263 touch ${D}/${POD_DIR}/${P}.pod
264 sed -e "s:${D}::g" \
265 ${D}${VENDOR_LIB}/perllocal.pod >> ${D}/${POD_DIR}/${P}.pod
266 touch ${D}/${POD_DIR}/${P}.pod.vendor
267 cat ${D}/${POD_DIR}/${P}.pod >>${D}/${POD_DIR}/${P}.pod.vendor
268 rm -f ${D}/${VENDOR_LIB}/perllocal.pod
269 fi
270}
271
272updatepod() {
273 perlinfo
274
275 if [ -d "${POD_DIR}" ]
276 then
277 for FILE in `find ${POD_DIR} -type f -name "*.pod.arch"`; do
278 cat ${FILE} >> ${ARCH_LIB}/perllocal.pod
279 rm -f ${FILE}
280 done
281 for FILE in `find ${POD_DIR} -type f -name "*.pod.site"`; do
282 cat ${FILE} >> ${SITE_LIB}/perllocal.pod
283 rm -f ${FILE}
284 done
285 for FILE in `find ${POD_DIR} -type f -name "*.pod.vendor"`; do
286 cat ${FILE} >> ${VENDOR_LIB}/perllocal.pod
287 rm -f ${FILE}
288 done
289 fi
290}

Legend:
Removed from v.1.83  
changed lines
  Added in v.1.123

  ViewVC Help
Powered by ViewVC 1.1.20