/[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.70 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.70 2005/05/17 14:36:13 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
11ECLASS=perl-module 15inherit perl-helper eutils base
12INHERITED="${INHERITED} ${ECLASS}"
13 16
17PERL_EXPF="src_unpack src_compile src_test src_install"
18
19case "${EAPI:-0}" in
20 0|1)
14EXPORT_FUNCTIONS pkg_setup pkg_preinst pkg_postinst pkg_prerm pkg_postrm \ 21 PERL_EXPF="${PERL_EXPF} pkg_setup pkg_preinst pkg_postinst pkg_prerm pkg_postrm"
15 src_compile src_install src_test \ 22 ;;
16 perlinfo updatepod 23 2|3)
24 PERL_EXPF="${PERL_EXPF} src_prepare src_configure"
25 [[ ${CATEGORY} == "perl-core" ]] && \
26 PERL_EXPF="${PERL_EXPF} pkg_postinst pkg_postrm"
17 27
18# 2005.04.28 mcummings 28 case "${GENTOO_DEPEND_ON_PERL:-yes}" in
19# Mounting problems with src_test functions has forced me to make the 29 yes)
20# compilation of perl modules honor the FEATURES maketest flag rather than what 30 DEPEND="dev-lang/perl[-build]"
21# is generally necessary. I've left a block to make sure we still need to set 31 RDEPEND="${DEPEND}"
22# the SRC_TEST="do" flag on the suspicion that otherwise we will face 10 times 32 ;;
23# as many bug reports as we have lately. 33 esac
34 ;;
35 *)
36 DEPEND="EAPI-UNSUPPORTED"
37 ;;
38esac
24 39
25# 2004.05.10 rac 40EXPORT_FUNCTIONS ${PERL_EXPF}
26# block on makemaker versions earlier than that in the 5.8.2 core. in
27# actuality, this should be handled in the perl ebuild, so every perl
28# ebuild should block versions of MakeMaker older than the one it
29# carries. in the meantime, since we have dumped support for MakeMaker
30# <6.11 and the associated broken DESTDIR handling, block here to save
31# people from sandbox trouble.
32#
33# 2004.05.25 rac
34# for the same reasons, make the perl dep >=5.8.2 to get everybody
35# with 5.8.0 and its 6.03 makemaker up to a version that can
36# understand DESTDIR
37#
38# 2004.10.01 mcummings
39# noticed a discrepancy in how we were sed fixing references to ${D}
40#
41# 2005.03.14 mcummings
42# Updated eclass to include a specific function for dealing with perlocal.pods -
43# this should avoid the conflicts we've been running into with the introduction
44# of file collision features by giving us a single exportable function to deal
45# with the pods. Modifications to the eclass provided by Yaakov S
46# <yselkowitz@hotmail.com> in bug 83622
47#
48# <later the same day>
49# The long awaited (by me) fix for automagically detecting and dealing
50# with module-build dependancies. I've chosen not to make it a default dep since
51# this adds overhead to people that might not otherwise need it, and instead
52# modified the eclass to detect the existence of a Build.PL and behave
53# accordingly. This will fix issues with g-cpan builds that needs module-build
54# support, as well as get rid of the (annoying) style=builder vars. I know of
55# only one module that needed to be hacked for this, Class-MethodMaker-2.05, but
56# that module has a bad Build.PL to begin with. Ebuilds should continue to
57# DEPEND on module-build<-version> as needed, but there should be no need for
58# the style directive any more (especially since it isn't in the eclass
59# anymore). Enjoy!
60 41
42DESCRIPTION="Based on the $ECLASS eclass"
61 43
44LICENSE="${LICENSE:-|| ( Artistic GPL-1 GPL-2 GPL-3 )}"
62 45
63DEPEND=">=dev-lang/perl-5.8.2 !<dev-perl/ExtUtils-MakeMaker-6.17" 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
64SRC_PREP="no" 52SRC_PREP="no"
65SRC_TEST="skip" 53SRC_TEST="skip"
54PREFER_BUILDPL="yes"
66 55
67PERL_VERSION="" 56pm_echovar=""
68SITE_ARCH="" 57perlinfo_done=false
69SITE_LIB="" 58
70VENDOR_LIB="" 59perl-module_src_unpack() {
71VENDOR_ARCH="" 60 debug-print-function $FUNCNAME "$@"
72ARCH_LIB="" 61 base_src_unpack
73POD_DIR="" 62 has src_prepare ${PERL_EXPF} || perl-module_src_prepare
74BUILDER_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}
75 76
76perl-module_src_prep() { 77perl-module_src_prep() {
78 debug-print-function $FUNCNAME "$@"
79 [[ ${SRC_PREP} = yes ]] && return 0
80 SRC_PREP="yes"
77 81
78 perlinfo 82 perl_set_version
83 perl_set_eprefix
79 84
80 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"
81 88
82 89 if [[ ${PREFER_BUILDPL} == yes && -f Build.PL ]] ; then
83 SRC_PREP="yes" 90 einfo "Using Module::Build"
84 if [ -f ${S}/Build.PL ]; then 91 if [[ ${DEPEND} != *virtual/perl-Module-Build* && ${PN} != Module-Build ]] ; then
85 if [ -z ${BUILDER_VER} ]; then 92 ewarn "QA Notice: The ebuild uses Module::Build but doesn't depend on it."
86 eerror 93 ewarn " Add virtual/perl-Module-Build to DEPEND!"
87 eerror "Please post a bug on http://bugs.gentoo.org assigned to"
88 eerror "perl@gentoo.org - ${P} was added without a dependancy"
89 eerror "on dev-perl/module-build"
90 eerror "${BUILDER_VER}"
91 eerror
92 die
93 else
94 perl ${S}/Build.PL installdirs=vendor destdir=${D}
95 fi 94 fi
96 else 95 set -- \
97 perl Makefile.PL ${myconf} \ 96 --installdirs=vendor \
98 PREFIX=/usr INSTALLDIRS=vendor DESTDIR=${D} 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
105 einfo "Using ExtUtils::MakeMaker"
106 set -- \
107 PREFIX=${EPREFIX}/usr \
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
99 fi 119 fi
100} 120}
101 121
102perl-module_src_compile() { 122perl-module_src_compile() {
123 debug-print-function $FUNCNAME "$@"
124 perl_set_version
103 125
104 perlinfo 126 has src_configure ${PERL_EXPF} || perl-module_src_prep
105 [ "${SRC_PREP}" != "yes" ] && perl-module_src_prep 127
106 if [ -z ${BUILDER_VER} ]; then 128 if [[ -f Build ]] ; then
129 ./Build build \
107 make ${mymake} || die "compilation failed" 130 || die "compilation failed"
108 else 131 elif [[ -f Makefile ]] ; then
109 perl ${S}/Build build 132 emake \
133 OTHERLDFLAGS="${LDFLAGS}" \
134 ${mymake} \
135 || die "compilation failed"
136# OPTIMIZE="${CFLAGS}" \
110 fi 137 fi
111
112} 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#
113 160
114perl-module_src_test() { 161perl-module_src_test() {
115 if [ "${SRC_TEST}" == "do" ]; then 162 debug-print-function $FUNCNAME "$@"
116 perlinfo 163 if has 'do' ${SRC_TEST} || has 'parallel' ${SRC_TEST} ; then
117 if [ -z ${BUILDER_VER} ]; then 164 if has "${TEST_VERBOSE:-0}" 0 && has 'parallel' ${SRC_TEST} ; then
118 make test || die "test failed" 165 export HARNESS_OPTIONS=j$(echo -j1 ${MAKEOPTS} | sed -r "s/.*(-j\s*|--jobs=)([0-9]+).*/\2/" )
119 else 166 einfo "Test::Harness Jobs=${HARNESS_OPTIONS}"
120 perl ${S}/Build test || die "test failed"
121 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
122 fi 174 fi
123} 175}
124 176
125perl-module_src_install() { 177perl-module_src_install() {
126 178 debug-print-function $FUNCNAME "$@"
127 perlinfo 179
128 180 perl_set_version
129 test -z ${mytargets} && mytargets="install" 181 perl_set_eprefix
130 182
131 if [ -z ${BUILDER_VER} ]; then 183 local f
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"
195 elif [[ -f Makefile ]] ; then
132 make ${myinst} ${mytargets} || die 196 emake ${myinst} ${mytargets} \
133 else 197 || die "emake ${myinst} ${mytargets} failed"
134 perl ${S}/Build install
135 fi
136
137 fixlocalpod
138
139 for FILE in `find ${D} -type f |grep -v '.so'`; do
140 STAT=`file $FILE| grep -i " text"`
141 if [ "${STAT}x" != "x" ]; then
142 sed -i -e "s:${D}:/:g" ${FILE}
143 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}
144 done 207 done
145 208
146 for doc in Change* MANIFEST* README*; do 209 perl_link_duallife_scripts
147 [ -s "$doc" ] && dodoc $doc
148 done
149 if [ -s "${mydoc}" ]; then
150 dodoc ${mydoc}
151 fi
152} 210}
153
154 211
155perl-module_pkg_setup() { 212perl-module_pkg_setup() {
156 213 debug-print-function $FUNCNAME "$@"
157 perlinfo 214 perl_set_version
158} 215}
159
160 216
161perl-module_pkg_preinst() { 217perl-module_pkg_preinst() {
162 218 debug-print-function $FUNCNAME "$@"
163 perlinfo 219 perl_set_version
164} 220}
165 221
166perl-module_pkg_postinst() { 222perl-module_pkg_postinst() {
167 223 debug-print-function $FUNCNAME "$@"
168 updatepod 224 perl_link_duallife_scripts
169} 225}
170 226
171perl-module_pkg_prerm() { 227perl-module_pkg_prerm() {
172 228 debug-print-function $FUNCNAME "$@"
173 updatepod
174} 229}
175 230
176perl-module_pkg_postrm() { 231perl-module_pkg_postrm() {
177 232 debug-print-function $FUNCNAME "$@"
178 updatepod 233 perl_link_duallife_scripts
179} 234}
180
181perlinfo() {
182
183 eval `perl '-V:version'`
184 PERL_VERSION=${version}
185
186 eval `perl '-V:installsitearch'`
187 SITE_ARCH=${installsitearch}
188
189 eval `perl '-V:installsitearch'`
190 SITE_LIB=${installsitearch}
191
192 eval `perl '-V:installarchlib'`
193 ARCH_LIB=${installarchlib}
194
195 eval `perl '-V:installvendorlib'`
196 VENDOR_LIB=${installvendorlib}
197
198 eval `perl '-V:installvendorarch'`
199 VENDOR_ARCH=${installvendorarch}
200
201 if [ -f ${S}/Build.PL ]; then
202 if [ ${PN} == "module-build" ]; then
203 BUILDER_VER="1" # A bootstrapping if you will
204 else
205 BUILDER_VER=`perl -MModule::Build -e 'print "$Module::Build::VERSION;"' `
206 fi
207 fi
208
209 if [ -f /usr/bin/perl ]
210 then
211 POD_DIR="/usr/share/perl/gentoo-pods/${version}"
212 fi
213}
214
215fixlocalpod() {
216 perlinfo
217 dodir ${POD_DIR}
218
219 if [ -f ${D}${ARCH_LIB}/perllocal.pod ];
220 then
221 touch ${D}/${POD_DIR}/${P}.pod
222 sed -e "s:${D}::g" \
223 ${D}${ARCH_LIB}/perllocal.pod >> ${D}/${POD_DIR}/${P}.pod
224 touch ${D}/${POD_DIR}/${P}.pod.arch
225 cat ${D}/${POD_DIR}/${P}.pod >>${D}/${POD_DIR}/${P}.pod.arch
226 rm -f ${D}/${ARCH_LIB}/perllocal.pod
227 fi
228
229 if [ -f ${D}${SITE_LIB}/perllocal.pod ];
230 then
231 touch ${D}/${POD_DIR}/${P}.pod
232 sed -e "s:${D}::g" \
233 ${D}${SITE_LIB}/perllocal.pod >> ${D}/${POD_DIR}/${P}.pod
234 touch ${D}/${POD_DIR}/${P}.pod.site
235 cat ${D}/${POD_DIR}/${P}.pod >>${D}/${POD_DIR}/${P}.pod.site
236 rm -f ${D}/${SITE_LIB}/perllocal.pod
237 fi
238
239 if [ -f ${D}${VENDOR_LIB}/perllocal.pod ];
240 then
241 touch ${D}/${POD_DIR}/${P}.pod
242 sed -e "s:${D}::g" \
243 ${D}${VENDOR_LIB}/perllocal.pod >> ${D}/${POD_DIR}/${P}.pod
244 touch ${D}/${POD_DIR}/${P}.pod.vendor
245 cat ${D}/${POD_DIR}/${P}.pod >>${D}/${POD_DIR}/${P}.pod.vendor
246 rm -f ${D}/${VENDOR_LIB}/perllocal.pod
247 fi
248}
249
250updatepod() {
251 perlinfo
252
253 if [ -d "${POD_DIR}" ]
254 then
255 for FILE in `find ${POD_DIR} -type f -name "*.pod.arch"`; do
256 cat ${FILE} >> ${ARCH_LIB}/perllocal.pod
257 rm -f ${FILE}
258 done
259 for FILE in `find ${POD_DIR} -type f -name "*.pod.site"`; do
260 cat ${FILE} >> ${SITE_LIB}/perllocal.pod
261 rm -f ${FILE}
262 done
263 for FILE in `find ${POD_DIR} -type f -name "*.pod.vendor"`; do
264 cat ${FILE} >> ${VENDOR_LIB}/perllocal.pod
265 rm -f ${FILE}
266 done
267 fi
268}

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

  ViewVC Help
Powered by ViewVC 1.1.20