1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
98
99
100
101
102
103
104
105
106
107
108
109
110
111
112
113
114
115
116
117
118
119
120
121
122
|
package install_steps_auto_install; # $Id$
use diagnostics;
use strict;
use vars qw(@ISA $graphical @graphical_steps);
@ISA = qw(install_steps);
#-######################################################################################
#- misc imports
#-######################################################################################
use common;
use install_steps;
sub new {
my ($type, $o) = @_;
# Handle legacy options
$o->{interactive} ||= 'gtk' if $graphical || !is_empty_array_ref($o->{interactiveSteps});
push @{$o->{interactiveSteps}}, qw(installPackages exitInstall configureNetwork), @graphical_steps;
if ($o->{interactive}) {
my $interactiveClass = "install_steps_$o->{interactive}";
require "$interactiveClass.pm";
@ISA = ($interactiveClass, @ISA);
foreach my $f (@{$o->{orderedSteps}}) {
my $auto_name = member($f, @{$o->{interactiveSteps}}) ? 'noauto' : 'auto';
$o->{steps}{$f}{$auto_name} = 1;
}
goto &{$::{$interactiveClass . "::"}{new}};
} else {
@ISA = ('install_steps_auto_install_non_interactive', @ISA);
(bless {}, ref($type) || $type)->install_steps::new($o);
}
}
sub configureNetwork {
my ($o) = @_;
log::l("install_steps_auto_install::configureNetwork");
modules::load_category($o->{modules_conf}, 'network/main|gigabit|usb');
goto &install_steps::configureNetwork;
}
sub exitInstall {
my ($o, $alldone) = @_;
return if $o->{autoExitInstall};
if ($o->{interactive}) {
$o->SUPER::exitInstall($alldone);
} else {
install_steps::exitInstall($o);
print "\a";
print "Auto installation complete (the postInstall is not done yet though)\n";
print "Press <Enter> to reboot\n";
<STDIN>;
}
}
#-######################################################################################
#- install_steps_auto_install_non_interactive package
#-######################################################################################
package install_steps_auto_install_non_interactive;
use install_steps;
use lang;
use modules;
use common;
use log;
sub enteringStep {
my ($o, $step) = @_;
my ($s, $t) = (N_("Entering step `%s'\n"), $o->{steps}{$step}{text});
($s, $t) = (translate($s), translate($t)) if $ENV{LANG} !~ /ja|ko|zh/;
print sprintf($s, $t);
$o->install_steps::enteringStep($step);
}
sub rebootNeeded {
my ($o) = @_;
errorInStep($o, <<EOF);
While partitioning, the partition table re-read failed, needing a reboot
This is plain wrong for an auto_install
EOF
}
sub ask_warn {
log::l(ref($_[1]) ? join " ", @{$_[1]} : $_[1]);
}
sub wait_message {
my ($_o, $_title, $_message) = @_;
}
sub charsetChanged {
my ($o) = @_;
lang::load_console_font($o->{locale});
}
sub errorInStep {
my ($_o, $err) = @_;
print "error :(\n";
print "$err\n\n";
print "switch to console f2 for a shell\n";
print "Press <Enter> to reboot\n";
<STDIN>;
c::_exit(0);
}
#-######################################################################################
#- Steps Functions
#-######################################################################################
sub installPackages {
my ($o, $packages) = @_;
catch_cdie { $o->install_steps::installPackages($packages) } sub { print formatError($@), "\n"; 1 }
}
1;
|