summaryrefslogtreecommitdiffstats
diff options
context:
space:
mode:
-rwxr-xr-xdrakwizard.pl139
1 files changed, 94 insertions, 45 deletions
diff --git a/drakwizard.pl b/drakwizard.pl
index 1b438616..5d15cd50 100755
--- a/drakwizard.pl
+++ b/drakwizard.pl
@@ -20,7 +20,7 @@
use lib qw(/usr/lib/libDrakX);
use strict;
-use vars qw($Wizard_title $Wizard_pix_up $lib_script $perl_module %variable $in $rpm %chooser_hash $welcome $perl_module_name $verbose %description $summary $summary_func %disabled);
+use vars qw($Wizard_title $Wizard_pix_up $lib_script $perl_module %variable $in $rpm %chooser_hash $welcome $perl_module_name $verbose %description $summary $summary_func %disabled $current_page %bool);
use XML::Parser;
use standalone;
@@ -79,9 +79,9 @@ $::isWizard = 1;
if (/-summary/) {
get_parameter($o2, $xmltree);
- $::Wizard_finished = 1;
+ $::Wizard_finished = 1;
get_summary($o2, $xmltree);
- robot($_[0], $o2->[0]);
+ is_disabled_summary($_[0], $o2->[0]);
my $data = map_freetext($summary->{freetext});
$in->ask_from("summary", "", $data) && $::{$perl_module_name."::"}{"$summary_func"}->();
}
@@ -127,10 +127,11 @@ sub load_wizard {
}
sub map_freetext {
- my @liste;
- my $valeur;
+ my @liste;
+ my $valeur;
my @data = map {
+ my $toto = $_->{variableName};
if ($_->{main_order} eq 'combo') {
if($_->{fillScript}){
@liste = ();
@@ -140,38 +141,58 @@ sub map_freetext {
$chooser_hash{$1} = $1;
}
}
+ if($_->{fillfunc}){
+ @liste = $::{$perl_module_name."::"}{"$_->{fillfunc}"}->();
+ }
else {
@liste = @{$_->{Option}};
}
}
+ elsif ($_->{main_order} eq 'bool') {
+ }
if ($_->{fillScript}) {
$ENV{$variable{$_->{variableName}}} = `. $lib_script && $_->{fillScript}`;
}
- elsif (!$ENV{$variable{$_->{variableName}}} && $_->{fillfunc}) {
- $ENV{$variable{$_->{variableName}}} = $::{$perl_module_name."::"}{"$_->{fillfunc}"}->();
- }
if ($_->{main_order} eq 'entry') {
+ if (!$ENV{$variable{$_->{variableName}}} && $_->{fillfunc}) {
+ $ENV{$variable{$_->{variableName}}} = $::{$perl_module_name."::"}{"$_->{fillfunc}"}->();
+ }
{ label => _($_->{helpText}),
val => \$ENV{$variable{$_->{variableName}}}, type => $_->{main_order},
disabled => $disabled{$_->{variableName}},
help => $_->{help}}
}
- elsif ($_->{main_order} eq 'bool') {
- { val => \$ENV{$variable{$_->{variableName}}},
- type => $_->{main_order},
- text => translate($_->{helpText}),
- disabled => $disabled{$_->{variableName}},
- help => $_->{help} }}
+ elsif ($_->{main_order} eq 'bool') {
+ if ($_->{fillfunc}) {
+ my @list = $::{$perl_module_name."::"}{"$_->{fillfunc}"}->();
+ map {{ val => \$bool{$_},
+ label => "",
+ type => 'bool',
+ text => "$_",
+ help => "",
+ disabled => $disabled{$toto}
+ }} @list;
+ }
+ else {
+ { val => \$ENV{$variable{$_->{variableName}}},
+ label => "",
+ type => $_->{main_order},
+ text => translate($_->{helpText}),
+ disabled => $disabled{$_->{variableName}},
+ help => $_->{help} }
+ }
+ }
elsif ($_->{main_order} eq 'combo') {
- { label => $_->{helptext}, val => \$ENV{$variable{$_->{variableName}}},
- list => [@liste], type => $_->{main_order},
- disabled => $disabled{$_->{variableName}} }}
- elsif ($_->{main_order} eq 'field') { { val =>
- $description{$ENV{$variable{$_->{variableName}}}}?
- $description{$ENV{$variable{$_->{variableName}}}} :
- $ENV{$variable{$_->{variableName}}},
- label => $_->{helpText},
- help => $_->{help}} }
+ { label => _($_->{helpText}),
+ val => \$ENV{$variable{$_->{variableName}}},
+ list => [@liste], type => $_->{main_order},
+ disabled => $disabled{$_->{variableName}} }}
+ elsif ($_->{main_order} eq 'field') {
+ { val => $description{$ENV{$variable{$_->{variableName}}}}?
+ $description{$ENV{$variable{$_->{variableName}}}} :
+ $ENV{$variable{$_->{variableName}}},
+ label => $_->{helpText},
+ help => $_->{help}} }
} @{$_[0]};
\@data;
}
@@ -190,7 +211,7 @@ sub get_parameter {
Variable => sub {
$variable{$leaf->{name}} = $leaf->{shellVariable};
$ENV{$variable{$leaf->{name}}} = $leaf->{defaultValue};
- $disabled{$leaf->{name}} = 0;
+ $disabled{$leaf->{name}} = sub { callback($leaf->{name})};
},
Page => sub {
!$welcome and $welcome = $page;
@@ -220,10 +241,10 @@ sub get_parameter {
},
Freetext => $common_freetext_chooser = sub {
push @{$page->{freetext}}, { %$leaf, main_order =>
- (($tag eq 'Chooser') ? 'combo'
- : ($tag eq 'Boolean') ? 'bool'
- : ($leaf->{editable} eq 'true') ? 'entry'
- : 'field'), help => $leaf->{help}};
+ (($tag eq 'Chooser') ? 'combo'
+ : ($tag eq 'Boolean') ? 'bool'
+ : ($leaf->{editable} eq 'true') ? 'entry'
+ : 'field'), help => $leaf->{help}};
},
Chooser => \&$common_freetext_chooser,
Boolean => \&$common_freetext_chooser,
@@ -231,6 +252,7 @@ sub get_parameter {
push @{${$page->{freetext}}[-1]->{Option}}, $leaf->{description};
$chooser_hash{$leaf->{description}} = $leaf->{value};
$description{$leaf->{value}} = $leaf->{description};
+ $disabled{$leaf->{description}} = sub { callback($leaf->{description})};
});
$actions{$tag} and &{$actions{$tag}};
} elsif($leaf=~ /\w\D/){
@@ -290,6 +312,7 @@ sub navigation {
my ($o, $page, $previous_page) = @_;
$page->{old_page} ||= $previous_page;
+ $current_page = $page;
display($o, $page);
my ($next, $prev) = do {
if (defined $perl_module_name && $page->{func}) {
@@ -331,32 +354,57 @@ sub navigation {
navigation($o, $next, $prev);
}
-sub robot {
+sub is_disabled_summary {
my ($widget, $page) = @_;
if ($page->{is}) {
- my ($val, $arg) = split(/\s*?=\s*/, $page->{is});
- if ($val eq $widget) {
+ my ($page_val, $page_arg) = split(/\s*?=\s*/, $page->{is});
+ if ($page_val eq $widget) {
foreach (@{$page->{freetext}}) {
- $disabled{$_->{variableName}} = $arg ? ($ENV{$variable{$val}} != $arg) : !$ENV{$variable{$val}};
+ my ($val, $arg) = split(/\s*?=\s*/, $_->{is}) if ($_->{is});
+ $disabled{$_->{variableName}} = defined $arg ? $ENV{$variable{$val}} != $arg : !$ENV{$variable{$val}};
+ $disabled{$_->{variableName}} = defined $page_arg ? ($ENV{$variable{$page_val}} != $page_arg) : !$ENV{$variable{$page_val}};
}
}
}
- robot($widget, $page->{next_page}) if $page->{next_page};
+ is_disabled_summary($widget, $page->{next_page}) if $page->{next_page};
}
-sub callback {
+sub is_disabled {
+ my ($widget, $page) = @_;
+ my $ret;
+
+ foreach (@{$page->{freetext}}) {
+ if ($_->{is}) {
+ my ($val, $arg) = split(/\s*?=\s*/, $_->{is});
+ $ret = defined $arg ? $ENV{$variable{$val}} != $arg : !$ENV{$variable{$val}};
+ }
+ $disabled{$_->{variableName}} = $ret;
+ }
+}
+
+sub callback_common {
return 1 if ($disabled{$_[0]} == 1);
foreach (keys %variable) {
- my $toto = $ENV{$variable{$_}};
- my $tata = $_;
- foreach (keys %chooser_hash) {
- if ($toto eq $_) {
- $ENV{$variable{$tata}} = $chooser_hash{$_};
- }
- }
+ my $toto = $ENV{$variable{$_}};
+ my $tata = $_;
+ foreach (keys %chooser_hash) {
+ if ($toto eq $_) {
+ $ENV{$variable{$tata}} = $chooser_hash{$_};
+ }
+ }
}
- robot($_[0], $o2->[0]);
+ 0;
+}
+
+sub callback_summary {
+ return 1 if callback_common($_[0]);
+ is_disabled_summary($_[0], $o2->[0]);
+}
+
+sub callback {
+ return 1 if callback_common($_[0]);
+ is_disabled($_[0], $current_page);
}
sub get_summary {
@@ -369,11 +417,12 @@ sub get_summary {
my $common_freetext_chooser;
my %actions = (
Wizard => sub {
- load_wizard(@{$leaf}{qw(wizardTitle libScript perlModule rpm defaultImage summaryFunc)}) },
+ load_wizard(@{$leaf}{
+ qw(wizardTitle libScript perlModule rpm defaultImage summaryFunc)}) },
Variable => sub {
$variable{$leaf->{name}} = $leaf->{shellVariable};
$ENV{$variable{$leaf->{name}}} = $leaf->{defaultValue};
- $disabled{$leaf->{name}} = sub { callback($leaf->{name})};
+ $disabled{$leaf->{name}} = sub { callback_summary($leaf->{name})};
},
Freetext => $common_freetext_chooser = sub {
my $main_order = ($tag eq 'Chooser') ? 'combo'
@@ -390,7 +439,7 @@ sub get_summary {
push @{${$summary->{freetext}}[-1]->{Option}}, $leaf->{description};
$chooser_hash{$leaf->{description}} = $leaf->{value};
$description{$leaf->{value}} = $leaf->{description};
- $disabled{$leaf->{description}} = sub {callback($leaf->{description})};
+ $disabled{$leaf->{description}} = sub {callback_summary($leaf->{description})};
});
$actions{$tag} and &{$actions{$tag}};
} elsif ($leaf=~ /\w\D/){