X-Git-Url: http://git.vpit.fr/?a=blobdiff_plain;f=lib%2FCPANPLUS%2FDist%2FGentoo.pm;h=032d46e886d97571db70ff7c328c1c67cc1aaa2b;hb=be982bd595059880773785ac66270369de53a309;hp=3d2e243b2a20de8a9e163ffce29dbd668774a6af;hpb=490a3ebfbbcc96fa3635b9a83408f26d9bedd4f8;p=perl%2Fmodules%2FCPANPLUS-Dist-Gentoo.git diff --git a/lib/CPANPLUS/Dist/Gentoo.pm b/lib/CPANPLUS/Dist/Gentoo.pm index 3d2e243..032d46e 100644 --- a/lib/CPANPLUS/Dist/Gentoo.pm +++ b/lib/CPANPLUS/Dist/Gentoo.pm @@ -26,15 +26,15 @@ CPANPLUS::Dist::Gentoo - CPANPLUS backend generating Gentoo ebuilds. =head1 VERSION -Version 0.10 +Version 0.11 =cut -our $VERSION = '0.10'; +our $VERSION = '0.11'; =head1 SYNOPSIS - # Using default values from your F + # Using default values from your make.conf cpan2dist --format=CPANPLUS::Dist::Gentoo --buildprereq Some::Module # Specifying your own options @@ -47,9 +47,9 @@ our $VERSION = '0.10'; --dist-opts footer="# End" \ Any::Module You::Like -=head1 DESCRPITON +=head1 DESCRIPTION -This module is a CPANPLUS backend that recursively generates Gentoo ebuilds for a given package in the specified overlay (defaults to F), updates the manifest, and even emerges it (together with its dependencies) if the user requires it. +This module is a CPANPLUS backend that recursively generates Gentoo ebuilds for a given package in the default overlay, updates the manifest, and even emerges it (together with its dependencies) if the user requires it. The generated ebuilds are placed into the C category. They favour depending on a C, on C, C or C (in that order) rather than C. @@ -121,6 +121,7 @@ L itself takes other options, most notably : =item * C<--buildprereq> generates an ebuild for every dependency, even for those that are already up-to-date. +Setting this option is recommended. =item * @@ -128,6 +129,10 @@ C<--force> forcefully regenerates ebuilds even if they already exist. =item * +C<--install> installs the ebuilds after generating them. + +=item * + C<--skiptest> skips tests while building, which speeds up the building process. =item * @@ -169,13 +174,13 @@ If you still have C C<5.8.x>, you can upgrade it by running the following Then, fetch the L tarball : $ cd /tmp - $ wget http://search.cpan.org/CPAN/authors/id/V/VP/VPIT/CPANPLUS-Dist-Gentoo-0.10.tar.gz + $ wget http://search.cpan.org/CPAN/authors/id/V/VP/VPIT/CPANPLUS-Dist-Gentoo-0.11.tar.gz Log in as root and unpack it in e.g. your home directory : # cd - # tar xzf /tmp/CPANPLUS-Dist-Gentoo-0.10.tar.gz - # cd CPANPLUS-Dist-Gentoo-0.10 + # tar xzf /tmp/CPANPLUS-Dist-Gentoo-0.11.tar.gz + # cd CPANPLUS-Dist-Gentoo-0.11 Bootstrap L using the bundled shell script C : @@ -218,6 +223,15 @@ my $format_available; sub format_available { return $format_available if defined $format_available; + unless (IPC::Cmd->can_capture_buffer) { + my $msg = 'IPC::Cmd must be able to capture buffers.'; + unless (do { local $@; eval { require IPC::Run; 1 } }) { + $msg .= ' Try installing IPC::Run (dev-perl/IPC-Run on Gentoo).'; + } + __PACKAGE__->_abort($msg); + return $format_available = 0; + } + for my $prog (qw) { unless (IPC::Cmd::can_run($prog)) { __PACKAGE__->_abort("$prog is required to write ebuilds"); @@ -225,7 +239,7 @@ sub format_available { } } - if (IPC::Cmd->can_capture_buffer) { + { my $buffers; my ($success, $errmsg) = IPC::Cmd::run( command => [ qw ],