diff options
author | Francois Pons <fpons@mandriva.com> | 2000-05-03 20:39:54 +0000 |
---|---|---|
committer | Francois Pons <fpons@mandriva.com> | 2000-05-03 20:39:54 +0000 |
commit | 88d33875b772a7ade8f61658233f04b7c4bb43c8 (patch) | |
tree | 34173c6895158285b4f23e2c55e485aeb1c56578 /perl-install | |
parent | 106949dcae76303b7a9593083352781ee4a54242 (diff) | |
download | drakx-88d33875b772a7ade8f61658233f04b7c4bb43c8.tar drakx-88d33875b772a7ade8f61658233f04b7c4bb43c8.tar.gz drakx-88d33875b772a7ade8f61658233f04b7c4bb43c8.tar.bz2 drakx-88d33875b772a7ade8f61658233f04b7c4bb43c8.tar.xz drakx-88d33875b772a7ade8f61658233f04b7c4bb43c8.zip |
*** empty log message ***
Diffstat (limited to 'perl-install')
-rw-r--r-- | perl-install/install_steps_interactive.pm | 22 | ||||
-rw-r--r-- | perl-install/modules.pm | 2 |
2 files changed, 20 insertions, 4 deletions
diff --git a/perl-install/install_steps_interactive.pm b/perl-install/install_steps_interactive.pm index 0ddecb4ea..2e6df5371 100644 --- a/perl-install/install_steps_interactive.pm +++ b/perl-install/install_steps_interactive.pm @@ -339,22 +339,38 @@ sub chooseGroups { sub chooseCD { my ($o, $packages) = @_; my @mediums = grep { $_ > 1 } pkgs::allMediums($packages); + my @mediumsDescr = (); + my %mediumsDescr = (); #- if no other medium available or a poor beginner, we are choosing for him! #- note first CD is always selected and should not be unselected! return if scalar(@mediums) == 0 || $::beginner; + #- build mediumDescr according to mediums, this avoid asking multiple times + #- all the medium grouped together on only one CD. + foreach (@mediums) { + my $descr = pkgs::mediumDescr($packages, $_); + exists $mediumsDescr{$descr} or push @mediumsDescr, $descr; + $mediumsDescr{$descr} ||= $packages->[2]{$_}{selected}; + } + $o->set_help('chooseCD'); $o->ask_many_from_list_ref('', _("If you have all the CDs in the list below, click Ok. If you have none of those CDs, click Cancel. If only some CDs are missing, unselect them, then click Ok."), - [ map { _("Cd-Rom labeled \"%s\"", pkgs::mediumDescr($packages, $_)) } @mediums ], - [ map { \$packages->[2]{$_}{selected} } @mediums ] + [ map { _("Cd-Rom labeled \"%s\"", $_) } @mediumsDescr ], + [ map { \$mediumsDescr{$_} } @mediumsDescr ] ) or do { - map { $packages->[2]{$_}{selected} = 0 } @mediums; #- force unselection of other CDs. + map { $mediumsDescr{$_} = 0 } @mediumsDescr; #- force unselection of other CDs. }; $o->set_help('choosePackages'); + + #- restore true selection of medium (which may have been grouped together) + foreach (@mediums) { + my $descr = pkgs::mediumDescr($packages, $_); + $packages->[2]{$_}{selected} = $mediumsDescr{$descr}; + } } #------------------------------------------------------------------------------ diff --git a/perl-install/modules.pm b/perl-install/modules.pm index a1a6dacc3..0e3ea2dc5 100644 --- a/perl-install/modules.pm +++ b/perl-install/modules.pm @@ -546,7 +546,7 @@ sub load_thiskind($;&$) { #- probe for USB SCSI, make sure keyboard is allowed. if (my ($c) = grep { /usb-/ } map { $_->[1] } pci_probing::main::probe('')) { - eval { load($c, "SERIAL_USB"); load("usb-storage", $type); load("usbkbd"); load("keybdev"); sleep(1); }; + eval { load($c, "SERIAL_USB"); load("usbkbd"); load("keybdev"); load("usb-storage", $type); sleep(1); }; -d "/proc/scsi/usb" or unload("usb-storage"); } #- probe for parport SCSI. |