X-Git-Url: http://git.shadowcat.co.uk/gitweb/gitweb.cgi?a=blobdiff_plain;f=Makefile.PL;h=11f376c1dfba6c7b08280c907463370b25f690fc;hb=59b1a634003229d22cc231e25980aeb561a01ee5;hp=8c4802b5fb6f68c0695316e2e201e889d1f33c54;hpb=1c9cde8ea186150ec281586cc0685641d205ea27;p=p5sagit%2Flocal-lib.git diff --git a/Makefile.PL b/Makefile.PL index 8c4802b..11f376c 100644 --- a/Makefile.PL +++ b/Makefile.PL @@ -28,7 +28,7 @@ if(exists $ENV{PERL_LL_TAR}) { $have_gtar ||= -x $ENV{PERL_LL_TAR}; } -die <<'DEATH' unless $has_gtar; +die <<'DEATH' unless $have_gtar; You are using Solaris (or another traditional Unix) that does not provide a sane tar, capable of dealing with the output of GNU tar. Please either set the PERL_LL_TAR environment variable to the location of a version of tar that @@ -92,7 +92,8 @@ DEATH my $cpan = $? >> 8; my $cpan_command = ''; - system($^X, '-MCPAN', '-e', + my $did_cpan_config = 0; + my $cpan_config_command = 'my $done; require ExtUtils::MakeMaker; my $orig = ExtUtils::MakeMaker->can("prompt"); *ExtUtils::MakeMaker::prompt = sub ($;$) { @@ -102,7 +103,8 @@ DEATH } return $orig->(@_); }; - $CPAN::Config->{urllist} = ["http://cpan.shadowcatprojects.net"]; + # not yet -- apeiron, 2010-03-10 + #$CPAN::Config->{urllist} = ["http://cpan.shadowcatprojects.net"]; # all bootstrapped fine on one DH account # on another, it tries to install man stuff into /usr/local # cannot for the life of me figure out why @@ -111,7 +113,7 @@ DEATH # ExtUtils::ParseXS uses Module::Build # but Module::Build depends on it # so you need to set prefer_installer MM - # so cpan uses EU::ParseXS' Makefile.PL + # so cpan uses EU::ParseXS Makefile.PL # since we already got EUMM, *that* works $CPAN::Config->{prefer_installer} = "EUMM"; CPAN::Config->load; @@ -120,8 +122,7 @@ DEATH delete @{$CPAN::Config}{keys %$CPAN::Config}; $CPAN::Config->{urllist} = $save; CPAN::Config->init; - }' - ); + }'; $ENV{PERL_MM_USE_DEFAULT} = 1; @@ -137,6 +138,8 @@ DEATH $cpan_command .= 'force("install","CPAN"); '; } if(length $cpan_command) { + system($^X, '-MCPAN', '-e', $cpan_config_command); + $did_cpan_config++; system($^X, '-MCPAN', '-e', $cpan_command); } if ($cpan) { @@ -146,6 +149,8 @@ DEATH # if we call this code directly, the changes get written to # $BOOTSTRAP/lib/perl5/CPAN/Config.pm, not where the user expects them to # be in their ~/.cpan/CPAN/MyConfig.pm. + system($^X, '-MCPAN', '-e', $cpan_config_command) + unless $did_cpan_config; system($^X, '-MCPAN', '-e', q[CPAN::HandleConfig->load;], @@ -171,9 +176,7 @@ all_from 'lib/local/lib.pm'; requires 'ExtUtils::MakeMaker' => '6.31'; # version INSTALL_BASE was added requires 'ExtUtils::Install' => '1.43'; # ditto -requires 'ExtUtils::CBuilder'; # this and ParseXS are needed for MB C_support -requires 'ExtUtils::ParseXS'; -requires 'Module::Build' => '0.28'; # lib -> lib/perl5 change +requires 'Module::Build' => '0.36'; # PERL_MB_OPT my $required_CPAN = '1.82'; requires 'CPAN' => $required_CPAN; # sudo support + CPAN::HandleConfig @@ -199,17 +202,27 @@ delete $ENV{PERL5_CPAN_IS_RUNNING} if $no_cpan_env; # It will already be installed by the time we reach here if bootstrapping, # otherwise, if we're running from CPAN then it will be installed soon # enough, and we'll come back here.. - if (!$@) { - CPAN::HandleConfig->load; - for my $eumm_setting ( qw/makepl_arg make_install_arg/ ) { - if ($CPAN::Config->{$eumm_setting} =~ /(?:PREFIX|INSTALL_BASE)/) { - die "Possibly invalid config detected in $eumm_setting: " . $CPAN::Config->{$eumm_setting}; + if (!$@ ) { + CPAN::HandleConfig->require_myconfig_or_config; + if ( $CPAN::Config ) { + for my $eumm_setting ( qw/makepl_arg make_install_arg/ ) { + if ($CPAN::Config->{$eumm_setting} =~ /(?:PREFIX|INSTALL_BASE)/) { + die <<"DEATH"; +WHOA THERE! It looks like you've got $CPAN::Config->{$eumm_setting} set. This is +known to cause problems with local::lib. Please either remove this setting or +clear out your .cpan directory. +DEATH + } } - } - for my $mb_setting (qw/mbuild_arg mbuild_install_arg mbuildpl_arg/) { - if ($CPAN::Config->{$mb_setting} =~ /(?:--prefix|--install_base)/) { - die "Possibly invalid config detected in $mb_setting: " . $CPAN::Config->{$mb_setting}; + for my $mb_setting (qw/mbuild_arg mbuild_install_arg mbuildpl_arg/) { + if ($CPAN::Config->{$mb_setting} =~ /(?:--prefix|--install_base)/) { + die <<"DEATH"; +WHOA THERE! It looks like you've got $CPAN::Config->{$mb_setting} set. This is +known to cause problems with local::lib. Please either remove this setting or +clear out your .cpan directory. +DEATH + } } } }