version 1.20, 2003/10/08 17:43:37
|
version 1.28, 2003/12/22 22:39:07
|
Line 161 but for most purposes, we do not have to
|
Line 161 but for most purposes, we do not have to
|
package Apache::lonlocal; |
package Apache::lonlocal; |
|
|
use strict; |
use strict; |
|
use Apache::Constants qw(:common); |
use Apache::localize; |
use Apache::localize; |
use Apache::File; |
use Apache::File; |
use locale; |
use locale; |
Line 169 use POSIX qw(locale_h);
|
Line 170 use POSIX qw(locale_h);
|
require Exporter; |
require Exporter; |
|
|
our @ISA = qw (Exporter); |
our @ISA = qw (Exporter); |
our @EXPORT = qw(mt); |
our @EXPORT = qw(mt mtn ns); |
|
|
my $reroute; |
|
|
|
# ========================================================= The language handle |
# ========================================================= The language handle |
|
|
Line 180 use vars qw($lh);
|
Line 179 use vars qw($lh);
|
# ===================================================== The "MakeText" function |
# ===================================================== The "MakeText" function |
|
|
sub mt (@) { |
sub mt (@) { |
unless ($ENV{'environment.translator'}) { |
# my $fh=Apache::File->new('>>/home/www/loncapa/loncom/localize/localize/newphrases.txt'); |
if ($lh) { |
# print $fh @_[0]."\n"; |
return $lh->maketext(@_); |
# $fh->close(); |
} else { |
if ($lh) { |
return @_; |
return $lh->maketext(@_); |
} |
|
} else { |
} else { |
if ($lh) { |
return @_; |
my $trans=$lh->maketext(@_); |
|
my $link='<a target="trans" href="/cgi-bin/translator.pl?arg1='. |
|
&Apache::lonnet::escape($_[0]).'&arg2='. |
|
&Apache::lonnet::escape($_[1]).'&arg3='. |
|
&Apache::lonnet::escape($_[2]).'&lang='. |
|
$ENV{'environment.translator'}. |
|
'">[['.$trans.']]</a>'; |
|
if ($ENV{'transreroute'}) { |
|
$reroute.=$link; |
|
return $trans; |
|
} else { |
|
return $link; |
|
} |
|
} else { |
|
return @_; |
|
} |
|
} |
} |
} |
} |
|
|
Line 214 sub current_language {
|
Line 196 sub current_language {
|
my $lang=$lh->maketext('language_code'); |
my $lang=$lh->maketext('language_code'); |
return ($lang eq 'language_code'?'en':$lang); |
return ($lang eq 'language_code'?'en':$lang); |
} |
} |
|
return 'en'; |
} |
} |
|
|
# ============================================================== What encoding? |
# ============================================================== What encoding? |
Line 248 sub texthash {
|
Line 231 sub texthash {
|
} |
} |
return %hash; |
return %hash; |
} |
} |
# ======================================================== Re-route translation |
|
|
|
sub clearreroutetrans { |
|
&reroutetrans(); |
|
$reroute=''; |
|
} |
|
|
|
# ======================================================== Re-route translation |
|
|
|
sub reroutetrans { |
|
$ENV{'transreroute'}=1; |
|
} |
|
|
|
# ==================================================== End re-route translation |
|
sub endreroutetrans { |
|
$ENV{'transreroute'}=0; |
|
if ($ENV{'environment.translator'}) { |
|
return $reroute; |
|
} else { |
|
return ''; |
|
} |
|
} |
|
|
|
# ========= Get a handle (do not invoke in vain, leave this to access handlers) |
# ========= Get a handle (do not invoke in vain, leave this to access handlers) |
|
|
sub get_language_handle { |
sub get_language_handle { |
my $r=shift; |
my $r=shift; |
$lh=Apache::localize->get_handle(&Apache::loncommon::preferred_languages); |
my $languages=&Apache::loncommon::preferred_languages; |
|
unless ($languages) { |
|
my $headers=$r->headers_in; |
|
$ENV{'HTTP_ACCEPT_LANGUAGE'}=$headers->{'Accept-language'}; |
|
} else { |
|
$ENV{'HTTP_ACCEPT_LANGUAGE'}=''; |
|
} |
|
$lh=Apache::localize->get_handle($languages); |
if (&Apache::lonnet::mod_perl_version == 1) { |
if (&Apache::lonnet::mod_perl_version == 1) { |
$r->content_languages([¤t_language()]); |
$r->content_languages([¤t_language()]); |
} |
} |
Line 331 sub normalize_string {
|
Line 299 sub normalize_string {
|
my $s = shift; |
my $s = shift; |
$s =~ s/\s+/ /g; |
$s =~ s/\s+/ /g; |
$s =~ s/<[^>]+>//g; |
$s =~ s/<[^>]+>//g; |
|
# Pop off beginning or ending spaces, which aren't good |
|
$s =~ s/^\s+//; |
|
$s =~ s/\s+$//; |
return $s; |
return $s; |
} |
} |
|
|
|
# alias for normalize_string; recommend using it only in the lexicon |
|
sub ns { |
|
return normalize_string(@_); |
|
} |
|
|
|
# mtn: call the mt function and the normalization function easily. |
|
# Returns original non-normalized string if there was no translation |
|
sub mtn (@) { |
|
my @args = @_; # don't want to modify caller's string; if we |
|
# didn't care about that we could set $_[0] |
|
# directly |
|
$args[0] = normalize_string($args[0]); |
|
my $translation = &mt(@args); |
|
if ($translation ne $args[0]) { |
|
return $translation; |
|
} else { |
|
return $_[0]; |
|
} |
|
} |
|
|
|
# ---------------------------------------------------- Replace MT{...} in files |
|
|
|
sub transstatic { |
|
my $strptr=shift; |
|
$$strptr=~s/MT\{([^\}]*)\}/&mt($1)/gse; |
|
} |
|
|
|
# ----------------------------------------------- Handler Routine /adm/localize |
|
sub handler { |
|
my $r=shift; |
|
&Apache::lonlocal::get_language_handle($r); |
|
&Apache::loncommon::content_type($r,'text/html'); |
|
$r->send_http_header; |
|
return OK if $r->header_only; |
|
|
|
my $uri=$r->uri; |
|
$uri=~s/^\/adm\/localize//; |
|
my $fn=$Apache::lonnet::perlvar{'lonDocRoot'}.$uri; |
|
|
|
my $file=&Apache::lonnet::getfile($fn); |
|
&transstatic(\$file); |
|
$r->print($file); |
|
return OK; |
|
} |
|
|
1; |
1; |
|
|
__END__ |
__END__ |