diff options
author | Steve Peters <steve@fisharerojo.org> | 2006-09-12 15:30:57 +0000 |
---|---|---|
committer | Steve Peters <steve@fisharerojo.org> | 2006-09-12 15:30:57 +0000 |
commit | 8962fc49433b904c85e0ec947ec7e1d19c26eb99 (patch) | |
tree | d689ae034f7b1394a1a105f64be8b6d1611d4699 /lib/CPAN | |
parent | 58d3253823637a1fee2c1c8064022162bc9d6374 (diff) | |
download | perl-8962fc49433b904c85e0ec947ec7e1d19c26eb99.tar.gz |
Upgrade to CPAN-1.87_62
p4raw-id: //depot/perl@28826
Diffstat (limited to 'lib/CPAN')
-rw-r--r-- | lib/CPAN/FirstTime.pm | 884 | ||||
-rw-r--r-- | lib/CPAN/HandleConfig.pm | 36 |
2 files changed, 592 insertions, 328 deletions
diff --git a/lib/CPAN/FirstTime.pm b/lib/CPAN/FirstTime.pm index 9d39282b80..946ca24eec 100644 --- a/lib/CPAN/FirstTime.pm +++ b/lib/CPAN/FirstTime.pm @@ -2,7 +2,7 @@ package CPAN::Mirrored::By; use strict; use vars qw($VERSION); -$VERSION = sprintf "%.6f", substr(q$Rev: 742 $,4)/1000000 + 5.4; +$VERSION = sprintf "%.6f", substr(q$Rev: 819 $,4)/1000000 + 5.4; sub new { my($self,@arg) = @_; @@ -20,8 +20,8 @@ use FileHandle (); use File::Basename (); use File::Path (); use File::Spec; -use vars qw($VERSION); -$VERSION = sprintf "%.6f", substr(q$Rev: 742 $,4)/1000000 + 5.4; +use vars qw($VERSION $urllist); +$VERSION = sprintf "%.6f", substr(q$Rev: 819 $,4)/1000000 + 5.4; =head1 NAME @@ -46,6 +46,16 @@ sub init { use Config; # extra arg in 'o conf init make' selects only $item =~ /make/ my $matcher = $args{args} && @{$args{args}} ? $args{args}[0] : ''; + if ($matcher =~ /^\w+$/) { + if ( + exists $CPAN::HandleConfig::keys{$matcher} + ) { + $matcher = "\\b$matcher\\b"; + } else { + $CPAN::Frontend->myprint("'$matcher' is not a valid configuration variable"); + return; + } + } CPAN->debug("matcher[$matcher]") if $CPAN::DEBUG; unless ($CPAN::VERSION) { @@ -61,19 +71,26 @@ sub init { my($ans,$default); # - # Files, directories + #= Files, directories # - print $prompts{manual_config}; + unless ($matcher) { + $CPAN::Frontend->myprint($prompts{manual_config}); + } my $manual_conf; - local *_real_prompt = \&ExtUtils::MakeMaker::prompt; + local *_real_prompt = \&CPAN::Shell::colorable_makemaker_prompt; if ( $args{autoconfig} ) { $manual_conf = "no"; + } elsif ($matcher) { + $manual_conf = "yes"; } else { - $manual_conf = prompt("Are you ready for manual configuration?", "yes"); + my $_conf = prompt("Would you like me to configure as much as possible ". + "automatically?", "yes"); + $manual_conf = ($_conf and $_conf =~ /^y/i) ? "no" : "yes"; } + CPAN->debug("manual_conf[$manual_conf]") if $CPAN::DEBUG; my $fastread; { if ($manual_conf =~ /^y/i) { @@ -84,259 +101,258 @@ sub init { local $^W = 0; # prototype should match that of &MakeMaker::prompt + my $current_second = time; + my $current_second_count = 0; + my $i_am_mad = 0; *_real_prompt = sub ($;$) { my($q,$a) = @_; my($ret) = defined $a ? $a : ""; $CPAN::Frontend->myprint(sprintf qq{%s [%s]\n\n}, $q, $ret); eval { require Time::HiRes }; unless ($@) { - Time::HiRes::sleep(0.1); + if (time == $current_second) { + $current_second_count++; + if ($current_second_count > 20) { + # I don't like more than 20 prompts per second + $i_am_mad++; + } + } else { + $current_second = time; + $current_second_count = 0; + $i_am_mad-- if $i_am_mad>0; + } + if ($i_am_mad>0){ + #require Carp; + #Carp::cluck("SLEEEEEEEEPIIIIIIIIIIINGGGGGGGGGGG"); + Time::HiRes::sleep(0.1); + } } $ret; }; } } - $CPAN::Frontend->myprint($prompts{config_intro}) - if !$matcher or 'config_intro' =~ /$matcher/; + if (!$matcher or 'cpan_home keep_source_where build_dir' =~ /$matcher/){ + $CPAN::Frontend->myprint($prompts{config_intro}); - my $cpan_home = $CPAN::Config->{cpan_home} - || File::Spec->catdir($ENV{HOME}, ".cpan"); + if (!$matcher or 'cpan_home' =~ /$matcher/) { + my $cpan_home = $CPAN::Config->{cpan_home} + || File::Spec->catdir($ENV{HOME}, ".cpan"); - if (-d $cpan_home) { - if (!$matcher or 'config_intro' =~ /$matcher/) { - $CPAN::Frontend->myprint(qq{ + if (-d $cpan_home) { + $CPAN::Frontend->myprint(qq{ I see you already have a directory $cpan_home Shall we use it as the general CPAN build and cache directory? }); - } - } else { - # no cpan-home, must prompt and get one - $CPAN::Frontend->myprint($prompts{cpan_home_where}); - } - - $default = $cpan_home; - while ($ans = prompt("CPAN build and cache directory?",$default)) { - unless (File::Spec->file_name_is_absolute($ans)) { - require Cwd; - my $cwd = Cwd::cwd(); - my $absans = File::Spec->catdir($cwd,$ans); - warn "The path '$ans' is not an absolute path. Please specify an absolute path\n"; - $default = $absans; - next; - } - eval { File::Path::mkpath($ans); }; # dies if it can't - if ($@) { - warn "Couldn't create directory $ans.\nPlease retry.\n"; - next; - } - if (-d $ans && -w _) { - last; - } else { - warn "Couldn't find directory $ans\n" - . "or directory is not writable. Please retry.\n"; - } - } - $CPAN::Config->{cpan_home} = $ans; + } else { + # no cpan-home, must prompt and get one + $CPAN::Frontend->myprint($prompts{cpan_home_where}); + } - $CPAN::Frontend->myprint($prompts{keep_source_where}); + $default = $cpan_home; + while ($ans = prompt("CPAN build and cache directory?",$default)) { + unless (File::Spec->file_name_is_absolute($ans)) { + require Cwd; + my $cwd = Cwd::cwd(); + my $absans = File::Spec->catdir($cwd,$ans); + $CPAN::Frontend->mywarn("The path '$ans' is not an ". + "absolute path. Please specify ". + "an absolute path\n"); + $default = $absans; + next; + } + eval { File::Path::mkpath($ans); }; # dies if it can't + if ($@) { + $CPAN::Frontend->mywarn("Couldn't create directory $ans.\n". + "Please retry.\n"); + next; + } + if (-d $ans && -w _) { + last; + } else { + $CPAN::Frontend->mywarn("Couldn't find directory $ans\n". + "or directory is not writable. Please retry.\n"); + } + } + $CPAN::Config->{cpan_home} = $ans; + } - $CPAN::Config->{keep_source_where} - = File::Spec->catdir($CPAN::Config->{cpan_home},"sources"); + if (!$matcher or 'keep_source_where' =~ /$matcher/) { + my_dflt_prompt("keep_source_where", + File::Spec->catdir($CPAN::Config->{cpan_home},"sources"), + $matcher, + ); + } - $CPAN::Config->{build_dir} - = File::Spec->catdir($CPAN::Config->{cpan_home},"build"); + if (!$matcher or 'build_dir' =~ /$matcher/) { + my_dflt_prompt("build_dir", + File::Spec->catdir($CPAN::Config->{cpan_home},"build"), + $matcher + ); + } + } # - # Cache size, Index expire + #= Cache size, Index expire # - $CPAN::Frontend->myprint($prompts{build_cache_intro}) - if !$matcher or 'build_cache_intro' =~ /$matcher/; - - # large enough to build large dists like Tk - my_dflt_prompt(build_cache => 100, $matcher); + if (!$matcher or 'build_cache' =~ /$matcher/){ + $CPAN::Frontend->myprint($prompts{build_cache_intro}); - # XXX This the time when we refetch the index files (in days) - $CPAN::Config->{'index_expire'} = 1; - - $CPAN::Frontend->myprint($prompts{scan_cache_intro}) - if !$matcher or 'build_cache_intro' =~ /$matcher/; - - my_prompt_loop(scan_cache => 'atstart', $matcher, 'atstart|never'); - - # - # cache_metadata - # - - if (!$matcher or 'build_cache_intro' =~ /$matcher/) { + # large enough to build large dists like Tk + my_dflt_prompt(build_cache => 100, $matcher); + } - $CPAN::Frontend->myprint($prompts{cache_metadata}); + if (!$matcher or 'index_expire' =~ /$matcher/) { + $CPAN::Frontend->myprint($prompts{index_expire_intro}); - defined($default = $CPAN::Config->{cache_metadata}) or $default = 1; - do { - $ans = prompt("Cache metadata (yes/no)?", ($default ? 'yes' : 'no')); - } while ($ans !~ /^[yn]/i); - $CPAN::Config->{cache_metadata} = ($ans =~ /^y/i ? 1 : 0); + my_dflt_prompt(index_expire => 1, $matcher); } - # - # term_is_latin - # - $CPAN::Frontend->myprint($prompts{term_is_latin}) - if !$matcher or 'term_is_latin' =~ /$matcher/; + if (!$matcher or 'scan_cache' =~ /$matcher/){ + $CPAN::Frontend->myprint($prompts{scan_cache_intro}); - defined($default = $CPAN::Config->{term_is_latin}) or $default = 1; - do { - $ans = prompt("Your terminal expects ISO-8859-1 (yes/no)?", - ($default ? 'yes' : 'no')); - } while ($ans !~ /^[yn]/i); - $CPAN::Config->{term_is_latin} = ($ans =~ /^y/i ? 1 : 0); + my_prompt_loop(scan_cache => 'atstart', $matcher, 'atstart|never'); + } # - # save history in file 'histfile' + #= cache_metadata # - $CPAN::Frontend->myprint($prompts{histfile_intro}); - - defined($default = $CPAN::Config->{histfile}) or - $default = File::Spec->catfile($CPAN::Config->{cpan_home},"histfile"); - $ans = prompt("File to save your history?", $default); - $CPAN::Config->{histfile} = $ans; - - if ($CPAN::Config->{histfile}) { - defined($default = $CPAN::Config->{histsize}) or $default = 100; - $ans = prompt("Number of lines to save?", $default); - $CPAN::Config->{histsize} = $ans; - } + my_yn_prompt(cache_metadata => 1, $matcher); # - # do an ls on the m or the d command + #= Do we follow PREREQ_PM? # - $CPAN::Frontend->myprint($prompts{show_upload_date_intro}); - defined($default = $CPAN::Config->{show_upload_date}) or - $default = 'n'; - $ans = prompt("Always try to show upload date with 'd' and 'm' command (yes/no)?", - ($default ? 'yes' : 'no')); - $CPAN::Config->{show_upload_date} = ($ans =~ /^[y1]/i ? 1 : 0); + if (!$matcher or 'prerequisites_policy' =~ /$matcher/){ + $CPAN::Frontend->myprint($prompts{prerequisites_policy_intro}); - #my_prompt_loop(show_upload_date => 'n', $matcher, - #'follow|ask|ignore'); + my_prompt_loop(prerequisites_policy => 'ask', $matcher, + 'follow|ask|ignore'); + } # - # prerequisites_policy - # Do we follow PREREQ_PM? + #= Module::Signature # - - $CPAN::Frontend->myprint($prompts{prerequisites_policy_intro}) - if !$matcher or 'prerequisites_policy_intro' =~ /$matcher/; - - my_prompt_loop(prerequisites_policy => 'ask', $matcher, - 'follow|ask|ignore'); - + if (!$matcher or 'check_sigs' =~ /$matcher/) { + my_yn_prompt(check_sigs => 0, $matcher); + } # - # Module::Signature + #= CPAN::Reporter # - $CPAN::Frontend->myprint($prompts{check_sigs_intro}); - - defined($default = $CPAN::Config->{check_sigs}) or - $default = 0; - $ans = prompt($prompts{check_sigs}, - ($default ? 'yes' : 'no')); - $CPAN::Config->{check_sigs} = ($ans =~ /^y/i ? 1 : 0); + if (!$matcher or 'test_report' =~ /$matcher/) { + my_yn_prompt(test_report => 0, $matcher); + if ( + $CPAN::Config->{test_report} && + $CPAN::META->has_inst("CPAN::Reporter") && + CPAN::Reporter->can('configure') + ) { + $CPAN::Frontend->myprint("\nProceeding to configure CPAN::Reporter.\n"); + CPAN::Reporter::configure(); + $CPAN::Frontend->myprint("\nReturning to CPAN configuration.\n"); + } + } # - # External programs + #= External programs # - $CPAN::Frontend->myprint($prompts{external_progs}) - if !$matcher or 'external_progs' =~ /$matcher/; - - my $old_warn = $^W; - local $^W if $^O eq 'MacOS'; - my(@path) = split /$Config{'path_sep'}/, $ENV{'PATH'}; - local $^W = $old_warn; - my $progname; - for $progname (qw/bzip2 gzip tar unzip make + my @external_progs = qw/bzip2 gzip tar unzip make curl lynx wget ncftpget ncftp ftp - gpg/) - { - if ($^O eq 'MacOS') { - $CPAN::Config->{$progname} = 'not_here'; - next; - } - next if $matcher && $progname !~ /$matcher/; - - my $progcall = $progname; - # we don't need ncftp if we have ncftpget - next if $progname eq "ncftp" && $CPAN::Config->{ncftpget} gt " "; - my $path = $CPAN::Config->{$progname} - || $Config::Config{$progname} - || ""; - if (File::Spec->file_name_is_absolute($path)) { - # testing existence is not good enough, some have these exe - # extensions - - # warn "Warning: configured $path does not exist\n" unless -e $path; - # $path = ""; - } elsif ($path =~ /^\s+$/) { - # preserve disabled programs - } else { - $path = ''; - } - unless ($path) { - # e.g. make -> nmake - $progcall = $Config::Config{$progname} if $Config::Config{$progname}; - } + gpg/; + my(@path) = split /$Config{'path_sep'}/, $ENV{'PATH'}; + if (!$matcher or "@external_progs" =~ /$matcher/) { + $CPAN::Frontend->myprint($prompts{external_progs}); + + my $old_warn = $^W; + local $^W if $^O eq 'MacOS'; + local $^W = $old_warn; + my $progname; + for $progname (@external_progs) { + if ($^O eq 'MacOS') { + $CPAN::Config->{$progname} = 'not_here'; + next; + } + next if $matcher && $progname !~ /$matcher/; + + my $progcall = $progname; + # we don't need ncftp if we have ncftpget + next if $progname eq "ncftp" && $CPAN::Config->{ncftpget} gt " "; + my $path = $CPAN::Config->{$progname} + || $Config::Config{$progname} + || ""; + if (File::Spec->file_name_is_absolute($path)) { + # testing existence is not good enough, some have these exe + # extensions + + # warn "Warning: configured $path does not exist\n" unless -e $path; + # $path = ""; + } elsif ($path =~ /^\s+$/) { + # preserve disabled programs + } else { + $path = ''; + } + unless ($path) { + # e.g. make -> nmake + $progcall = $Config::Config{$progname} if $Config::Config{$progname}; + } - $path ||= find_exe($progcall,[@path]); - $CPAN::Frontend->mywarn("Warning: $progcall not found in PATH\n") unless - $path; # not -e $path, because find_exe already checked that - $ans = prompt("Where is your $progname program?",$path) || $path; - $CPAN::Config->{$progname} = $ans; + $path ||= find_exe($progcall,[@path]); + $CPAN::Frontend->mywarn("Warning: $progcall not found in PATH\n") unless + $path; # not -e $path, because find_exe already checked that + $ans = prompt("Where is your $progname program?",$path) || $path; + $CPAN::Config->{$progname} = $ans; + } } - my $path = $CPAN::Config->{'pager'} || - $ENV{PAGER} || find_exe("less",[@path]) || - find_exe("more",[@path]) || ($^O eq 'MacOS' ? $ENV{EDITOR} : 0 ) - || "more"; - $ans = prompt("What is your favorite pager program?",$path); - $CPAN::Config->{'pager'} = $ans; - $path = $CPAN::Config->{'shell'}; - if (File::Spec->file_name_is_absolute($path)) { - warn "Warning: configured $path does not exist\n" unless -e $path; - $path = ""; + + if (!$matcher or 'pager' =~ /$matcher/) { + my $path = $CPAN::Config->{'pager'} || + $ENV{PAGER} || find_exe("less",[@path]) || + find_exe("more",[@path]) || ($^O eq 'MacOS' ? $ENV{EDITOR} : 0 ) + || "more"; + $ans = prompt("What is your favorite pager program?",$path); + $CPAN::Config->{'pager'} = $ans; } - $path ||= $ENV{SHELL}; - $path ||= $ENV{COMSPEC} if $^O eq "MSWin32"; - if ($^O eq 'MacOS') { - $CPAN::Config->{'shell'} = 'not_here'; - } else { - $path =~ s,\\,/,g if $^O eq 'os2'; # Cosmetic only - $ans = prompt("What is your favorite shell?",$path); - $CPAN::Config->{'shell'} = $ans; + + if (!$matcher or 'shell' =~ /$matcher/) { + my $path = $CPAN::Config->{'shell'}; + if (File::Spec->file_name_is_absolute($path)) { + $CPAN::Frontend->mywarn("Warning: configured $path does not exist\n") + unless -e $path; + $path = ""; + } + $path ||= $ENV{SHELL}; + $path ||= $ENV{COMSPEC} if $^O eq "MSWin32"; + if ($^O eq 'MacOS') { + $CPAN::Config->{'shell'} = 'not_here'; + } else { + $path =~ s,\\,/,g if $^O eq 'os2'; # Cosmetic only + $ans = prompt("What is your favorite shell?",$path); + $CPAN::Config->{'shell'} = $ans; + } } # - # Arguments to make etc. + #= Installer, arguments to make etc. # - $CPAN::Frontend->myprint($prompts{prefer_installer_intro}) - if !$matcher or 'prerequisites_policy_intro' =~ /$matcher/; - - my_prompt_loop(prefer_installer => 'EUMM', $matcher, 'MB|EUMM'); + if (!$matcher or 'prefer_installer' =~ /$matcher/){ + $CPAN::Frontend->myprint($prompts{prefer_installer_intro}); + my_prompt_loop(prefer_installer => 'EUMM', $matcher, 'MB|EUMM'); + } - $CPAN::Frontend->myprint($prompts{makepl_arg_intro}) - if !$matcher or 'makepl_arg_intro' =~ /$matcher/; - - my_dflt_prompt(makepl_arg => "", $matcher); + if (!$matcher or 'makepl_arg make_arg' =~ /$matcher/){ + $CPAN::Frontend->myprint($prompts{makepl_arg_intro}); - my_dflt_prompt(make_arg => "", $matcher); + my_dflt_prompt(makepl_arg => "", $matcher); + my_dflt_prompt(make_arg => "", $matcher); + } require CPAN::HandleConfig; if (exists $CPAN::HandleConfig::keys{make_install_make_command}) { @@ -349,12 +365,13 @@ Shall we use it as the general CPAN build and cache directory? my_dflt_prompt(make_install_arg => $CPAN::Config->{make_arg} || "", $matcher); - $CPAN::Frontend->myprint($prompts{mbuildpl_arg_intro}) - if !$matcher or 'mbuildpl_arg_intro' =~ /$matcher/; + if (!$matcher or 'mbuildpl_arg mbuild_arg' =~ /$matcher/){ + $CPAN::Frontend->myprint($prompts{mbuildpl_arg_intro}); - my_dflt_prompt(mbuildpl_arg => "", $matcher); + my_dflt_prompt(mbuildpl_arg => "", $matcher); - my_dflt_prompt(mbuild_arg => "", $matcher); + my_dflt_prompt(mbuild_arg => "", $matcher); + } if (exists $CPAN::HandleConfig::keys{mbuild_install_build_command}) { # as long as Windows needs $self->_build_command, we cannot @@ -365,67 +382,168 @@ Shall we use it as the general CPAN build and cache directory? my_dflt_prompt(mbuild_install_arg => "", $matcher); # - # Alarm period + #= Alarm period + # + + if (!$matcher or 'inactivity_timeout' =~ /$matcher/) { + $CPAN::Frontend->myprint($prompts{inactivity_timeout_intro}); + $default = $CPAN::Config->{inactivity_timeout} || 0; + $CPAN::Config->{inactivity_timeout} = + prompt("Timeout for inactivity during {Makefile,Build}.PL?",$default); + } + + # + #= Proxies # - $CPAN::Frontend->myprint($prompts{inactivity_timeout_intro}) - if !$matcher or 'inactivity_timeout_intro' =~ /$matcher/; + my @proxy_vars = qw/ftp_proxy http_proxy no_proxy/; + my @proxy_user_vars = qw/proxy_user proxy_pass/; + if (!$matcher or "@proxy_vars @proxy_user_vars" =~ /$matcher/){ + $CPAN::Frontend->myprint($prompts{proxy_intro}); - # my_dflt_prompt(inactivity_timeout => 0); + for (@proxy_vars) { + if (!$matcher or /$matcher/){ + $default = $CPAN::Config->{$_} || $ENV{$_} || ""; + $CPAN::Config->{$_} = prompt("Your $_?",$default); + } + } - $default = $CPAN::Config->{inactivity_timeout} || 0; - $CPAN::Config->{inactivity_timeout} = - prompt("Timeout for inactivity during {Makefile,Build}.PL?",$default); + if ($CPAN::Config->{ftp_proxy} || + $CPAN::Config->{http_proxy}) { - # Proxies + $default = $CPAN::Config->{proxy_user} || $CPAN::LWP::UserAgent::USER || ""; - $CPAN::Frontend->myprint($prompts{proxy_intro}) - if !$matcher or 'proxy_intro' =~ /$matcher/; + $CPAN::Frontend->myprint($prompts{proxy_user}); - for (qw/ftp_proxy http_proxy no_proxy/) { - next if $matcher and $_ =~ /$matcher/; + if ($CPAN::Config->{proxy_user} = prompt("Your proxy user id?",$default)) { + $CPAN::Frontend->myprint($prompts{proxy_pass}); - $default = $CPAN::Config->{$_} || $ENV{$_}; - $CPAN::Config->{$_} = prompt("Your $_?",$default); + if ($CPAN::META->has_inst("Term::ReadKey")) { + Term::ReadKey::ReadMode("noecho"); + } else { + $CPAN::Frontend->myprint($prompts{password_warn}); + } + $CPAN::Config->{proxy_pass} = prompt_no_strip("Your proxy password?"); + if ($CPAN::META->has_inst("Term::ReadKey")) { + Term::ReadKey::ReadMode("restore"); + } + $CPAN::Frontend->myprint("\n\n"); + } + } } - if ($CPAN::Config->{ftp_proxy} || - $CPAN::Config->{http_proxy}) { + # + #= how FTP works + # - $default = $CPAN::Config->{proxy_user} || $CPAN::LWP::UserAgent::USER; + my_yn_prompt(ftp_passive => 1, $matcher); - $CPAN::Frontend->myprint($prompts{proxy_user}); + # + #= how cwd works + # - if ($CPAN::Config->{proxy_user} = prompt("Your proxy user id?",$default)) { - $CPAN::Frontend->myprint($prompts{proxy_pass}); + if (!$matcher or 'getcwd' =~ /$matcher/){ + $CPAN::Frontend->myprint($prompts{getcwd_intro}); - if ($CPAN::META->has_inst("Term::ReadKey")) { - Term::ReadKey::ReadMode("noecho"); - } else { - $CPAN::Frontend->myprint($prompts{password_warn}); - } - $CPAN::Config->{proxy_pass} = prompt_no_strip("Your proxy password?"); - if ($CPAN::META->has_inst("Term::ReadKey")) { - Term::ReadKey::ReadMode("restore"); + my_prompt_loop(getcwd => 'cwd', $matcher, + 'cwd|getcwd|fastcwd|backtickcwd'); + } + + # + #= the CPAN shell itself + # + + my_yn_prompt(commandnumber_in_prompt => 1, $matcher); + my_yn_prompt(term_ornaments => 1, $matcher); + if ("colorize_output colorize_print colorize_warn" =~ $matcher) { + my_yn_prompt(colorize_output => 0, $matcher); + if ($CPAN::Config->{colorize_output}) { + for my $tuple ( + ["colorize_print", "bold blue"], + ["colorize_warn", "bold red"], + ) { + my_dflt_prompt($tuple->[0] => $tuple->[1], $matcher); + if ($CPAN::META->has_inst("Term::ANSIColor")) { + eval { Term::ANSIColor::color($CPAN::Config->{$tuple->[0]})}; + if ($@) { + $CPAN::Config->{$tuple->[0]} = $tuple->[1]; + $CPAN::Frontend->mywarn($@."setting to default '$tuple->[1]'\n"); + } + } } - $CPAN::Frontend->myprint("\n\n"); } } # - # MIRRORED.BY + #== term_is_latin + # + + if (!$matcher or 'term_is_latin' =~ /$matcher/){ + $CPAN::Frontend->myprint($prompts{term_is_latin}); + my_yn_prompt(term_is_latin => 1, $matcher); + } + + # + #== save history in file 'histfile' + # + + if (!$matcher or 'histfile histsize' =~ /$matcher/) { + $CPAN::Frontend->myprint($prompts{histfile_intro}); + defined($default = $CPAN::Config->{histfile}) or + $default = File::Spec->catfile($CPAN::Config->{cpan_home},"histfile"); + $ans = prompt("File to save your history?", $default); + $CPAN::Config->{histfile} = $ans; + + if ($CPAN::Config->{histfile}) { + defined($default = $CPAN::Config->{histsize}) or $default = 100; + $ans = prompt("Number of lines to save?", $default); + $CPAN::Config->{histsize} = $ans; + } + } + + # + #== do an ls on the m or the d command + # + if (!$matcher or 'show_upload_date' =~ /$matcher/) { + $CPAN::Frontend->myprint($prompts{show_upload_date_intro}); + + defined($default = $CPAN::Config->{show_upload_date}) or + $default = 'n'; + $ans = prompt("Always try to show upload date with 'd' and 'm' command (yes/no)?", + ($default ? 'yes' : 'no')); + $CPAN::Config->{show_upload_date} = ($ans =~ /^[y1]/i ? 1 : 0); + } + + # + #= MIRRORED.BY and conf_sites() # - conf_sites() unless $fastread; + if ($matcher){ + if ("urllist" =~ $matcher) { + # conf_sites would go into endless loop with the smash prompt + local *_real_prompt; + *_real_prompt = \&CPAN::Shell::colorable_makemaker_prompt; + conf_sites(); + } + } elsif ($fastread) { + $CPAN::Frontend->myprint("Autoconfigured everything but 'urllist'.\n". + "Please call 'o conf init urllist' to configure ". + "your CPAN server(s) now!"); + } else { + conf_sites(); + } - # We don't ask these now, the defaults are very likely OK. + # We don't ask this one now, it's plain silly and maybe is not + # even used correctly everywhere. $CPAN::Config->{inhibit_startup_message} = 0; - $CPAN::Config->{getcwd} = 'cwd'; - $CPAN::Config->{ftp_passive} = 1; - $CPAN::Config->{term_ornaments} = 1; $CPAN::Frontend->myprint("\n\n"); - CPAN::HandleConfig->commit($configpm); + if ($matcher) { + $CPAN::Frontend->myprint("Please remember to call 'o conf commit' to ". + "make the config permanent!\n\n"); + } else { + CPAN::HandleConfig->commit($configpm); + } } sub my_dflt_prompt { @@ -440,6 +558,23 @@ sub my_dflt_prompt { } } +sub my_yn_prompt { + my ($item, $dflt, $m) = @_; + my $default; + defined($default = $CPAN::Config->{$item}) or $default = $dflt; + + $DB::single = 1; + if (!$m || $item =~ /$m/) { + if (my $intro = $prompts{$item . "_intro"}) { + $CPAN::Frontend->myprint($intro); + } + my $ans = prompt($prompts{$item}, $default ? 'yes' : 'no'); + $CPAN::Config->{$item} = ($ans =~ /^[y1]/i ? 1 : 0); + } else { + $CPAN::Config->{$item} = $default; + } +} + sub my_prompt_loop { my ($item, $dflt, $m, $ok) = @_; my $default = $CPAN::Config->{$item} || $dflt; @@ -481,25 +616,28 @@ Shall I use the local database in $mby?}; } while ($mby) { if ($overwrite_local) { - print qq{Trying to overwrite $mby\n}; + $CPAN::Frontend->myprint(qq{Trying to overwrite $mby\n}); $mby = CPAN::FTP->localize($m,$mby,3); $overwrite_local = 0; } elsif ( ! -f $mby ){ - print qq{You have no $mby\n I\'m trying to fetch one\n}; + $CPAN::Frontend->myprint(qq{You have no $mby\n I\'m trying to fetch one\n}); $mby = CPAN::FTP->localize($m,$mby,3); } elsif (-M $mby > 60 && $loopcount == 0) { - print qq{Your $mby is older than 60 days,\n I\'m trying to fetch one\n}; - $mby = CPAN::FTP->localize($m,$mby,3); - $loopcount++; + $CPAN::Frontend->myprint(qq{Your $mby is older than 60 days,\n I\'m trying }. + qq{to fetch one\n}); + $mby = CPAN::FTP->localize($m,$mby,3); + $loopcount++; } elsif (-s $mby == 0) { - print qq{You have an empty $mby,\n I\'m trying to fetch one\n}; + $CPAN::Frontend->myprint(qq{You have an empty $mby,\n I\'m trying to fetch one\n}); $mby = CPAN::FTP->localize($m,$mby,3); } else { last; } } + local $urllist = []; read_mirrored_by($mby); bring_your_own(); + $CPAN::Config->{urllist} = $urllist; } sub find_exe { @@ -516,34 +654,45 @@ sub find_exe { sub picklist { my($items,$prompt,$default,$require_nonempty,$empty_warning)=@_; + CPAN->debug("picklist('$items','$prompt','$default','$require_nonempty',". + "'$empty_warning')") if $CPAN::DEBUG; $default ||= ''; my $pos = 0; my @nums; - while (1) { + SELECTION: while (1) { # display, at most, 15 items at a time my $limit = $#{ $items } - $pos; $limit = 15 if $limit > 15; # show the next $limit items, get the new position - $pos = display_some($items, $limit, $pos); + $pos = display_some($items, $limit, $pos, $default); $pos = 0 if $pos >= @$items; my $num = prompt($prompt,$default); @nums = split (' ', $num); + { + my %seen; + @nums = grep { !$seen{$_}++ } @nums; + } my $i = scalar @$items; - (warn "invalid items entered, try again\n"), next - if grep (/\D/ || $_ < 1 || $_ > $i, @nums); - if ($require_nonempty) { - (warn "$empty_warning\n"); + if (grep (/\D/ || $_ < 1 || $_ > $i, @nums)){ + $CPAN::Frontend->mywarn("invalid items entered, try again\n"); + if ("@nums" =~ /\D/) { + $CPAN::Frontend->mywarn("(we are expecting at least one number between 1 and $i)\n"); + } + next SELECTION; + } + if ($require_nonempty && !@nums) { + $CPAN::Frontend->mywarn("$empty_warning\n"); } - print "\n"; + $CPAN::Frontend->myprint("\n"); # a blank line continues... - next unless @nums; + next SELECTION unless @nums; last; } for (@nums) { $_-- } @@ -551,18 +700,20 @@ sub picklist { } sub display_some { - my ($items, $limit, $pos) = @_; - $pos ||= 0; + my ($items, $limit, $pos, $default) = @_; + $pos ||= 0; - my @displayable = @$items[$pos .. ($pos + $limit)]; + my @displayable = @$items[$pos .. ($pos + $limit)]; for my $item (@displayable) { - printf "(%d) %s\n", ++$pos, $item; + $CPAN::Frontend->myprint(sprintf "(%d) %s\n", ++$pos, $item); } - printf("%d more items, hit SPACE RETURN to show them\n", - (@$items - $pos) - ) - if $pos < @$items; - return $pos; + my $hit_what = $default ? "SPACE RETURN" : "RETURN"; + $CPAN::Frontend->myprint(sprintf("%d more items, hit %s to show them\n", + (@$items - $pos), + $hit_what, + )) + if $pos < @$items; + return $pos; } sub read_mirrored_by { @@ -588,20 +739,22 @@ sub read_mirrored_by { } $fh->close; $CPAN::Config->{urllist} ||= []; - my(@previous_urls); - if (@previous_urls = @{$CPAN::Config->{urllist}}) { - $CPAN::Config->{urllist} = []; - } + my @previous_urls = @{$CPAN::Config->{urllist}}; - print $prompts{urls_intro}; + $CPAN::Frontend->myprint($prompts{urls_intro}); my (@cont, $cont, %cont, @countries, @urls, %seen); - my $no_previous_warn = - "Sorry! since you don't have any existing picks, you must make a\n" . - "geographic selection."; - @cont = picklist([sort keys %all], + my $no_previous_warn = + "Sorry! since you don't have any existing picks, you must make a\n" . + "geographic selection."; + my $offer_cont = [sort keys %all]; + if (@previous_urls) { + push @$offer_cont, "(edit previous picks)"; + $default = @$offer_cont; + } + @cont = picklist($offer_cont, "Select your continent (or several nearby continents)", - '', + $default, ! @previous_urls, $no_previous_warn); @@ -612,21 +765,26 @@ sub read_mirrored_by { @c = map ("$_ ($cont)", @c) if @cont > 1; push (@countries, @c); } + if (@previous_urls && @countries) { + push @countries, "(edit previous picks)"; + $default = @countries; + } if (@countries) { @countries = picklist (\@countries, "Select your country (or several nearby countries)", - '', + $default, ! @previous_urls, $no_previous_warn); %seen = map (($_ => 1), @previous_urls); # hmmm, should take list of defaults from CPAN::Config->{'urllist'}... foreach $country (@countries) { + next if $country =~ /edit previous picks/; (my $bare_country = $country) =~ s/ \(.*\)//; my @u = sort keys %{$all{$cont{$bare_country}}{$bare_country}}; @u = grep (! $seen{$_}, @u); @u = map ("$_ ($bare_country)", @u) - if @countries > 1; + if @countries > 1; push (@urls, @u); } } @@ -634,18 +792,18 @@ sub read_mirrored_by { my $prompt = "Select as many URLs as you like (by number), put them on one line, separated by blanks, e.g. '1 4 5'"; if (@previous_urls) { - $default = join (' ', ((scalar @urls) - (scalar @previous_urls) + 1) .. - (scalar @urls)); - $prompt .= "\n(or just hit RETURN to keep your previous picks)"; + $default = join (' ', ((scalar @urls) - (scalar @previous_urls) + 1) .. + (scalar @urls)); + $prompt .= "\n(or just hit RETURN to keep your previous picks)"; } @urls = picklist (\@urls, $prompt, $default); foreach (@urls) { s/ \(.*\)//; } - push @{$CPAN::Config->{urllist}}, @urls; + push @$urllist, @urls; } sub bring_your_own { - my %seen = map (($_ => 1), @{$CPAN::Config->{urllist}}); + my %seen = map (($_ => 1), @$urllist); my($ans,@urls); do { my $prompt = "Enter another URL or RETURN to quit:"; @@ -662,21 +820,24 @@ Please enter your CPAN site:}; if ($ans =~ /^\w+:\/./) { push @urls, $ans unless $seen{$ans}++; } else { - printf(qq{"%s" doesn\'t look like an URL at first sight. + $CPAN::Frontend-> + myprint(sprintf(qq{"%s" doesn\'t look like an URL at first sight. I\'ll ignore it for now. You can add it to your %s later if you\'re sure it\'s right.\n}, - $ans, - $INC{'CPAN/MyConfig.pm'} || $INC{'CPAN/Config.pm'} || "configuration file", - ); + $ans, + $INC{'CPAN/MyConfig.pm'} + || $INC{'CPAN/Config.pm'} + || "configuration file", + )); } } } while $ans || !%seen; - push @{$CPAN::Config->{urllist}}, @urls; + push @$urllist, @urls; # xxx delete or comment these out when you're happy that it works - print "New set of picks:\n"; - map { print " $_\n" } @{$CPAN::Config->{urllist}}; + $CPAN::Frontend->myprint("New set of picks:\n"); + map { $CPAN::Frontend->myprint(" $_\n") } @$urllist; } @@ -685,7 +846,6 @@ sub _strip_spaces { $_[0] =~ s/\s+\z//; # no trailing spaces } - sub prompt ($;$) { my $ans = _real_prompt(@_); @@ -707,14 +867,17 @@ my @prompts = ( manual_config => qq[ CPAN is the world-wide archive of perl resources. It consists of about -300 sites that all replicate the same contents around the globe. -Many countries have at least one CPAN site already. The resources -found on CPAN are easily accessible with the CPAN.pm module. If you -want to use CPAN.pm, you have to configure it properly. - -If you do NOT want to enter a dialog now, you can answer 'no' to this -question and I'll try to autoconfigure. (Note: you can revisit this -dialog anytime later by typing 'o conf init' at the cpan prompt.) +300 sites that all replicate the same contents around the globe. Many +countries have at least one CPAN site already. The resources found on +CPAN are easily accessible with the CPAN.pm module. If you want to use +CPAN.pm, lots of things have to be configured. Fortunately, most of +them can be determined automatically. If you prefer the automatic +configuration, answer 'yes' below. + +If you prefer to enter a dialog instead, you can answer 'no' to this +question and I'll let you configure in small steps one thing after the +other. (Note: you can revisit this dialog anytime later by typing 'o +conf init' at the cpan prompt.) ], @@ -737,13 +900,9 @@ First of all, I\'d like to create this directory. Where? keep_source_where => qq{ -If you like, I can cache the source files after I build them. Doing -so means that, if you ever rebuild that module in the future, the -files will be taken from the cache. The tradeoff is that it takes up -space. How much space would you like to allocate to this cache? (If -you don\'t want me to keep a cache, answer 0.) - -}, +Unless you are accessing the CPAN via the filesystem directly CPAN.pm +needs to keep the source files it downloads somewhere. Please supply a +directory where the downloaded files are to be kept.}, build_cache_intro => qq{ @@ -755,6 +914,9 @@ with all the intermediate files\? build_cache => "Cache size for build directory (in MB)?", +build_dir => + +"Directory where the build process takes place?", scan_cache_intro => qq{ @@ -766,7 +928,7 @@ performed to keep the cache size in sync. To prevent this, answer scan_cache => "Perform cache scanning (atstart or never)?", -cache_metadata => qq{ +cache_metadata_intro => qq{ To considerably speed up the initial CPAN shell startup, it is possible to use Storable to create a cache of metadata. If Storable @@ -774,7 +936,9 @@ is not available, the normal index mechanism will be used. }, -term_is_latin => qq{ +cache_metadata => qq{Cache metadata (yes/no)?}, + +term_is_latin_intro => qq{ The next option deals with the charset (aka character set) your terminal supports. In general, CPAN is English speaking territory, so @@ -788,6 +952,8 @@ anyway. If you answer no, names will be output in UTF-8. }, +term_is_latin => qq{Your terminal expects ISO-8859-1 (yes/no)?}, + histfile_intro => qq{ If you have one of the readline packages (Term::ReadLine::Perl, @@ -852,13 +1018,35 @@ check_sigs => qq{Always try to check and verify signatures if a SIGNATURE file is in the package and Module::Signature is installed (yes/no)?}, +test_report_intro => +qq{ + +The goal of the CPAN Testers project (http://testers.cpan.org/) is to +test as many CPAN packages as possible on as many platforms as +possible. This provides valuable feedback to module authors and +potential users to identify bugs or platform compatibility issues and +improves the overall quality and value of CPAN. + +One way you can contribute is to send test results for each module +that you install. If you install the CPAN::Reporter module, you have +the option to automatically generate and email test reports to CPAN +Testers whenever you run tests on a CPAN package. + +See the CPAN::Reporter documentation for additional details and +configuration settings. If your firewall blocks outgoing email, +you will need to configure CPAN::Reporter before sending reports. + +}, + +test_report => +qq{Email test reports if CPAN::Reporter is installed (yes/no)?}, + external_progs => qq{ The CPAN module will need a few external programs to work properly. Please correct me, if I guess the wrong path for a program. Don\'t panic if you do not have some of them, just press ENTER for those. To -disable the use of a download program, you can type a space followed -by ENTER. +disable the use of a program, you can type a space followed by ENTER. }, @@ -867,7 +1055,7 @@ prefer_installer_intro => qq{ When you have Module::Build installed and a module comes with both a Makefile.PL and a Build.PL, which shall have precedence? The two installer modules we have are the old and well established -ExtUtils::MakeMaker (for short: EUMM) understands the Makefile.PL and +ExtUtils::MakeMaker (for short: EUMM) which uses the Makefile.PL and the next generation installer Module::Build (MB) works with the Build.PL. @@ -971,9 +1159,10 @@ Your choice: }, inactivity_timeout_intro => qq{ Sometimes you may wish to leave the processes run by CPAN alone -without caring about them. Because the Makefile.PL sometimes contains -question you\'re expected to answer, you can set a timer that will -kill a 'perl Makefile.PL' process after the specified time in seconds. +without caring about them. Because the Makefile.PL or the Build.PL +sometimes contains question you\'re expected to answer, you can set a +timer that will kill a 'perl Makefile.PL' process after the specified +time in seconds. If you set this value to 0, these processes will wait forever. This is the default and recommended setting. @@ -1016,13 +1205,13 @@ a few sites onto the array (just in case the first on the array won\'t work). If you are mirroring CPAN to your local workstation, specify a file: URL. -First, pick a nearby continent and country (you can pick several of -each, separated by spaces, or none if you just want to keep your -existing selections). Then, you will be presented with a list of URLs -of CPAN mirrors in the countries you selected, along with previously -selected URLs. Select some of those URLs, or just keep the old list. -Finally, you will be prompted for any extra URLs -- file:, ftp:, or -http: -- that host a CPAN mirror. +First, pick a nearby continent and country by typing in the number(s) +in front of the item(s) you want to select. You can pick several of +each, separated by spaces. Then, you will be presented with a list of +URLs of CPAN mirrors in the countries you selected, along with +previously selected URLs. Select some of those URLs, or just keep the +old list. Finally, you will be prompted for any extra URLs -- file:, +ftp:, or http: -- that host a CPAN mirror. }, @@ -1033,6 +1222,65 @@ be echoed to the terminal! }, +commandnumber_in_prompt => qq{ + +The prompt of the cpan shell can contain the current command number +for easier tracking of the session or be a plain string. Do you want +the command number in the prompt (yes/no)?}, + +ftp_passive => qq{ + +Shall we always set FTP_PASSIVE envariable when dealing with ftp +download (yes/no)?}, + +# taken from the manpage: +getcwd_intro => qq{ + +CPAN.pm changes the current working directory often and needs to +determine its own current working directory. Per default it uses +Cwd::cwd but if this doesn't work on your system for some reason, +alternatives can be configured according to the following table: + + cwd Cwd::cwd + getcwd Cwd::getcwd + fastcwd Cwd::fastcwd + backtickcwd external command cwd + +}, + +getcwd => qq{Preferred method for determining the current working directory?}, + +index_expire_intro => qq{ + +The CPAN indexes are usually rebuilt once or twice per hour, but the +typical CPAN mirror mirrors only once or twice per day. Depending on +the quality of your mirror and your desire to be on the bleeding edge, +you may want to set the following value to more or less than one day +(which is the default). It determines after how many days CPAN.pm +downloads new indexes. + +}, + +index_expire => qq{Let the index expire after how many days?}, + +term_ornaments => qq{ + +When using Term::ReadLine, you can turn ornaments on so that your +input stands out against the output from CPAN.pm. Do you want to turn +ornaments on?}, + +colorize_output => qq{ + +When you have Term::ANSIColor installed, you can turn on colorized +output to have some visual differences between normal CPAN.pm output, +warnings, and the output of the modules being installed. Set your +favorite colors after some experimenting with the Term::ANSIColor +module. Do you want to turn on colored output?}, + +colorize_print => qq{Color for normal output?}, + +colorize_warn => qq{Color for warnings?}, + ); die "Coding error in \@prompts declaration. Odd number of elements, above" @@ -1041,17 +1289,13 @@ die "Coding error in \@prompts declaration. Odd number of elements, above" %prompts = @prompts; if (scalar(keys %prompts) != scalar(@prompts)/2) { - my %already; - for my $item (0..$#prompts) { next if $item % 2; - die "$prompts[$item] is duplicated\n" - if $already{$prompts[$item]}++; + die "$prompts[$item] is duplicated\n" if $already{$prompts[$item]}++; } - } -} +} # EOBEGIN 1; diff --git a/lib/CPAN/HandleConfig.pm b/lib/CPAN/HandleConfig.pm index 588b15bbc0..5b3c296757 100644 --- a/lib/CPAN/HandleConfig.pm +++ b/lib/CPAN/HandleConfig.pm @@ -2,7 +2,7 @@ package CPAN::HandleConfig; use strict; use vars qw(%can %keys $VERSION); -$VERSION = sprintf "%.6f", substr(q$Rev: 740 $,4)/1000000 + 5.4; +$VERSION = sprintf "%.6f", substr(q$Rev: 809 $,4)/1000000 + 5.4; %can = ( commit => "Commit changes to disk", @@ -18,6 +18,9 @@ $VERSION = sprintf "%.6f", substr(q$Rev: 740 $,4)/1000000 + 5.4; "bzip2", "cache_metadata", "check_sigs", + "colorize_output", + "colorize_print", + "colorize_warn", "commandnumber_in_prompt", "cpan_home", "curl", @@ -53,12 +56,15 @@ $VERSION = sprintf "%.6f", substr(q$Rev: 740 $,4)/1000000 + 5.4; "password", "prefer_installer", "prerequisites_policy", + "proxy_pass", + "proxy_user", "scan_cache", "shell", "show_upload_date", "tar", "term_is_latin", "term_ornaments", + "test_report", "unzip", "urllist", "username", @@ -89,7 +95,7 @@ sub edit { $o = shift @args; $DB::single = 1; if($can{$o}) { - $self->$o(args => \@args); + $self->$o(args => \@args); # o conf init => sub init => sub load return 1; } else { CPAN->debug("o[$o]") if $CPAN::DEBUG; @@ -141,6 +147,7 @@ sub edit { } else { $CPAN::Config->{$o} = $args[0] if defined $args[0]; $self->prettyprint($o); + return 1; } } } @@ -445,17 +452,18 @@ sub load { } local($") = ", "; - $CPAN::Frontend->myprint(<<END) if $redo && ! $theycalled; + if ($redo && ! $theycalled){ + $CPAN::Frontend->myprint(<<END); Sorry, we have to rerun the configuration dialog for CPAN.pm due to the following indispensable but missing parameters: @miss END + $args{args} = ["\\b".join("|",@miss)."\\b"]; + } $CPAN::Frontend->myprint(qq{ $configpm initialized. }); - - sleep 2; CPAN::FirstTime::init($configpm, %args); } @@ -521,13 +529,25 @@ sub cpl { if ( defined($words[2]) and + $words[2] =~ /list$/ + and ( - $words[2] =~ /list$/ && @words == 3 + @words == 3 || - $words[2] =~ /list$/ && @words == 4 && length($word) + @words == 4 && length($word) ) ) { return grep /^\Q$word\E/, qw(splice shift unshift pop push); + } elsif (defined($words[2]) + and + $words[2] eq "init" + and + ( + @words == 3 + || + @words == 4 && length($word) + )) { + return sort grep /^\Q$word\E/, keys %keys; } elsif (@words >= 4) { return (); } @@ -552,7 +572,7 @@ package use strict; use vars qw($AUTOLOAD $VERSION); -$VERSION = sprintf "%.2f", substr(q$Rev: 740 $,4)/100; +$VERSION = sprintf "%.2f", substr(q$Rev: 809 $,4)/100; # formerly CPAN::HandleConfig was known as CPAN::Config sub AUTOLOAD { |