/[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.86 Revision 1.111
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.86 2006/04/03 11:16:52 mcummings Exp $ 3# $Header: /var/cvsroot/gentoo-x86/eclass/perl-module.eclass,v 1.111 2008/02/06 02:39:04 robbat2 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
9# modules, and their incorporation into the Gentoo Linux system. 9# modules, and their incorporation into the Gentoo Linux system.
10 10
11inherit base
11 12
12EXPORT_FUNCTIONS pkg_setup pkg_preinst pkg_postinst pkg_prerm pkg_postrm src_compile src_install src_test 13EXPORT_FUNCTIONS pkg_setup pkg_preinst pkg_postinst pkg_prerm pkg_postrm src_compile src_install src_test src_unpack
13 14
14# 2005.04.28 mcummings 15# 2005.04.28 mcummings
15# Mounting problems with src_test functions has forced me to make the 16# Mounting problems with src_test functions has forced me to make the
16# compilation of perl modules honor the FEATURES maketest flag rather than what 17# compilation of perl modules honor the FEATURES maketest flag rather than what
17# is generally necessary. I've left a block to make sure we still need to set 18# is generally necessary. I've left a block to make sure we still need to set
18# the SRC_TEST="do" flag on the suspicion that otherwise we will face 10 times 19# the SRC_TEST="do" flag on the suspicion that otherwise we will face 10 times
19# as many bug reports as we have lately. 20# as many bug reports as we have lately.
20 21#
21# 2004.05.10 rac 22# 2004.05.10 rac
22# block on makemaker versions earlier than that in the 5.8.2 core. in 23# block on makemaker versions earlier than that in the 5.8.2 core. in
23# actuality, this should be handled in the perl ebuild, so every perl 24# actuality, this should be handled in the perl ebuild, so every perl
24# ebuild should block versions of MakeMaker older than the one it 25# ebuild should block versions of MakeMaker older than the one it
25# carries. in the meantime, since we have dumped support for MakeMaker 26# carries. in the meantime, since we have dumped support for MakeMaker
58# Fix for proper handling of $mydoc - thanks to stkn for noticing we were 59# Fix for proper handling of $mydoc - thanks to stkn for noticing we were
59# bombing out there 60# bombing out there
60# 61#
61# 2005.07.19 mcummings 62# 2005.07.19 mcummings
62# Providing an override var for the use of Module::Build. While it is being 63# 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# incorporated in more and more modules, not all module authors have working
64# Build.PL's in place. The override is to allow for a fallback to the "classic" 65# 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# Makfile.PL - example is Class::MethodMaker, which provides a Build.PL that is
66# severely broken. 67# severely broken.
67# 68#
68# 2006.02.11 mcummings 69# 2006.02.11 mcummings
69# Per a conversation with solar, adding a change to the dep/rdep lines for 70# 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# minimal. Should fix bug 68367 and bug 83622, as well as other embedded builds
71# that use perl components without providing perl 72# that use perl components without providing perl
73#
74# 2006.06.13 mcummings
75# I've reordered and extended the logic on when to invoke module-build versus
76# MakeMaker. The problem that has arisen is that some modules provide a
77# Makefile.PL that passes all arguments on to a Build.PL - including PREFIX,
78# which causes module-build to build with a target of /usr/usr/
79# (how broken is that?). Current logic is if there is a Build.PL and we aren't
80# overriding, use it; otherwise use the Makefile.PL; otherwise return (maybe we
81# want all the functionality of the perl-module eclass without needing to
82# compile??).
83#
84# 2007.08.19 ian
85# Added ${myconf} - bug #176818
86#
87# 2007.10.17 robbat2
88# Added the 'MODULE_AUTHOR' variable. Set it before inheriting the eclass
89# and it will set your HOMEPAGE and SRC_URI correctly for a CPAN package.
72 90
91[ -z "${SRC_URI}" -a -n "${MODULE_AUTHOR}" ] && \
92 SRC_URI="mirror://cpan/authors/id/${MODULE_AUTHOR:0:1}/${MODULE_AUTHOR:0:2}/${MODULE_AUTHOR}/${MODULE_SECTION}/${P}.tar.gz"
93[ -z "${HOMEPAGE}" ] && HOMEPAGE="http://search.cpan.org/search?query=${PN}&mode=dist"
73 94
74IUSE="minimal"
75DEPEND=">=dev-lang/perl-5.8.2 !<perl-core/ExtUtils-MakeMaker-6.17"
76RDEPEND="!minimal? ( ${DEPEND} )"
77SRC_PREP="no" 95SRC_PREP="no"
78SRC_TEST="skip" 96SRC_TEST="skip"
79USE_BUILDER="yes" 97PREFER_BUILDPL="yes"
80 98
81PERL_VERSION="" 99PERL_VERSION=""
82SITE_ARCH="" 100SITE_ARCH=""
83SITE_LIB="" 101SITE_LIB=""
84VENDOR_LIB="" 102VENDOR_LIB=""
85VENDOR_ARCH="" 103VENDOR_ARCH=""
86ARCH_LIB="" 104ARCH_LIB=""
87POD_DIR="" 105POD_DIR=""
88BUILDER_VER="" 106BUILDER_VER=""
107pm_echovar=""
108
109perl-module_src_unpack() {
110 if [[ -n ${PATCHES} ]]; then
111 base_src_unpack unpack
112 base_src_unpack autopatch
113 else
114 base_src_unpack unpack
115 fi
116}
89 117
90perl-module_src_prep() { 118perl-module_src_prep() {
91 119
92 perlinfo 120 perlinfo
93 121
94 export PERL_MM_USE_DEFAULT=1 122 export PERL_MM_USE_DEFAULT=1
123 # Disable ExtUtils::AutoInstall from prompting
124 export PERL_EXTUTILS_AUTOINSTALL="--skipdeps"
95 125
96 126
97 SRC_PREP="yes" 127 SRC_PREP="yes"
98 if [ -f Makefile.PL ]; then 128 find ${S} -type d -name "\.svn" -exec /bin/rm -rf {} \; 2>/dev/null
129 if [ "${PREFER_BUILDPL}" == "yes" ] && ( [ -f Build.PL ] || [ ${PN} == "module-build" ] ); then
130 einfo "Using Module::Build"
131 echo "$pm_echovar" | perl Build.PL ${myconf} --installdirs=vendor --destdir=${D} --libdoc= || die "Unable to build! (are you using USE=\"build\"?)"
132 elif [ -f Makefile.PL ] && [ ! ${PN} == "module-build" ]; then
99 einfo "Using ExtUtils::MakeMaker" 133 einfo "Using ExtUtils::MakeMaker"
100 #perl Makefile.PL ${myconf} \
101 perl Makefile.PL ${myconf} INSTALLMAN3DIR='none'\ 134 echo "$pm_echovar" | perl Makefile.PL ${myconf} INSTALLMAN3DIR='none'\
102 PREFIX=/usr INSTALLDIRS=vendor DESTDIR=${D} 135 PREFIX=/usr INSTALLDIRS=vendor DESTDIR=${D} || die "Unable to build! (are you using USE=\"build\"?)"
103 elif [ -f Build.PL ] && [ "${USE_BUILDER}" == "yes" ]; then
104 einfo "Using Module::Build"
105 if [ -z ${BUILDER_VER} ]; then
106 eerror
107 eerror "Please post a bug on http://bugs.gentoo.org assigned to"
108 eerror "perl@gentoo.org - ${P} was added without a dependancy"
109 eerror "on dev-perl/module-build"
110 eerror "${BUILDER_VER}"
111 eerror
112 die
113 else
114 perl Build.PL installdirs=vendor destdir=${D} libdoc=
115 fi 136 fi
116 else 137 if [ ! -f Build.PL ] && [ ! -f Makefile.PL ]; then
117 einfo "No Make or Build file detect..." 138 einfo "No Make or Build file detected..."
118 return 139 return
119 fi 140 fi
120} 141}
121 142
122perl-module_src_compile() { 143perl-module_src_compile() {
123 144
124 perlinfo 145 perlinfo
125 [ "${SRC_PREP}" != "yes" ] && perl-module_src_prep 146 [ "${SRC_PREP}" != "yes" ] && perl-module_src_prep
126 if [ -z ${BUILDER_VER} ]; then 147 if [ -f Makefile ]; then
127 make ${mymake} || die "compilation failed" 148 make ${mymake} || die "compilation failed"
128 else 149 elif [ -f Build ]; then
129 perl ${S}/Build build 150 perl Build build || die "compilation failed"
130 fi 151 fi
152 fixlocalpod
131 153
132} 154}
133 155
134perl-module_src_test() { 156perl-module_src_test() {
135 if [ "${SRC_TEST}" == "do" ]; then 157 if [ "${SRC_TEST}" == "do" ]; then
136 perlinfo 158 perlinfo
137 if [ -z ${BUILDER_VER} ]; then 159 if [ -f Makefile ]; then
138 make test || die "test failed" 160 make test || die "test failed"
139 else 161 elif [ -f Build ]; then
140 perl ${S}/Build test || die "test failed" 162 perl Build test || die "test failed"
141 fi 163 fi
142 fi 164 fi
143} 165}
144 166
145perl-module_src_install() { 167perl-module_src_install() {
146 168
147 perlinfo 169 perlinfo
148 170
149 test -z ${mytargets} && mytargets="install" 171 test -z ${mytargets} && mytargets="install"
150 172
151 if [ -z ${BUILDER_VER} ]; then 173 if [ -f Makefile ]; then
152 make ${myinst} ${mytargets} || die 174 make ${myinst} ${mytargets} || die
153 else 175 elif [ -f Build ]; then
154 perl ${S}/Build install 176 perl ${S}/Build install
155 fi 177 fi
178
179
180 einfo "Cleaning out stray man files"
181 for FILE in `find ${D} -type f -name "*.3pm*"`; do
182 rm -rf ${FILE}
183 done
184 find ${D}/usr/share/man -depth -type d 2>/dev/null | xargs -r rmdir 2>/dev/null
156 185
157 fixlocalpod 186 fixlocalpod
158 187
159 for FILE in `find ${D} -type f |grep -v '.so'`; do 188 for FILE in `find ${D} -type f |grep -v '.so'`; do
160 STAT=`file $FILE| grep -i " text"` 189 STAT=`file $FILE| grep -i " text"`
181} 210}
182 211
183perl-module_pkg_postinst() { 212perl-module_pkg_postinst() {
184 213
185 einfo "Man pages are not installed for most modules now." 214 einfo "Man pages are not installed for most modules now."
186 einfo "Please use perldoc instad." 215 einfo "Please use perldoc instead."
187 updatepod 216 updatepod
188} 217}
189 218
190perl-module_pkg_prerm() { 219perl-module_pkg_prerm() {
191 220
221 250
222 local installvendorarch 251 local installvendorarch
223 eval `perl '-V:installvendorarch'` 252 eval `perl '-V:installvendorarch'`
224 VENDOR_ARCH=${installvendorarch} 253 VENDOR_ARCH=${installvendorarch}
225 254
226 if [ "${USE_BUILDER}" == "yes" ]; then 255 if [ "${PREFER_BUILDPL}" == "yes" ]; then
227 if [ ! -f ${S}/Makefile.PL ]; then 256 if [ ! -f ${S}/Makefile.PL ] || [ ${PN} == "module-build" ]; then
228 if [ -f ${S}/Build.PL ]; then 257 if [ -f ${S}/Build.PL ]; then
229 if [ ${PN} == "module-build" ]; then 258 if [ ${PN} == "module-build" ]; then
230 BUILDER_VER="1" # A bootstrapping if you will 259 BUILDER_VER="1" # A bootstrapping if you will
231 else 260 else
232 BUILDER_VER=`perl -MModule::Build -e 'print "$Module::Build::VERSION;"' ` 261 BUILDER_VER=`perl -MModule::Build -e 'print "$Module::Build::VERSION;"' `
262 fi
233 fi 263 fi
234 fi 264 fi
235 fi
236 fi 265 fi
237 266
238 if [ -f /usr/bin/perl ] 267 if [ -f /usr/bin/perl ]
239 then 268 then
240 POD_DIR="/usr/share/perl/gentoo-pods/${version}" 269 POD_DIR="/usr/share/perl/gentoo-pods/${version}"
241 fi 270 fi
242} 271}
243 272
244fixlocalpod() { 273fixlocalpod() {
245 perlinfo 274 perlinfo
246 dodir ${POD_DIR}
247 275
248 if [ -f ${D}${ARCH_LIB}/perllocal.pod ]; 276 if [ -f ${D}${ARCH_LIB}/perllocal.pod ];
249 then 277 then
250 touch ${D}/${POD_DIR}/${P}.pod
251 sed -e "s:${D}::g" \
252 ${D}${ARCH_LIB}/perllocal.pod >> ${D}/${POD_DIR}/${P}.pod
253 touch ${D}/${POD_DIR}/${P}.pod.arch
254 cat ${D}/${POD_DIR}/${P}.pod >>${D}/${POD_DIR}/${P}.pod.arch
255 rm -f ${D}/${ARCH_LIB}/perllocal.pod 278 rm -f ${D}/${ARCH_LIB}/perllocal.pod
256 fi 279 fi
257 280
258 if [ -f ${D}${SITE_LIB}/perllocal.pod ]; 281 if [ -f ${D}${SITE_LIB}/perllocal.pod ];
259 then 282 then
260 touch ${D}/${POD_DIR}/${P}.pod
261 sed -e "s:${D}::g" \
262 ${D}${SITE_LIB}/perllocal.pod >> ${D}/${POD_DIR}/${P}.pod
263 touch ${D}/${POD_DIR}/${P}.pod.site
264 cat ${D}/${POD_DIR}/${P}.pod >>${D}/${POD_DIR}/${P}.pod.site
265 rm -f ${D}/${SITE_LIB}/perllocal.pod 283 rm -f ${D}/${SITE_LIB}/perllocal.pod
266 fi 284 fi
267 285
268 if [ -f ${D}${VENDOR_LIB}/perllocal.pod ]; 286 if [ -f ${D}${VENDOR_LIB}/perllocal.pod ];
269 then 287 then
270 touch ${D}/${POD_DIR}/${P}.pod
271 sed -e "s:${D}::g" \
272 ${D}${VENDOR_LIB}/perllocal.pod >> ${D}/${POD_DIR}/${P}.pod
273 touch ${D}/${POD_DIR}/${P}.pod.vendor
274 cat ${D}/${POD_DIR}/${P}.pod >>${D}/${POD_DIR}/${P}.pod.vendor
275 rm -f ${D}/${VENDOR_LIB}/perllocal.pod 288 rm -f ${D}/${VENDOR_LIB}/perllocal.pod
276 fi 289 fi
277} 290}
278 291
279updatepod() { 292updatepod() {
280 perlinfo 293 perlinfo
281 294
282 if [ -d "${POD_DIR}" ] 295 if [ -d "${POD_DIR}" ]
283 then 296 then
284 for FILE in `find ${POD_DIR} -type f -name "*.pod.arch"`; do 297 for FILE in `find ${POD_DIR} -type f -name "*.pod.arch"`; do
285 cat ${FILE} >> ${ARCH_LIB}/perllocal.pod 298 cat ${FILE} >> ${ARCH_LIB}/perllocal.pod
286 rm -f ${FILE} 299 rm -f ${FILE}
287 done 300 done
288 for FILE in `find ${POD_DIR} -type f -name "*.pod.site"`; do 301 for FILE in `find ${POD_DIR} -type f -name "*.pod.site"`; do
289 cat ${FILE} >> ${SITE_LIB}/perllocal.pod 302 cat ${FILE} >> ${SITE_LIB}/perllocal.pod
290 rm -f ${FILE} 303 rm -f ${FILE}
291 done 304 done
292 for FILE in `find ${POD_DIR} -type f -name "*.pod.vendor"`; do 305 for FILE in `find ${POD_DIR} -type f -name "*.pod.vendor"`; do
293 cat ${FILE} >> ${VENDOR_LIB}/perllocal.pod 306 cat ${FILE} >> ${VENDOR_LIB}/perllocal.pod
294 rm -f ${FILE} 307 rm -f ${FILE}
295 done 308 done
296 fi 309 fi
297} 310}

Legend:
Removed from v.1.86  
changed lines
  Added in v.1.111

  ViewVC Help
Powered by ViewVC 1.1.20