diff options
author | Marcin Juszkiewicz <hrw@openedhand.com> | 2007-05-30 09:32:36 +0000 |
---|---|---|
committer | Marcin Juszkiewicz <hrw@openedhand.com> | 2007-05-30 09:32:36 +0000 |
commit | 6c47cd48aff1dbc3b2550ea71307c48debca9298 (patch) | |
tree | 96e18b82c2f72e76c3c1ddbc148c7ef2fbf56ad7 /meta/classes/cpan_build.bbclass | |
parent | 4ed25e747d7a5a636d9e517b59601ff66f1d6c15 (diff) | |
download | openembedded-core-6c47cd48aff1dbc3b2550ea71307c48debca9298.tar.gz openembedded-core-6c47cd48aff1dbc3b2550ea71307c48debca9298.tar.bz2 openembedded-core-6c47cd48aff1dbc3b2550ea71307c48debca9298.tar.xz openembedded-core-6c47cd48aff1dbc3b2550ea71307c48debca9298.zip |
cpan classes: sync Perl with OE
git-svn-id: https://svn.o-hand.com/repos/poky/trunk@1815 311d38ba-8fff-0310-9ca6-ca027cbcb966
Diffstat (limited to 'meta/classes/cpan_build.bbclass')
-rw-r--r-- | meta/classes/cpan_build.bbclass | 70 |
1 files changed, 70 insertions, 0 deletions
diff --git a/meta/classes/cpan_build.bbclass b/meta/classes/cpan_build.bbclass new file mode 100644 index 000000000..63e716c09 --- /dev/null +++ b/meta/classes/cpan_build.bbclass @@ -0,0 +1,70 @@ +# +# This is for perl modules that use the new Build.PL build system +# +inherit cpan-base + +INHIBIT_NATIVE_STAGE_INSTALL = "1" + +# +# We also need to have built libmodule-build-perl-native for +# everything except libmodule-build-perl-native itself (which uses +# this class, but uses itself as the provider of +# libmodule-build-perl) +# +def cpan_build_dep_prepend(d): + import bb; + if bb.data.getVar('CPAN_BUILD_DEPS', d, 1): + return '' + pn = bb.data.getVar('PN', d, 1) + if pn in ['libmodule-build-perl', 'libmodule-build-perl-native']: + return '' + return 'libmodule-build-perl-native ' + +DEPENDS_prepend = "${@cpan_build_dep_prepend(d)}" + +cpan_build_do_configure () { + if [ ${@is_target(d)} == "yes" ]; then + # build for target + . ${STAGING_DIR}/${TARGET_SYS}/perl/config.sh + if [ "${IS_NEW_PERL}" = "yes" ]; then + perl Build.PL --installdirs vendor \ + --destdir ${D} \ + --install_path lib="${datadir}/perl5" \ + --install_path arch="${libdir}/perl5" \ + --install_path script=${bindir} \ + --install_path bin=${bindir} \ + --install_path bindoc=${mandir}/man1 \ + --install_path libdoc=${mandir}/man3 + else + perl Build.PL --installdirs vendor \ + --destdir ${D} \ + --install_path lib="${libdir}/perl5/site_perl/${version}" \ + --install_path arch="${libdir}/perl5/site_perl/${version}/${TARGET_SYS}" \ + --install_path script=${bindir} \ + --install_path bin=${bindir} \ + --install_path bindoc=${mandir}/man1 \ + --install_path libdoc=${mandir}/man3 + fi + else + # build for host + perl Build.PL --installdirs site + fi +} + +cpan_build_do_compile () { + perl Build +} + +cpan_build_do_install () { + if [ ${@is_target(d)} == "yes" ]; then + perl Build install + fi +} + +do_stage_append () { + if [ ${@is_target(d)} == "no" ]; then + perl Build install + fi +} + +EXPORT_FUNCTIONS do_configure do_compile do_install |