use vars qw($bootstrapping);
BEGIN {
- if (grep { /^--bootstrap(?:=(.*))?$/ } @ARGV) {
+ # watch out for fancy dashes. these can wind up in our @ARGV if the user is
+ # copypasting the bootstrap command from the POD displayed e.g. by perldoc
+ # on a Mac OS X terminal. since no software recognizes and handles these
+ # dashes, it's better to die loudly telling the user exactly what happened
+ # so they don't make the same mistake again rather than being the only
+ # program in the universe that works with them.
+ if(grep { /−/ } @ARGV) {
+ die <<'DEATH';
+WHOA THERE! It looks like you've got some fancy dashes in your commandline!
+These are *not* the traditional -- dashes that software recognizes. You
+probably got these by copy-pasting from the perldoc for this module as
+rendered by a UTF8-capable formatter. This most typically happens on an OS X
+terminal, but can happen elsewhere too. Please try again after replacing the
+dashes with normal minus signs.
+DEATH
+ }
+ if (my ($x) = grep { /^--bootstrap(?:=.*)?$/ } @ARGV) {
+ @ARGV = grep { !/^--bootstrap(?:=.*)?$/ } @ARGV;
$bootstrapping = 1;
+ $x =~ /^--bootstrap(?:=(.*))?$/;
my @args = (defined $1 ? ($1) : ());
{
local::lib->import(@args);
push(@ARGV,$ENV{PERL_MM_OPT});
+ push(@ARGV, map { "-I$_" } split(':',$ENV{PERL5LIB}));
system($^X, '-MExtUtils::MakeMaker 6.31', '-e1');
my $eumm = $? >> 8;
my $cpan = $? >> 8;
my $cpan_command = '';
+ system($^X, '-MCPAN', '-e',
+ 'my $done; require ExtUtils::MakeMaker;
+ my $orig = ExtUtils::MakeMaker->can("prompt");
+ *ExtUtils::MakeMaker::prompt = sub {
+ if (!$done && $_[0] =~ /manual configuration/) {
+ $done++;
+ return "no";
+ }
+ return $orig->(@_);
+ };
+ CPAN::Config->load;
+ unless ($done || -w $CPAN::Config->{keep_source_where}) {
+ my $save = $CPAN::Config->{urllist};
+ delete @{$CPAN::Config}{keys %$CPAN::Config};
+ $CPAN::Config->{urllist} = $save;
+ CPAN::Config->init;
+ }'
+ );
+
+ $ENV{PERL_MM_USE_DEFAULT} = 1;
+
# XXX - remove the force on EUMM once its test suite survive PERL_MM_OPT
if ($eumm) { # non-zero exit
$cpan_command .= 'force("install","ExtUtils::MakeMaker"); ';
}
if ($cpan) {
- $cpan_command .= 'install("CPAN"); ';
+ $cpan_command .= 'force("install","CPAN"); ';
}
if(length $cpan_command) {
system($^X, '-MCPAN', '-e', $cpan_command);
}
-
+ if ($cpan) {
+ system($^X, '-MCPAN', '-e', 'CPAN::Config->load; CPAN::Config->commit;');
+ }
}
}
requires 'Module::Build' => '0.28'; # lib -> lib/perl5 change
requires 'CPAN' => '1.80'; # sudo support
+# No, really. See
+# https://rt.cpan.org/Public/Bug/Display.html?id=23735
+# for why CPAN now sets the CPANPLUS env var.
+# trouble is this means we can't auto_install(_now) CPAN itself
+# without this beautiful hack
+
+my $no_cpanplus_env = !exists $ENV{PERL5_CPANPLUS_IS_RUNNING};
+require CPAN;
+delete $ENV{PERL5_CPANPLUS_IS_RUNNING} if $no_cpanplus_env;
+
if ($bootstrapping) {
auto_install_now;
} else {