summaryrefslogtreecommitdiffstats
path: root/perl-install/any.pm
diff options
context:
space:
mode:
authorPascal Rigaux <pixel@mandriva.com>2003-01-22 00:15:50 +0000
committerPascal Rigaux <pixel@mandriva.com>2003-01-22 00:15:50 +0000
commit1e438db0a3bba659e5c5e8aec5194ea3fc3233d9 (patch)
tree87831b0f55475469601a2b611d707d034dd3e600 /perl-install/any.pm
parentce4ab206f27055fc7459d04a5173efa132e7f43c (diff)
downloaddrakx-1e438db0a3bba659e5c5e8aec5194ea3fc3233d9.tar
drakx-1e438db0a3bba659e5c5e8aec5194ea3fc3233d9.tar.gz
drakx-1e438db0a3bba659e5c5e8aec5194ea3fc3233d9.tar.bz2
drakx-1e438db0a3bba659e5c5e8aec5194ea3fc3233d9.tar.xz
drakx-1e438db0a3bba659e5c5e8aec5194ea3fc3233d9.zip
- remove createBootdisk step
- add mkbootdisk option in setupBootloader__general() - move kernelVersion() from install_any to any
Diffstat (limited to 'perl-install/any.pm')
-rw-r--r--perl-install/any.pm67
1 files changed, 67 insertions, 0 deletions
diff --git a/perl-install/any.pm b/perl-install/any.pm
index 5a9464c1f..4072ff5b7 100644
--- a/perl-install/any.pm
+++ b/perl-install/any.pm
@@ -74,6 +74,67 @@ sub enableShadow {
run_program::rooted($prefix, "grpconv") or log::l("grpconv failed");
}
+sub kernelVersion {
+ my $kernel = readlink "$::prefix/boot/vmlinuz" || first(all("$::prefix/boot"));
+ first($kernel =~ /vmlinuz-(.*)/);
+}
+
+sub mkbootdisk {
+ my ($in, $bootloader, $fstab) = @_;
+
+ $in->set_help('createBootdisk') if !$::isStandalone;
+
+ if (arch() =~ /sparc/) {
+ #- as probing floppies is a bit more different on sparc, assume always /dev/fd0.
+ #- [pixel] uh, but in that case it would be better to change detect_devices::floppies, no?
+ $in->ask_okcancel('',
+ N("A custom bootdisk provides a way of booting into your Linux system without
+depending on the normal bootloader. This is useful if you don't want to install
+SILO on your system, or another operating system removes SILO, or SILO doesn't
+work with your hardware configuration. A custom bootdisk can also be used with
+the Mandrake rescue image, making it much easier to recover from severe system
+failures.
+
+If you want to create a bootdisk for your system, insert a floppy in the first
+drive and press \"Ok\".")) or return;
+ } else {
+ $in->ask_yesorno('', formatAlaTeX(
+ N("A custom bootdisk provides a way of booting into your Linux system without
+depending on the normal bootloader. This is useful if you don't want to install
+LILO (or grub) on your system, or another operating system removes LILO, or LILO doesn't
+work with your hardware configuration. A custom bootdisk can also be used with
+the Mandrake rescue image, making it much easier to recover from severe system
+failures. Would you like to create a bootdisk for your system?
+%s", isThisFs('xfs', fsedit::get_root($fstab)) ? N("
+
+(WARNING! You're using XFS for your root partition,
+creating a bootdisk on a 1.44 Mb floppy will probably fail,
+because XFS needs a very large driver).") : ''))) or return;
+ }
+
+ my $floppy_dev;
+ my @l = detect_devices::floppies_dev() or die N("Sorry, no floppy drive available");
+ my %l = (
+ 'fd0' => N("First floppy drive"),
+ 'fd1' => N("Second floppy drive"),
+ 'Skip' => N("Skip"),
+ );
+ my $format = sub { $l{$_[0]} || $_[0] };
+
+ $in->ask_from_({
+ messages => N("Choose the floppy drive you want to use to make the bootdisk"),
+ }, [ { val => \$floppy_dev, list => \@l, format => $format } ]
+ ) or return;
+
+ $in->ask_warn('', N("Insert a floppy in %s", $format->($floppy_dev)));
+
+ my $_w = $in->wait_message('', N("Creating bootdisk..."));
+
+ require bootloader;
+ bootloader::mkbootdisk(kernelVersion(), $floppy_dev, $bootloader->{perImageAppend});
+ 1;
+}
+
sub setupBootloader {
my ($in, $b, $all_hds, $fstab, $security) = @_;
my $hds = $all_hds->{hds};
@@ -184,6 +245,7 @@ sub setupBootloader__general {
my $memsize = bootloader::get_append($b, 'mem');
my $prev_clean_tmp = my $clean_tmp = any { $_->{mntpoint} eq '/tmp' } @{$all_hds->{special} ||= []};
my $prev_boot = $b->{boot};
+ my $mkbootdisk;
$b->{password2} ||= $b->{password} ||= '';
$b->{vga} ||= 'normal';
@@ -203,6 +265,9 @@ sub setupBootloader__general {
{ label => N("Password (again)"), val => \$b->{password2}, hidden => 1 },
{ label => N("Restrict command line options"), val => \$b->{restricted}, type => "bool", text => N("restrict") },
),
+ if_(arch() !~ /alpha/ && arch() !~ /ppc/,
+ { label => N("Create a bootdisk"), val => \$mkbootdisk, type => 'bool', advanced => 1 },
+ ),
{ label => N("Clean /tmp at each boot"), val => \$clean_tmp, type => 'bool', advanced => 1 },
{ label => N("Precise RAM size if needed (found %d MB)", availableRamMB()), val => \$memsize, advanced => 1 },
if_(detect_devices::isLaptop(),
@@ -247,6 +312,8 @@ sub setupBootloader__general {
@{$all_hds->{special}} = grep { $_->{mntpoint} eq '/tmp' } @{$all_hds->{special}};
}
}
+ mkbootdisk($in, $b, $fstab) or return &setupBootloader__general if $mkbootdisk;
+
1;
}