summaryrefslogtreecommitdiffstats
path: root/perl-install/lang.pm
diff options
context:
space:
mode:
authorOlivier Blin <oblin@mandriva.com>2009-03-03 14:08:05 +0000
committerOlivier Blin <oblin@mandriva.com>2009-03-03 14:08:05 +0000
commit76ed3da4863bce19d48c9900c30734fb2138b170 (patch)
treed2e46567784ba0fa520ea3dd1ffca816513babd1 /perl-install/lang.pm
parentc48b6ad56a4ce1f0ca891694b4cb022c9ddbc578 (diff)
downloaddrakx-76ed3da4863bce19d48c9900c30734fb2138b170.tar
drakx-76ed3da4863bce19d48c9900c30734fb2138b170.tar.gz
drakx-76ed3da4863bce19d48c9900c30734fb2138b170.tar.bz2
drakx-76ed3da4863bce19d48c9900c30734fb2138b170.tar.xz
drakx-76ed3da4863bce19d48c9900c30734fb2138b170.zip
fix reading default input method setting (skim was read if scim-bridge was configured before)
Diffstat (limited to 'perl-install/lang.pm')
-rw-r--r--perl-install/lang.pm12
1 files changed, 5 insertions, 7 deletions
diff --git a/perl-install/lang.pm b/perl-install/lang.pm
index 46d0dcbf1..291568679 100644
--- a/perl-install/lang.pm
+++ b/perl-install/lang.pm
@@ -1083,13 +1083,11 @@ sub read {
my $locale = system_locales_to_ourlocale($h{LC_MESSAGES} || 'en_US', $h{LC_MONETARY} || 'en_US');
if (find { $h{$_} } @IM_i18n_fields) {
- my @l = grep { !/^scim/ || /\(default\)/ } keys %IM_config;
- foreach my $field ('XMODIFIERS', 'XIM_PROGRAM') {
- $h{$field} or next;
- my @m = grep { $h{$field} eq $IM_config{$_}{$field} } @l or last;
- @l = @m;
- }
- $locale->{IM} = $l[0] if @l;
+ my $current_IM = find {
+ my $i = $IM_config{$_};
+ every { !defined $i->{$_} || $h{$_} eq $i->{$_} } ('GTK_IM_MODULE', 'XMODIFIERS', 'XIM_PROGRAM');
+ } keys %IM_config;
+ $locale->{IM} = $current_IM if $current_IM;
}
$locale;
}