summaryrefslogtreecommitdiffstats
path: root/perl-install/interactive.pm
blob: f4b95ae9dbd14b7aeb36e1b9d812b07614df0104 (plain)
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
-rw-r--r--po/rpmdrake.pot1408
1 files changed, 552 insertions, 856 deletions
diff --git a/po/rpmdrake.pot b/po/rpmdrake.pot
index cc6c5f54..5925b34d 100644
--- a/po/rpmdrake.pot
+++ b/po/rpmdrake.pot
@@ -1,26 +1,26 @@
# SOME DESCRIPTIVE TITLE.
-# Copyright (C) YEAR Free Software Foundation, Inc.
+# Copyright (C) YEAR THE PACKAGE'S COPYRIGHT HOLDER
+# This file is distributed under the same license as the PACKAGE package.
# FIRST AUTHOR <EMAIL@ADDRESS>, YEAR.
#
#, fuzzy
msgid ""
msgstr ""
"Project-Id-Version: PACKAGE VERSION\n"
-"POT-Creation-Date: 2006-01-26 13:16+0100\n"
+"Report-Msgid-Bugs-To: \n"
+"POT-Creation-Date: 2006-07-22 16:36+0800\n"
"PO-Revision-Date: YEAR-MO-DA HO:MI+ZONE\n"
"Last-Translator: FULL NAME <EMAIL@ADDRESS>\n"
"Language-Team: LANGUAGE <LL@li.org>\n"
"MIME-Version: 1.0\n"
"Content-Type: text/plain; charset=CHARSET\n"
-"Content-Transfer-Encoding: 8-bit\n"
+"Content-Transfer-Encoding: 8bit\n"
-#: ../edit-urpm-sources.pl:75
-#, c-format
+#: ../edit-urpm-sources.pl:76
msgid "Choose media type"
msgstr ""
-#: ../edit-urpm-sources.pl:76
-#, c-format
+#: ../edit-urpm-sources.pl:77
msgid ""
"This step enables you to add sources from a Mandriva Linux web or FTP "
"mirror.\n"
@@ -34,18 +34,16 @@ msgid ""
"to do this in two steps.)"
msgstr ""
-#: ../edit-urpm-sources.pl:84
-#, c-format
+#: ../edit-urpm-sources.pl:85
msgid "Distribution sources"
msgstr ""
-#: ../edit-urpm-sources.pl:84
-#, c-format
+#: ../edit-urpm-sources.pl:85
msgid "Official updates"
msgstr ""
-#: ../edit-urpm-sources.pl:87
-#, c-format
+#: ../edit-urpm-sources.pl:88
+#, perl-format
msgid ""
"This will attempt to install all official sources corresponding to your\n"
"distribution (%s).\n"
@@ -56,116 +54,94 @@ msgid ""
"Is it ok to continue?"
msgstr ""
-#: ../edit-urpm-sources.pl:96
-#, c-format
+#: ../edit-urpm-sources.pl:98
msgid "Please wait, adding media..."
msgstr ""
-#: ../edit-urpm-sources.pl:128
-#, c-format
+#: ../edit-urpm-sources.pl:130
msgid "Add a medium"
msgstr ""
-#: ../edit-urpm-sources.pl:130
-#, c-format
+#: ../edit-urpm-sources.pl:132
msgid "Local files"
msgstr ""
-#: ../edit-urpm-sources.pl:130
-#, c-format
+#: ../edit-urpm-sources.pl:132
msgid "Path:"
msgstr ""
-#: ../edit-urpm-sources.pl:131
-#, c-format
+#: ../edit-urpm-sources.pl:133
msgid "FTP server"
msgstr ""
-#: ../edit-urpm-sources.pl:131 ../edit-urpm-sources.pl:132
-#: ../edit-urpm-sources.pl:133 ../edit-urpm-sources.pl:403
-#, c-format
+#: ../edit-urpm-sources.pl:133 ../edit-urpm-sources.pl:134
+#: ../edit-urpm-sources.pl:135 ../edit-urpm-sources.pl:403
msgid "URL:"
msgstr ""
-#: ../edit-urpm-sources.pl:132
-#, c-format
+#: ../edit-urpm-sources.pl:134
msgid "RSYNC server"
msgstr ""
-#: ../edit-urpm-sources.pl:133
-#, c-format
+#: ../edit-urpm-sources.pl:135
msgid "HTTP server"
msgstr ""
-#: ../edit-urpm-sources.pl:134
-#, c-format
-msgid "Removable device"
+#: ../edit-urpm-sources.pl:136
+msgid "Path or mount point:"
msgstr ""
-#: ../edit-urpm-sources.pl:134
-#, c-format
-msgid "Path or mount point:"
+#: ../edit-urpm-sources.pl:136
+msgid "Removable device"
msgstr ""
-#: ../edit-urpm-sources.pl:150
-#, c-format
+#: ../edit-urpm-sources.pl:155
msgid "Browse..."
msgstr ""
-#: ../edit-urpm-sources.pl:180
-#, c-format
+#: ../edit-urpm-sources.pl:183
msgid "Login:"
msgstr ""
-#: ../edit-urpm-sources.pl:180 ../edit-urpm-sources.pl:479 ../rpmdrake.pm:129
-#, c-format
+#: ../edit-urpm-sources.pl:183 ../edit-urpm-sources.pl:479 ../rpmdrake.pm:130
msgid "Password:"
msgstr ""
-#: ../edit-urpm-sources.pl:185 ../edit-urpm-sources.pl:404
-#, c-format
+#: ../edit-urpm-sources.pl:188 ../edit-urpm-sources.pl:404
msgid "Relative path to synthesis/hdlist:"
msgstr ""
-#: ../edit-urpm-sources.pl:187
-#, c-format
+#: ../edit-urpm-sources.pl:190
msgid "If left blank, synthesis/hdlist will be automatically probed"
msgstr ""
-#: ../edit-urpm-sources.pl:192
-#, c-format
+#: ../edit-urpm-sources.pl:195
msgid "Name:"
msgstr ""
#: ../edit-urpm-sources.pl:203
-#, c-format
msgid "Create media for a whole distribution"
msgstr ""
-#: ../edit-urpm-sources.pl:217
-#, c-format
+#: ../edit-urpm-sources.pl:214
msgid "Search this media for updates"
msgstr ""
-#: ../edit-urpm-sources.pl:228
-#, c-format
+#: ../edit-urpm-sources.pl:224
msgid "You need to fill up at least the two first entries."
msgstr ""
-#: ../edit-urpm-sources.pl:232
-#, c-format
+#: ../edit-urpm-sources.pl:228
msgid ""
"There is already a medium by that name, do you\n"
"really want to replace it?"
msgstr ""
-#: ../edit-urpm-sources.pl:243
-#, c-format
+#: ../edit-urpm-sources.pl:239
msgid "Adding a medium:"
msgstr ""
-#: ../edit-urpm-sources.pl:244
-#, c-format
+#: ../edit-urpm-sources.pl:241
msgid "Type of medium:"
msgstr ""
@@ -173,10 +149,9 @@ msgstr ""
#: ../edit-urpm-sources.pl:410 ../edit-urpm-sources.pl:435
#: ../edit-urpm-sources.pl:496 ../edit-urpm-sources.pl:577
#: ../edit-urpm-sources.pl:617 ../edit-urpm-sources.pl:675
-#: ../edit-urpm-sources.pl:814 ../rpmdrake:181 ../rpmdrake:727
-#: ../rpmdrake:1578 ../rpmdrake:1586 ../rpmdrake.pm:576 ../rpmdrake.pm:666
-#: ../rpmdrake.pm:739
-#, c-format
+#: ../edit-urpm-sources.pl:814 ../rpmdrake:191 ../rpmdrake:783
+#: ../rpmdrake:1675 ../rpmdrake:1683 ../rpmdrake.pm:280 ../rpmdrake.pm:592
+#: ../rpmdrake.pm:682 ../rpmdrake.pm:755
msgid "Cancel"
msgstr ""
@@ -185,350 +160,293 @@ msgstr ""
#: ../edit-urpm-sources.pl:574 ../edit-urpm-sources.pl:616
#: ../edit-urpm-sources.pl:668 ../edit-urpm-sources.pl:740
#: ../edit-urpm-sources.pl:807 ../edit-urpm-sources.pl:860
-#: ../edit-urpm-sources.pl:995 ../rpmdrake:181 ../rpmdrake:727 ../rpmdrake:744
-#: ../rpmdrake:749 ../rpmdrake:1512 ../rpmdrake:1578 ../rpmdrake:1729
-#: ../rpmdrake.pm:120 ../rpmdrake.pm:220 ../rpmdrake.pm:277 ../rpmdrake.pm:576
-#, c-format
+#: ../edit-urpm-sources.pl:1009 ../rpmdrake:191 ../rpmdrake:783
+#: ../rpmdrake:800 ../rpmdrake:805 ../rpmdrake:1606 ../rpmdrake:1675
+#: ../rpmdrake:1826 ../rpmdrake.pm:121 ../rpmdrake.pm:222 ../rpmdrake.pm:282
+#: ../rpmdrake.pm:592
msgid "Ok"
msgstr ""
#: ../edit-urpm-sources.pl:308
-#, c-format
msgid "Global options for package installation"
msgstr ""
#: ../edit-urpm-sources.pl:310
-#, c-format
msgid "always"
msgstr ""
#: ../edit-urpm-sources.pl:311
-#, c-format
msgid "never"
msgstr ""
#: ../edit-urpm-sources.pl:320
-#, c-format
msgid "Verify RPMs to be installed:"
msgstr ""
#: ../edit-urpm-sources.pl:321
-#, c-format
msgid "Download program to use:"
msgstr ""
#: ../edit-urpm-sources.pl:351
-#, c-format
msgid "Source Removal"
msgstr ""
#: ../edit-urpm-sources.pl:352
-#, c-format
+#, perl-format
msgid "Are you sure you want to remove source \"%s\"?"
msgstr ""
#: ../edit-urpm-sources.pl:357
-#, c-format
msgid "Please wait, removing medium..."
msgstr ""
#: ../edit-urpm-sources.pl:394
-#, c-format
msgid "Edit a medium"
msgstr ""
#: ../edit-urpm-sources.pl:400
-#, c-format
+#, perl-format
msgid "Editing medium \"%s\":"
msgstr ""
#: ../edit-urpm-sources.pl:414
-#, c-format
msgid "Save changes"
msgstr ""
-#: ../edit-urpm-sources.pl:422 ../edit-urpm-sources.pl:982
-#, c-format
+#: ../edit-urpm-sources.pl:422 ../edit-urpm-sources.pl:996
msgid "Proxy..."
msgstr ""
#: ../edit-urpm-sources.pl:433
-#, c-format
msgid "You need to insert the medium to continue"
msgstr ""
#: ../edit-urpm-sources.pl:434
-#, c-format
msgid ""
"In order to save the changes, you need to insert the medium in the drive."
msgstr ""
#: ../edit-urpm-sources.pl:455
-#, c-format
msgid "Configure proxies"
msgstr ""
#: ../edit-urpm-sources.pl:465
-#, c-format
+#, perl-format
msgid "Proxy settings for media \"%s\""
msgstr ""
#: ../edit-urpm-sources.pl:466
-#, c-format
msgid "Global proxy settings"
msgstr ""
#: ../edit-urpm-sources.pl:468
-#, c-format
msgid ""
"If you need a proxy, enter the hostname and an optional port (syntax: "
"<proxyhost[:port]>):"
msgstr ""
#: ../edit-urpm-sources.pl:471
-#, c-format
msgid "Proxy hostname:"
msgstr ""
#: ../edit-urpm-sources.pl:474
-#, c-format
msgid "You may specify a user/password for the proxy authentication:"
msgstr ""
#: ../edit-urpm-sources.pl:477
-#, c-format
msgid "User:"
msgstr ""
#: ../edit-urpm-sources.pl:545
-#, c-format
msgid "Add a parallel group"
msgstr ""
#: ../edit-package interactive; # $Id$ use diagnostics; use strict; #-###################################################################################### #- misc imports #-###################################################################################### use MDK::Common::Func; use common; use do_pkgs; #- minimal example using interactive: # #- > use lib qw(/usr/lib/libDrakX); #- > use interactive; #- > my $in = interactive->vnew; #- > $in->ask_okcancel('title', 'question'); #- > $in->exit; #- ask_from_ takes global options ($common): #- title => window title #- messages => message displayed in the upper part of the window #- advanced_messages => message displayed when "Advanced" is pressed #- ok => force the name of the "Ok"/"Next" button #- cancel => force the name of the "Cancel"/"Previous" button #- advanced_label => force the name of the "Advanced" button #- advanced_label_close => force the name of the "Basic" button #- advanced_state => if set to 1, force the "Advanced" part of the dialog to be opened initially #- focus_cancel => force focus on the "Cancel" button #- focus_first => force focus on the first entry #- callbacks => functions called when something happen: complete canceled advanced changed focus_out ok_disabled #- ask_from_ takes a list of entries with fields: #- val => reference to the value #- label => description #- icon => icon to put before the description #- help => tooltip #- advanced => wether it is shown in by default or only in advanced mode #- disabled => function returning wether it should be disabled (grayed) #- gtk => gtk preferences #- type => #- button => (with clicked or clicked_may_quit) #- (type defaults to button if clicked or clicked_may_quit is there) #- (val need not be a reference) (if clicked_may_quit return true, it's as if "Ok" was pressed) #- label => (val need not be a reference) (type defaults to label if val is not a reference) #- bool (with "text" or "image" (which overrides text) giving an image filename) #- range (with min, max) #- combo (with list, not_edit, format) #- list (with list, icon2f (aka icon), separator (aka tree), format (aka pre_format function), #- help can be a hash or a function, #- tree_expanded boolean telling wether the tree should be wide open by default #- quit_if_double_click boolean #- allow_empty_list disables the special cases for 0 and 1 element lists #- image2f is a subroutine which takes a value of the list as parameter, and returns an array (text, image_file_name)) #- entry (the default) (with hidden) # #- heritate from this class and you'll get all made interactivity for same steps. #- for this you need to provide #- - ask_from_listW(o, title, messages, arrayref, default) returns one string of arrayref #- #- where #- - o is the object #- - title is a string #- - messages is an refarray of strings #- - default is an optional string (default is in arrayref) #- - arrayref is an arrayref of strings #- - arrayref2 contains booleans telling the default state, #- #- ask_from_list and ask_from_list_ are wrappers around ask_from_biglist and ask_from_smalllist #- #- ask_from_list_ just translate arrayref before calling ask_from_list and untranslate the result #- #- ask_from_listW should handle differently small lists and big ones. #- #-###################################################################################### #- OO Stuff #-###################################################################################### our @ISA = qw(do_pkgs); sub new($) { my ($type) = @_; bless {}, ref($type) || $type; } sub vnew { my ($_type, $o_su, $o_icon) = @_; my $su = $o_su eq "su"; if ($ENV{INTERACTIVE_HTTP}) { require interactive::http; return interactive::http->new; } require c; if ($su) { $ENV{PATH} = "/sbin:/usr/sbin:$ENV{PATH}"; $su = '' if $::testing || $ENV{TESTING}; } require_root_capability() if $su; if (check_for_xserver()) { eval { require interactive::gtk }; if (!$@) { my $o = interactive::gtk->new; if ($o_icon && $o_icon ne 'default' && !$::isWizard) { $o->{icon} = $o_icon } else { undef $o->{icon} } return $o; } elsif ($::testing) { die; } } require 'log.pm'; #- "require log" causes some pb, perl thinking that "log" is the log() function undef *log::l; *log::l = sub {}; # otherwise, it will bother us :( require interactive::newt; interactive::newt->new; } sub enter_console {} sub leave_console {} sub suspend {} sub resume {} sub end {} sub exit { if ($::isStandalone) { require standalone; standalone::exit($_[0]); } else { exit($_[0]); } } #-###################################################################################### #- Interactive functions #-###################################################################################### sub ask_warn { my ($o, $title, $message) = @_; ask_warn_($o, { title => $title, messages => $message }); } sub ask_yesorno { my ($o, $title, $message, $b_def) = @_; ask_yesorno_($o, { title => $title, messages => $message }, $b_def); } sub ask_okcancel { my ($o, $title, $message, $b_def) = @_; ask_okcancel_($o, { title => $title, messages => $message }, $b_def); } sub ask_warn_ { my ($o, $common) = @_; ask_from_listf_raw_no_check($o, $common, undef, [ $o->ok ]); } sub ask_yesorno_ { my ($o, $common, $b_def) = @_; $common->{cancel} = ''; ask_from_listf_raw($o, $common, sub { translate($_[0]) }, [ N_("Yes"), N_("No") ], $b_def ? "Yes" : "No") eq "Yes"; } sub ask_okcancel_ { my ($o, $common, $b_def) = @_; if ($::isWizard) { $::no_separator = 1; $common->{focus_cancel} = !$b_def; ask_from_no_check($o, $common, []); } else { ask_from_listf_raw($o, $common, sub { translate($_[0]) }, [ $o->ok, $o->cancel ], $b_def ? $o->ok : "Cancel") eq $o->ok; } } sub ask_filename { my ($o, $common) = @_; $common->{want_a_dir} = 0; $o->ask_fileW($common); } sub ask_directory { my ($o, $common) = @_; $common->{want_a_dir} = 1; $o->ask_fileW($common); } #- predecated sub ask_file { my ($o, $title, $o_dir) = @_; $o->ask_fileW({ title => $title, want_a_dir => 0, directory => $o_dir }); } sub ask_fileW { my ($o, $common) = @_; $o->ask_from_entry($common->{title}, $common->{message} || N("Choose a file")); } sub ask_from_list { my ($o, $title, $message, $l, $o_def) = @_; ask_from_listf($o, $title, $message, undef, $l, $o_def); } sub ask_from_list_ { my ($o, $title, $message, $l, $o_def) = @_; ask_from_listf($o, $title, $message, sub { translate($_[0]) }, $l, $o_def); } sub ask_from_listf_ { my ($o, $title, $message, $f, $l, $o_def) = @_; ask_from_listf($o, $title, $message, sub { translate($f->(@_)) }, $l, $o_def); } sub ask_from_listf { my ($o, $title, $message, $f, $l, $o_def) = @_; ask_from_listf_raw($o, { title => $title, messages => $message }, $f, $l, $o_def); } sub ask_from_listf_raw { my ($_o, $_common, $_f, $l, $_o_def) = @_; @$l == 0 and die "ask_from_list: empty list\n" . backtrace(); @$l == 1 and return $l->[0]; goto &ask_from_listf_raw_no_check; } sub ask_from_listf_raw_no_check { my ($o, $common, $f, $l, $o_def) = @_; if (@$l <= ($::isWizard ? 1 : 2)) { my ($ok, $cancel) = map { $_ && may_apply($f, $_) } @$l; if (length "$ok$cancel" < 70) { my $ret = eval { put_in_hash($common, { ok => $ok, if_($cancel, cancel => $cancel, focus_cancel => $o_def eq $l->[1]) }); ask_from_no_check($o, $common, []) ? $l->[0] : $l->[1]; }; die if $@ && $@ !~ /^wizcancel/; return $@ ? undef : $ret; } } ask_from_no_check($o, $common, [ { val => \$o_def, type => 'list', list => $l, format => $f } ]) && $o_def; } sub ask_from_treelist { my ($o, $title, $message, $separator, $l, $o_def) = @_; ask_from_treelistf($o, $title, $message, $separator, undef, $l, $o_def); } sub ask_from_treelist_ { my ($o, $title, $message, $separator, $l, $o_def) = @_; my $transl = sub { join '|', map { translate($_) } split(quotemeta($separator), $_[0]) }; ask_from_treelistf($o, $title, $message, $separator, $transl, $l, $o_def); } sub ask_from_treelistf { my ($o, $title, $message, $separator, $f, $l, $o_def) = @_; ask_from($o, $title, $message, [ { val => \$o_def, separator => $separator, list => $l, format => $f, sort => 1 } ]) or return; $o_def; } sub ask_many_from_list { my ($o, $title, $message, @l) = @_; @l = grep { @{$_->{list}} } @l or return ''; foreach my $h (@l) { $h->{e}{$_} = { text => may_apply($h->{label}, $_), val => $h->{val} ? $h->{val}->($_) : do { my $i = $h->{value} ? $h->{value}->($_) : $h->{values} ? member($_, @{$h->{values}}) : 0; \$i; }, type => 'bool', help => may_apply($h->{help}, $_, ''), icon => may_apply($h->{icon2f}, $_, ''), } foreach @{$h->{list}}; if ($h->{sort}) { $h->{list} = [ sort { $h->{e}{$a}{text} cmp $h->{e}{$b}{text} } @{$h->{list}} ]; } } $o->ask_from($title, $message, [ map { my $h = $_; map { $h->{e}{$_} } @{$h->{list}} } @l ]) or return; @l = map { my $h = $_; [ grep { ${$h->{e}{$_}{val}} } @{$h->{list}} ]; } @l; wantarray() ? @l : $l[0]; } sub ask_from_entry { my ($o, $title, $message, %callback) = @_; first(ask_from_entries($o, $title, $message, [''], %callback)); } sub ask_from_entries { my ($o, $title, $message, $l, %callback) = @_; my @l = map { my $i = ''; { label => $_, val => \$i } } @$l; $o->ask_from_({ title => $title, messages => $message, callbacks => \%callback, focus_first => 1 }, \@l) or return; map { ${$_->{val}} } @l; } sub ask_from__add_modify_remove { my ($o, $title, $message, $l, %callback) = @_; die "ask_from__add_modify_remove only handles one item" if @$l != 1; $callback{$_} or internal_error("missing callback $_") foreach qw(Add Modify Remove); if ($o->can('ask_from__add_modify_removeW')) { $o->ask_from__add_modify_removeW($title, $message, $l, %callback); } else { my $e = $l->[0]; my $chosen_element; put_in_hash($e, { allow_empty_list => 1, val => \$chosen_element, type => 'list' }); while (1) { my $continue; my @l = (@$l, map { my $s = $_; { val => translate($_), clicked_may_quit => sub { my $r = $callback{$s}->($chosen_element); defined $r or return; $continue = 1; } } } N_("Add"), if_(@{$e->{list}} > 0, N_("Modify"), N_("Remove"))); $o->ask_from_({ title => $title, messages => $message, callbacks => \%callback }, \@l) or return; return 1 if !$continue; } } } #- can get a hash of callback: focus_out changed and complete #- moreove if you pass a hash with a field list -> combo #- if you pass a hash with a field hidden -> emulate stty -echo sub ask_from { my ($o, $title, $message, $l, %callback) = @_; ask_from_($o, { title => $title, messages => $message, callbacks => \%callback }, $l); } sub ask_from_normalize { my ($o, $common, $l) = @_; ref($l) eq 'ARRAY' or internal_error('ask_from_normalize'); foreach my $e (@$l) { if (my $li = $e->{list}) { ref($e->{val}) =~ /SCALAR|REF/ or internal_error($e->{val} ? "field {val} must be a reference (it is $e->{val})" : "field {val} is mandatory"); #-# if ($e->{sort} || @$li > 10 && !exists $e->{sort}) { my @l2 = map { may_apply($e->{format}, $_) } @$li; my @places = sort { $l2[$a] cmp $l2[$b] } 0 .. $#l2; $e->{list} = $li = [ map { $li->[$_] } @places ]; } $e->{type} = 'iconlist' if $e->{icon2f}; $e->{type} = 'treelist' if $e->{separator}; add2hash_($e, { not_edit => 1 }); $e->{type} ||= 'combo'; if (!$e->{not_edit}) { die q(when using "not_edit" you must use strings, not a data structure) if ref(${$e->{val}}) || any { ref $_ } @$li; } if ($e->{type} ne 'combo' || $e->{not_edit}) { ${$e->{val}} = $li->[0] if !member(may_apply($e->{format}, ${$e->{val}}), map { may_apply($e->{format}, $_) } @$li); } } elsif ($e->{type} eq 'range') { $e->{min} <= $e->{max} or die "bad range min $e->{min} > max $e->{max} (called from " . join(':', caller()) . ")"; ${$e->{val}} = max($e->{min}, min(${$e->{val}}, $e->{max})); } elsif ($e->{type} eq 'button' || $e->{clicked} || $e->{clicked_may_quit}) { $e->{type} = 'button'; $e->{clicked_may_quit} ||= $e->{clicked} ? sub { $e->{clicked}(); 0 } : sub {}; $e->{val} = \ (my $_v = $e->{val}) if !ref($e->{val}); } elsif ($e->{type} eq 'label' || !ref($e->{val})) { $e->{type} = 'label'; $e->{val} = \ (my $_v = $e->{val}) if !ref($e->{val}); } else { $e->{type} ||= 'entry'; } $e->{disabled} ||= sub { 0 }; } #- do not display empty lists and one element lists @$l = grep { if ($_->{list} && $_->{not_edit} && !$_->{allow_empty_list}) { if (!@{$_->{list}}) { eval { require 'log.pm'; #- "require log" causes some pb, perl thinking that "log" is the log() function log::l("ask_from_normalize: empty list for $_->{label}\n" . backtrace()); }; } @{$_->{list}} > 1; } else { 1; } } @$l; if (!$common->{title} && $::isStandalone) { ($common->{title} = $0) =~ s|.*/||; } $common->{interactive_help} ||= $o->{interactive_help}; $common->{interactive_help} ||= $common->{interactive_help_id} && $o->interactive_help_sub_get_id($common->{interactive_help_id}); $common->{advanced_label} ||= N("Advanced"); $common->{advanced_label_close} ||= N("Basic"); $common->{$_} = $common->{$_} ? [ deref($common->{$_}) ] : [] foreach qw(messages advanced_messages); add2hash_($common->{callbacks} ||= {}, { changed => sub {}, focus_out => sub {}, complete => sub { 0 }, canceled => sub { 0 }, advanced => sub {} }); } sub ask_from_ { my ($o, $common, $l) = @_; ask_from_normalize($o, $common, $l); @$l or return 1; $common->{cancel} = '' if !defined wantarray(); ask_from_real($o, $common, $l); } sub ask_from_no_check { my ($o, $common, $l) = @_; ask_from_normalize($o, $common, $l); $common->{cancel} = '' if !defined wantarray(); my ($l1, $l2) = partition { !$_->{advanced} } @$l; $o->ask_fromW($common, $l1, $l2); } sub ask_from_real { my ($o, $common, $l) = @_; my ($l1, $l2) = partition { !$_->{advanced} } @$l; my $v = $o->ask_fromW($common, $l1, $l2); foreach my $e (@$l1, @$l2) { if ($e->{type} eq 'range') { ${$e->{val}} = max($e->{min}, min(${$e->{val}}, $e->{max})); } } %$common = (); $v; } sub ask_browse_tree_info { my ($o, $title, $message, $common) = @_; $common->{interactive_help} ||= $common->{interactive_help_id} && $o->interactive_help_sub_get_id($common->{interactive_help_id}); add2hash_($common, { ok => $::isWizard ? ($::Wizard_finished ? N("Finish") : N("Next")) : N("Ok"), cancel => $::isWizard ? N("Previous") : N("Cancel") }); add2hash_($common, { title => $title, message => $message }); add2hash_($common, { grep_allowed_to_toggle => sub { @_ }, grep_unselected => sub { grep { $common->{node_state}($_) eq 'unselected' } @_ }, check_interactive_to_toggle => sub { 1 }, toggle_nodes => sub { my ($set_state, @nodes) = @_; my $new_state = !$common->{grep_unselected}($nodes[0]) ? 'selected' : 'unselected'; $set_state->($_, $new_state) foreach @nodes; }, }); $o->ask_browse_tree_info_refW($common); } sub ask_browse_tree_info_refW { #- default definition, do not use with too many items (memory consuming) my ($o, $common) = @_; my ($l, $v, $h) = ([], [], {}); $common->{build_tree}(sub { my ($node) = $common->{grep_allowed_to_toggle}(@_); if (my $state = $node && $common->{node_state}($node)) { push @$l, $node; $state eq 'selected' and push @$v, $node; $h->{$node} = $state eq 'selected'; } }, 'flat'); add2hash_($common, { list => $l, #- TODO interactivity of toggle is missing values => $v, help => sub { $common->{get_info}($_[0]) }, }); my ($new_v) = $o->ask_many_from_list($common->{title}, $common->{message}, $common) or return; $common->{toggle_nodes}(sub {}, grep { ! delete $h->{$_} } @$new_v); $common->{toggle_nodes}(sub {}, grep { $h->{$_} } keys %$h); 1; } sub wait_message { my ($o, $title, $message, $b_temp) = @_; my $w = $o->wait_messageW($title, [ N("Please wait"), deref($message) ]); push @tempory::objects, $w if $b_temp; my $b = before_leaving { $o->wait_message_endW($w) }; #- enable access through set MDK::Common::Func::add_f4before_leaving(sub { $o->wait_message_nextW([ deref($_[1]) ], $w) }, $b, 'set'); $b; } sub kill() {} sub helper_separator_tree_to_tree { my ($separator, $list, $formatted_list) = @_; my $sep = quotemeta $separator; my $tree = {}; each_index { my @l = split $sep; my $leaf = pop @l; my $node = $tree; foreach (@l) { $node = $node->{$_} ||= do { my $r = {}; push @{$node->{_order_}}, $_; $r; }; } push @{$node->{_leaves_}}, [ $leaf, $list->[$::i] ]; (); } @$formatted_list; $tree; } sub interactive_help_has_id { my ($_o, $id) = @_; exists $help::{$id}; } sub interactive_help_get_id { my ($_o, @l) = @_; @l = map { join("\n\n", map { s/\n/ /mg; $_ } split("\n\n", translate($help::{$_}->()))); } grep { exists $help::{$_} } @l; join("\n\n\n", @l); } sub interactive_help_sub_get_id { my ($o, $id) = @_; $o->interactive_help_has_id($id) && sub { $o->interactive_help_get_id($id) }; } sub interactive_help_sub_display_id { my ($o, $id) = @_; $o->interactive_help_has_id($id) && sub { $o->ask_warn(N("Help"), $o->interactive_help_get_id($id)) }; } 1;
class='ctx'>
-#: ../rpmdrake.pm:399
-#, c-format
+#: ../rpmdrake.pm:404
msgid "Portugal"
msgstr ""
-#: ../rpmdrake.pm:400
-#, c-format
+#: ../rpmdrake.pm:405
msgid "Russia"
msgstr ""
-#: ../rpmdrake.pm:401
-#, c-format
+#: ../rpmdrake.pm:406
msgid "Sweden"
msgstr ""
-#: ../rpmdrake.pm:402
-#, c-format
+#: ../rpmdrake.pm:407
msgid "Singapore"
msgstr ""
-#: ../rpmdrake.pm:403
-#, c-format
+#: ../rpmdrake.pm:408
msgid "Slovakia"
msgstr ""
-#: ../rpmdrake.pm:404
-#, c-format
+#: ../rpmdrake.pm:409
msgid "Taiwan"
msgstr ""
-#: ../rpmdrake.pm:405
-#, c-format
+#: ../rpmdrake.pm:410
msgid "United Kingdom"
msgstr ""
-#: ../rpmdrake.pm:406
-#, c-format
+#: ../rpmdrake.pm:411
msgid "China"
msgstr ""
-#: ../rpmdrake.pm:407 ../rpmdrake.pm:408 ../rpmdrake.pm:409 ../rpmdrake.pm:410
-#: ../rpmdrake.pm:490
-#, c-format
+#: ../rpmdrake.pm:412 ../rpmdrake.pm:413 ../rpmdrake.pm:414 ../rpmdrake.pm:415
+#: ../rpmdrake.pm:504
msgid "United States"
msgstr ""
-#: ../rpmdrake.pm:505
-#, c-format
+#: ../rpmdrake.pm:518
msgid ""
"I need to access internet to get the mirror list.\n"
"Please check that your network is currently running.\n"
@@ -2065,8 +1777,7 @@ msgid ""
"Is it ok to continue?"
msgstr ""
-#: ../rpmdrake.pm:509
-#, c-format
+#: ../rpmdrake.pm:522
msgid ""
"I need to contact the Mandriva website to get the mirror list.\n"
"Please check that your network is currently running.\n"
@@ -2074,23 +1785,25 @@ msgid ""
"Is it ok to continue?"
msgstr ""
-#: ../rpmdrake.pm:515
-#, c-format
+#: ../rpmdrake.pm:527
+msgid "Mirror choice"
+msgstr ""
+
+#: ../rpmdrake.pm:530
msgid "Please wait, downloading mirror addresses."
msgstr ""
-#: ../rpmdrake.pm:516
-#, c-format
+#: ../rpmdrake.pm:531
msgid "Please wait, downloading mirror addresses from the Mandriva website."
msgstr ""
-#: ../rpmdrake.pm:522
-#, c-format
+#. - seems that value is bitten before being printed by next func..
+#: ../rpmdrake.pm:537
msgid "Error during download"
msgstr ""
-#: ../rpmdrake.pm:524
-#, c-format
+#: ../rpmdrake.pm:539
+#, perl-format
msgid ""
"There was an error downloading the mirror list:\n"
"\n"
@@ -2099,8 +1812,8 @@ msgid ""
"Please try again later."
msgstr ""
-#: ../rpmdrake.pm:529
-#, c-format
+#: ../rpmdrake.pm:544
+#, perl-format
msgid ""
"There was an error downloading the mirror list:\n"
"\n"
@@ -2109,18 +1822,15 @@ msgid ""
"Please try again later."
msgstr ""
-#: ../rpmdrake.pm:538
-#, c-format
+#: ../rpmdrake.pm:554
msgid "No mirror"
msgstr ""
-#: ../rpmdrake.pm:540
-#, c-format
+#: ../rpmdrake.pm:556
msgid "I can't find any suitable mirror."
msgstr ""
-#: ../rpmdrake.pm:541
-#, c-format
+#: ../rpmdrake.pm:557
msgid ""
"I can't find any suitable mirror.\n"
"\n"
@@ -2129,69 +1839,64 @@ msgid ""
"by Mandriva Linux Official Updates."
msgstr ""
-#: ../rpmdrake.pm:560
-#, c-format
+#: ../rpmdrake.pm:576
msgid "Please choose the desired mirror."
msgstr ""
-#: ../rpmdrake.pm:618
-#, c-format
+#: ../rpmdrake.pm:634
+#, perl-format
msgid "Copying file for medium `%s'..."
msgstr ""
-#: ../rpmdrake.pm:621
-#, c-format
+#: ../rpmdrake.pm:637
+#, perl-format
msgid "Examining file of medium `%s'..."
msgstr ""
-#: ../rpmdrake.pm:624
-#, c-format
+#: ../rpmdrake.pm:640
+#, perl-format
msgid "Examining remote file of medium `%s'..."
msgstr ""
-#: ../rpmdrake.pm:628
-#, c-format
+#: ../rpmdrake.pm:644
msgid " done."
msgstr ""
-#: ../rpmdrake.pm:632
-#, c-format
+#: ../rpmdrake.pm:648
msgid " failed!"
msgstr ""
#. -PO: We're downloading the said file from the said medium
-#: ../rpmdrake.pm:636
-#, c-format
+#: ../rpmdrake.pm:652
+#, perl-format
msgid "%s from medium %s"
msgstr ""
-#: ../rpmdrake.pm:640
-#, c-format
+#: ../rpmdrake.pm:656
+#, perl-format
msgid "Starting download of `%s'..."
msgstr ""
-#: ../rpmdrake.pm:644
-#, c-format
+#: ../rpmdrake.pm:660
+#, perl-format
msgid "Download of `%s', time to go:%s, speed:%s"
msgstr ""
-#: ../rpmdrake.pm:647
-#, c-format
+#: ../rpmdrake.pm:663
+#, perl-format
msgid "Download of `%s', speed:%s"
msgstr ""
-#: ../rpmdrake.pm:658
-#, c-format
+#: ../rpmdrake.pm:674
msgid "Please wait, updating media..."
msgstr ""
-#: ../rpmdrake.pm:685
-#, c-format
+#: ../rpmdrake.pm:701
msgid "Error retrieving packages"
msgstr ""
-#: ../rpmdrake.pm:686
-#, c-format
+#: ../rpmdrake.pm:702
+#, perl-format
msgid ""
"It's impossible to retrieve the list of new packages from the media\n"
"`%s'. Either this update media is misconfigured, and in this case\n"
@@ -2201,34 +1906,29 @@ msgid ""
"later."
msgstr ""
-#: ../rpmdrake.pm:717
-#, c-format
+#: ../rpmdrake.pm:733
msgid "Update media"
msgstr ""
-#: ../rpmdrake.pm:722
-#, c-format
+#: ../rpmdrake.pm:738
msgid ""
"No active medium found. You must enable some media to be able to update them."
msgstr ""
-#: ../rpmdrake.pm:729
-#, c-format
+#: ../rpmdrake.pm:745
msgid "Select the media you wish to update:"
msgstr ""
-#: ../rpmdrake.pm:743
-#, c-format
+#: ../rpmdrake.pm:759
msgid "Select all"
msgstr ""
-#: ../rpmdrake.pm:747
-#, c-format
+#: ../rpmdrake.pm:763
msgid "Update"
msgstr ""
-#: ../rpmdrake.pm:768
-#, c-format
+#: ../rpmdrake.pm:784
+#, perl-format
msgid ""
"Unable to update medium; it will be automatically disabled.\n"
"\n"
@@ -2236,55 +1936,51 @@ msgid ""
"%s"
msgstr ""
-#: ../rpmdrake.pm:791 ../rpmdrake.pm:802
-#, c-format
+#: ../rpmdrake.pm:807 ../rpmdrake.pm:818
+#, perl-format
msgid ""
"Unable to add medium, errors reported:\n"
"\n"
"%s"
msgstr ""
-#: ../rpmdrake.pm:814
-#, c-format
+#: ../rpmdrake.pm:830
msgid "Unable to create medium."
msgstr ""
-#: ../rpmdrake.pm:819
-#, c-format
+#: ../rpmdrake.pm:835
msgid "Failure when adding medium"
msgstr ""
-#: ../rpmdrake.pm:820
-#, c-format
+#: ../rpmdrake.pm:836
+#, perl-format
msgid ""
"There was a problem adding medium:\n"
"\n"
"%s"
msgstr ""
-#: ../rpmdrake.pm:833
-#, c-format
+#: ../rpmdrake.pm:849
+#, perl-format
msgid ""
"Your medium `%s', used for updates, does not match the version of %s you're "
"running (%s).\n"
"It will be disabled."
msgstr ""
-#: ../rpmdrake.pm:836
-#, c-format
+#: ../rpmdrake.pm:852
+#, perl-format
msgid ""
"Your medium `%s', used for updates, does not match the version of Mandriva "
"Linux you're running (%s).\n"
"It will be disabled."
msgstr ""
-#: ../rpmdrake.pm:852
-#, c-format
+#: ../rpmdrake.pm:869
msgid "Help launched in background"
msgstr ""
-#: ../rpmdrake.pm:853
-#, c-format
+#: ../rpmdrake.pm:870
msgid ""
"The help window has been started, it should appear shortly on your desktop."
msgstr ""