Browse Source

New i18n-structure

tags/v3.0
Jakob Sack 13 years ago
parent
commit
61993419ec

core/l10n/javascript.php → core/ajax/translations.php View File


log/l10n/da.po → l10n/da/log.po View File


core/l10n/de.po → l10n/de/core.po View File


log/l10n/de.po → l10n/de/log.po View File


+ 104
- 0
l10n/l10n.pl View File

@@ -0,0 +1,104 @@
#!/usr/bin/perl
use strict;
use Locale::PO;
use Cwd;
use Data::Dumper;

sub crawl{
my( $dir ) = @_;
my @found = ();

opendir( DIR, $dir );
my @files = readdir( DIR );
closedir( DIR );

foreach my $i ( @files ){
next if substr( $i, 0, 1 ) eq '.';
if( -d $dir.'/'.$i ){
push( @found, crawl( $dir.'/'.$i ));
}
elsif( $i eq 'xgettextfiles' ){
push( @found, $dir );
}
}

return @found;
}

my $task = shift( @ARGV );
my $place = '..';

die( "Usuage: l10n.pl task\ntask: read, write\n") unless $task && $place;

# Where are i18n-files?
my @dirs = crawl( $place );

# Languages
mkdir( 'templates' ) unless -d 'templates';

my @languages = ();
opendir( DIR, '.' );
my @files = readdir( DIR );
closedir( DIR );
foreach my $i ( @files ){
push( @languages, $i ) if -d $i && substr( $i, 0, 1 ) ne '.';
}

# Our current position
my $whereami = cwd();

if( $task eq 'read' ){
foreach my $dir ( @dirs ){
my @temp = split( /\//, $dir );
pop( @temp );
my $app = pop( @temp );
chdir( $dir );
foreach my $language ( @languages ){
my $output = "${whereami}/$language/$app.po";
$output .= 't' if $language eq 'templates';
if( -e $output ){
`xgettext --files-from=xgettextfiles --join-existing --output="$output" --keyword=t`
}
else{
`xgettext --files-from=xgettextfiles --output="$output" --keyword=t`
}
}
chdir( $whereami );
}
}
elsif( $task eq 'write' ){
foreach my $dir ( @dirs ){
my @temp = split( /\//, $dir );
pop( @temp );
my $app = pop( @temp );
chdir( $dir );
foreach my $language ( @languages ){
next if $language eq 'templates';
my $input = "${whereami}/$language/$app.po";
next unless -e $input;

my $hash = Locale::PO->load_file_ashash( $input );

# Create array
my @strings = ();
foreach my $key ( keys( %{$hash} )){
next if $key eq '""';
next if $hash->{$key}->msgstr() eq '""';
push( @strings, $hash->{$key}->msgid()." => ".$hash->{$key}->msgstr());
}

# Write PHP file
open( OUT, ">$lang.php" );
print OUT "<?php \$TRANSLATIONS = array(\n";
print OUT join( ",\n", @strings );
print OUT "\n);\n";
close( OUT );
}
chdir( $whereami );
}
}
else{
print "unknown task!\n";
}

core/l10n/nl.po → l10n/nl/core.po View File


log/l10n/messages.pot → l10n/nl/log.po View File


settings/l10n/nl.po → l10n/nl/settings.po View File


admin/l10n/messages.pot → l10n/templates/admin.pot View File


core/l10n/messages.pot → l10n/templates/core.pot View File


log/l10n/nl.po → l10n/templates/log.pot View File


settings/l10n/messages.pot → l10n/templates/settings.pot View File


+ 4
- 4
lib/l10n.php View File

@@ -81,9 +81,9 @@ class OC_L10N{
}
}

if( file_exists( $SERVERROOT.'/l10n/l10n-'.$lang.'.php' )){
if( file_exists( $SERVERROOT.'/core/l10n/l10n-'.$lang.'.php' )){
// Include the file, save the data from $CONFIG
include( $SERVERROOT.'/l10n/l10n-'.$lang.'.php' );
include( $SERVERROOT.'/core/l10n/l10n-'.$lang.'.php' );
if( isset( $LOCALIZATIONS ) && is_array( $LOCALIZATIONS )){
$this->localizations = array_merge( $this->localizations, $LOCALIZATIONS );
}
@@ -231,8 +231,8 @@ class OC_L10N{
global $SERVERROOT;
// find the i18n dir
$i18ndir = $SERVERROOT.'/l10n/';
if( $app != 'core' && $app != '' ){
$i18ndir = $SERVERROOT.'/core/l10n/';
if( $app != '' ){
// Check if the app is in the app folder
if( file_exists( $SERVERROOT.'/apps/'.$app.'/l10n/' )){
$i18ndir = $SERVERROOT.'/apps/'.$app.'/l10n/';

+ 0
- 4
log/l10n/log View File

@@ -1,4 +0,0 @@
[General]
LangCode=de
ProjectID=oc_log
TargetLangCode=de

Loading…
Cancel
Save