/[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.96 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.96 2006/06/12 20:11:39 mcummings 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 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
95 # Disable ExtUtils::AutoInstall from prompting 86 # Disable ExtUtils::AutoInstall from prompting
96 export PERL_EXTUTILS_AUTOINSTALL="--skipdeps" 87 export PERL_EXTUTILS_AUTOINSTALL="--skipdeps"
97 88
98 89 if [[ ${PREFER_BUILDPL} == yes && -f Build.PL ]] ; then
99 SRC_PREP="yes" 90 einfo "Using Module::Build"
100 if [ -f Makefile.PL ] && [ ! ${PN} == "module-build" ]; then 91 if [[ ${DEPEND} != *virtual/perl-Module-Build* && ${PN} != Module-Build ]] ; then
92 ewarn "QA Notice: The ebuild uses Module::Build but doesn't depend on it."
93 ewarn " Add virtual/perl-Module-Build to DEPEND!"
94 fi
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
101 einfo "Using ExtUtils::MakeMaker" 105 einfo "Using ExtUtils::MakeMaker"
102 #perl Makefile.PL ${myconf} \ 106 set -- \
103 perl Makefile.PL ${myconf} INSTALLMAN3DIR='none'\ 107 PREFIX=${EPREFIX}/usr \
104 PREFIX=/usr INSTALLDIRS=vendor DESTDIR=${D} || die "Unable to build! (are you using USE=\"build\"?)" 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\"?)"
105 fi 115 fi
106 if [ -f Build.PL ] && ( [ ! -f Makefile.PL ] || [ ${PN} == "module-build" ]); then
107 einfo "Using Module::Build"
108 perl Build.PL --installdirs=vendor --destdir=${D} --libdoc= || die "Unable to build! (are you using USE=\"build\"?)"
109 fi
110 if [ ! -f Build.PL ] && [ ! -f Makefile.PL ]; then 116 if [[ ! -f Build.PL && ! -f Makefile.PL ]] ; then
111 einfo "No Make or Build file detected..." 117 einfo "No Make or Build file detected..."
112 return 118 return
113 fi 119 fi
114} 120}
115 121
116perl-module_src_compile() { 122perl-module_src_compile() {
123 debug-print-function $FUNCNAME "$@"
124 perl_set_version
117 125
118 perlinfo 126 has src_configure ${PERL_EXPF} || perl-module_src_prep
119 [ "${SRC_PREP}" != "yes" ] && perl-module_src_prep 127
128 if [[ -f Build ]] ; then
129 ./Build build \
130 || die "compilation failed"
120 if [ -f Makefile ]; then 131 elif [[ -f Makefile ]] ; then
132 emake \
133 OTHERLDFLAGS="${LDFLAGS}" \
134 ${mymake} \
121 make ${mymake} || die "compilation failed" 135 || die "compilation failed"
122 elif [ -f Build ]; then 136# OPTIMIZE="${CFLAGS}" \
123 perl Build build || die "compilation failed"
124 fi 137 fi
125
126} 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#
127 160
128perl-module_src_test() { 161perl-module_src_test() {
129 if [ "${SRC_TEST}" == "do" ]; then 162 debug-print-function $FUNCNAME "$@"
130 perlinfo 163 if has 'do' ${SRC_TEST} || has 'parallel' ${SRC_TEST} ; then
131 if [ -f Makefile ]; then 164 if has "${TEST_VERBOSE:-0}" 0 && has 'parallel' ${SRC_TEST} ; then
132 make test || die "test failed" 165 export HARNESS_OPTIONS=j$(echo -j1 ${MAKEOPTS} | sed -r "s/.*(-j\s*|--jobs=)([0-9]+).*/\2/" )
133 elif [ -f Build ]; then 166 einfo "Test::Harness Jobs=${HARNESS_OPTIONS}"
134 perl Build test || die "test failed"
135 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
136 fi 174 fi
137} 175}
138 176
139perl-module_src_install() { 177perl-module_src_install() {
178 debug-print-function $FUNCNAME "$@"
140 179
141 perlinfo 180 perl_set_version
181 perl_set_eprefix
142 182
143 test -z ${mytargets} && mytargets="install" 183 local f
144 184
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"
145 if [ -f Makefile ]; then 195 elif [[ -f Makefile ]] ; then
146 make ${myinst} ${mytargets} || die 196 emake ${myinst} ${mytargets} \
147 elif [ -f Build ]; then 197 || die "emake ${myinst} ${mytargets} failed"
148 perl ${S}/Build install
149 fi
150
151 fixlocalpod
152
153 for FILE in `find ${D} -type f |grep -v '.so'`; do
154 STAT=`file $FILE| grep -i " text"`
155 if [ "${STAT}x" != "x" ]; then
156 sed -i -e "s:${D}:/:g" ${FILE}
157 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}
158 done 207 done
159 208
160 for doc in Change* MANIFEST* README* ${mydoc}; do 209 perl_link_duallife_scripts
161 [ -s "$doc" ] && dodoc $doc
162 done
163} 210}
164
165 211
166perl-module_pkg_setup() { 212perl-module_pkg_setup() {
167 213 debug-print-function $FUNCNAME "$@"
168 perlinfo 214 perl_set_version
169} 215}
170
171 216
172perl-module_pkg_preinst() { 217perl-module_pkg_preinst() {
173 218 debug-print-function $FUNCNAME "$@"
174 perlinfo 219 perl_set_version
175} 220}
176 221
177perl-module_pkg_postinst() { 222perl-module_pkg_postinst() {
178 223 debug-print-function $FUNCNAME "$@"
179 einfo "Man pages are not installed for most modules now." 224 perl_link_duallife_scripts
180 einfo "Please use perldoc instead."
181 updatepod
182} 225}
183 226
184perl-module_pkg_prerm() { 227perl-module_pkg_prerm() {
185 228 debug-print-function $FUNCNAME "$@"
186 updatepod
187} 229}
188 230
189perl-module_pkg_postrm() { 231perl-module_pkg_postrm() {
190 232 debug-print-function $FUNCNAME "$@"
191 updatepod 233 perl_link_duallife_scripts
192} 234}
193
194perlinfo() {
195
196 local version
197 eval `perl '-V:version'`
198 PERL_VERSION=${version}
199
200 local installsitearch
201 eval `perl '-V:installsitearch'`
202 SITE_ARCH=${installsitearch}
203
204 local installsitelib
205 eval `perl '-V:installsitelib'`
206 SITE_LIB=${installsitelib}
207
208 local installarchlib
209 eval `perl '-V:installarchlib'`
210 ARCH_LIB=${installarchlib}
211
212 local installvendorlib
213 eval `perl '-V:installvendorlib'`
214 VENDOR_LIB=${installvendorlib}
215
216 local installvendorarch
217 eval `perl '-V:installvendorarch'`
218 VENDOR_ARCH=${installvendorarch}
219
220 if [ "${USE_BUILDER}" == "yes" ]; then
221 if [ ! -f ${S}/Makefile.PL ] || [ ${PN} == "module-build" ]; 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 fi
231
232 if [ -f /usr/bin/perl ]
233 then
234 POD_DIR="/usr/share/perl/gentoo-pods/${version}"
235 fi
236}
237
238fixlocalpod() {
239 perlinfo
240 dodir ${POD_DIR}
241
242 if [ -f ${D}${ARCH_LIB}/perllocal.pod ];
243 then
244 touch ${D}/${POD_DIR}/${P}.pod
245 sed -e "s:${D}::g" \
246 ${D}${ARCH_LIB}/perllocal.pod >> ${D}/${POD_DIR}/${P}.pod
247 touch ${D}/${POD_DIR}/${P}.pod.arch
248 cat ${D}/${POD_DIR}/${P}.pod >>${D}/${POD_DIR}/${P}.pod.arch
249 rm -f ${D}/${ARCH_LIB}/perllocal.pod
250 fi
251
252 if [ -f ${D}${SITE_LIB}/perllocal.pod ];
253 then
254 touch ${D}/${POD_DIR}/${P}.pod
255 sed -e "s:${D}::g" \
256 ${D}${SITE_LIB}/perllocal.pod >> ${D}/${POD_DIR}/${P}.pod
257 touch ${D}/${POD_DIR}/${P}.pod.site
258 cat ${D}/${POD_DIR}/${P}.pod >>${D}/${POD_DIR}/${P}.pod.site
259 rm -f ${D}/${SITE_LIB}/perllocal.pod
260 fi
261
262 if [ -f ${D}${VENDOR_LIB}/perllocal.pod ];
263 then
264 touch ${D}/${POD_DIR}/${P}.pod
265 sed -e "s:${D}::g" \
266 ${D}${VENDOR_LIB}/perllocal.pod >> ${D}/${POD_DIR}/${P}.pod
267 touch ${D}/${POD_DIR}/${P}.pod.vendor
268 cat ${D}/${POD_DIR}/${P}.pod >>${D}/${POD_DIR}/${P}.pod.vendor
269 rm -f ${D}/${VENDOR_LIB}/perllocal.pod
270 fi
271}
272
273updatepod() {
274 perlinfo
275
276 if [ -d "${POD_DIR}" ]
277 then
278 for FILE in `find ${POD_DIR} -type f -name "*.pod.arch"`; do
279 cat ${FILE} >> ${ARCH_LIB}/perllocal.pod
280 rm -f ${FILE}
281 done
282 for FILE in `find ${POD_DIR} -type f -name "*.pod.site"`; do
283 cat ${FILE} >> ${SITE_LIB}/perllocal.pod
284 rm -f ${FILE}
285 done
286 for FILE in `find ${POD_DIR} -type f -name "*.pod.vendor"`; do
287 cat ${FILE} >> ${VENDOR_LIB}/perllocal.pod
288 rm -f ${FILE}
289 done
290 fi
291}

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

  ViewVC Help
Powered by ViewVC 1.1.20