po(otherlanguages): return pages that should exist
... instead of already existing ones. This fixes the "missing otherlanguages links on master pages just created via the CGI" bug. Signed-off-by: intrigeri <intrigeri@boum.org>master
parent
36312b13b4
commit
190c641c8a
|
@ -150,6 +150,7 @@ sub needsbuild () { #{{{
|
|||
# a given master page was rendered because its source file was changed
|
||||
@origneedsbuild=(@$needsbuild);
|
||||
|
||||
flushmemoizecache();
|
||||
buildtranslationscache();
|
||||
|
||||
# make existing translations depend on the corresponding master page
|
||||
|
@ -568,20 +569,24 @@ sub islanguagecode ($) { #{{{
|
|||
return ($code =~ /^[a-z]{2}$/);
|
||||
} #}}}
|
||||
|
||||
sub otherlanguage ($$) { #{{{
|
||||
my $page=shift;
|
||||
my $code=shift;
|
||||
|
||||
return masterpage($page) if $code eq $config{po_master_language}{code};
|
||||
return masterpage($page) . '.' . $code;
|
||||
} #}}}
|
||||
|
||||
sub otherlanguages ($) { #{{{
|
||||
my $page=shift;
|
||||
|
||||
my %ret;
|
||||
if (istranslatable($page)) {
|
||||
%ret = %{$translations{$page}} if defined $translations{$page};
|
||||
}
|
||||
elsif (istranslation($page)) {
|
||||
my $masterpage = masterpage($page);
|
||||
$ret{$config{po_master_language}{code}} = $masterpage;
|
||||
foreach my $lang (sort keys %{$translations{$masterpage}}) {
|
||||
next if $lang eq lang($page);
|
||||
$ret{$lang} = $translations{$masterpage}{$lang};
|
||||
}
|
||||
return \%ret unless (istranslation($page) || istranslatable($page));
|
||||
my $curlang=lang($page);
|
||||
foreach my $lang
|
||||
($config{po_master_language}{code}, keys %{$config{po_slave_languages}}) {
|
||||
next if $lang eq $curlang;
|
||||
$ret{$lang}=otherlanguage($page, $lang);
|
||||
}
|
||||
return \%ret;
|
||||
} #}}}
|
||||
|
|
|
@ -592,8 +592,7 @@ Robustness tests
|
|||
### Creating pages
|
||||
|
||||
- creating a master page via RCS: **OK**
|
||||
- creating a master page via CGI: **FIXME** the new master page has no
|
||||
`otherlanguages` links until refreshed once more
|
||||
- creating a master page via CGI: **OK**
|
||||
|
||||
### Deleting pages
|
||||
|
||||
|
|
Loading…
Reference in New Issue