Merge pull request #6265 from nextcloud/unperl-l10n

Remove old perl script to update l10n files
This commit is contained in:
Morris Jobke 2018-02-09 09:57:58 +01:00 committed by GitHub
commit 0841d29c4c
No known key found for this signature in database
GPG key ID: 4AEE18F83AFDEB23
8 changed files with 132 additions and 443 deletions

2
.gitignore vendored
View file

@ -8,6 +8,8 @@
/apps/inc.php
/assets
/.htaccess
/translationfiles
/translationtool.phar
# ignore all apps except core ones
/apps*/*

129
.tx/config Normal file
View file

@ -0,0 +1,129 @@
[main]
host = https://www.transifex.com
lang_map = bg_BG: bg, cs_CZ: cs, fi_FI: fi, hu_HU: hu, nb_NO: nb, sk_SK: sk, th_TH: th, ja_JP: ja
[nextcloud.core]
file_filter = translationfiles/<lang>/core.po
source_file = translationfiles/templates/core.pot
source_lang = en
type = PO
[nextcloud.files]
file_filter = translationfiles/<lang>/files.po
source_file = translationfiles/templates/files.pot
source_lang = en
type = PO
[nextcloud.settings-1]
file_filter = translationfiles/<lang>/settings.po
source_file = translationfiles/templates/settings.pot
source_lang = en
type = PO
[nextcloud.lib]
file_filter = translationfiles/<lang>/lib.po
source_file = translationfiles/templates/lib.pot
source_lang = en
type = PO
[nextcloud.dav]
file_filter = translationfiles/<lang>/dav.po
source_file = translationfiles/templates/dav.pot
source_lang = en
type = PO
[nextcloud.files_encryption]
file_filter = translationfiles/<lang>/encryption.po
source_file = translationfiles/templates/encryption.pot
source_lang = en
type = PO
[nextcloud.files_external]
file_filter = translationfiles/<lang>/files_external.po
source_file = translationfiles/templates/files_external.pot
source_lang = en
type = PO
[nextcloud.files_sharing]
file_filter = translationfiles/<lang>/files_sharing.po
source_file = translationfiles/templates/files_sharing.pot
source_lang = en
type = PO
[nextcloud.files_trashbin]
file_filter = translationfiles/<lang>/files_trashbin.po
source_file = translationfiles/templates/files_trashbin.pot
source_lang = en
type = PO
[nextcloud.files_versions]
file_filter = translationfiles/<lang>/files_versions.po
source_file = translationfiles/templates/files_versions.pot
source_lang = en
type = PO
[nextcloud.user_ldap]
file_filter = translationfiles/<lang>/user_ldap.po
source_file = translationfiles/templates/user_ldap.pot
source_lang = en
type = PO
[nextcloud.comments]
file_filter = translationfiles/<lang>/comments.po
source_file = translationfiles/templates/comments.pot
source_lang = en
type = PO
[nextcloud.federatedfilesharing]
file_filter = translationfiles/<lang>/federatedfilesharing.po
source_file = translationfiles/templates/federatedfilesharing.pot
source_lang = en
type = PO
[nextcloud.federation]
file_filter = translationfiles/<lang>/federation.po
source_file = translationfiles/templates/federation.pot
source_lang = en
type = PO
[nextcloud.oauth2]
file_filter = translationfiles/<lang>/oauth2.po
source_file = translationfiles/templates/oauth2.pot
source_lang = en
type = PO
[nextcloud.sharebymail]
file_filter = translationfiles/<lang>/sharebymail.po
source_file = translationfiles/templates/sharebymail.pot
source_lang = en
type = PO
[nextcloud.systemtags]
file_filter = translationfiles/<lang>/systemtags.po
source_file = translationfiles/templates/systemtags.pot
source_lang = en
type = PO
[nextcloud.updatenotification]
file_filter = translationfiles/<lang>/updatenotification.po
source_file = translationfiles/templates/updatenotification.pot
source_lang = en
type = PO
[nextcloud.theming]
file_filter = translationfiles/<lang>/theming.po
source_file = translationfiles/templates/theming.pot
source_lang = en
type = PO
[nextcloud.twofactor_backupcodes]
file_filter = translationfiles/<lang>/twofactor_backupcodes.po
source_file = translationfiles/templates/twofactor_backupcodes.pot
source_lang = en
type = PO
[nextcloud.workflowengine]
file_filter = translationfiles/<lang>/workflowengine.po
source_file = translationfiles/templates/workflowengine.pot
source_lang = en
type = PO

View file

@ -36,6 +36,7 @@ $expectedFiles = [
'.mailmap',
'.scrutinizer.yml',
'.tag',
'.tx',
'.user.ini',
'3rdparty',
'apps',
@ -62,7 +63,6 @@ $expectedFiles = [
'index.html',
'index.php',
'issue_template.md',
'l10n',
'lib',
'occ',
'ocs',

View file

@ -1,60 +0,0 @@
<?php
/**
* @copyright Copyright (c) 2017 Morris Jobke <hey@morrisjobke.de>
*
* @license GNU AGPL version 3 or any later version
*
* This program is free software: you can redistribute it and/or modify
* it under the terms of the GNU Affero General Public License as
* published by the Free Software Foundation, either version 3 of the
* License, or (at your option) any later version.
*
* This program is distributed in the hope that it will be useful,
* but WITHOUT ANY WARRANTY; without even the implied warranty of
* MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
* GNU Affero General Public License for more details.
*
* You should have received a copy of the GNU Affero General Public License
* along with this program. If not, see <http://www.gnu.org/licenses/>.
*
*/
/**
* This little script parses the info.xml and extracts the app name as well
* as the navigation entry name from the XML and writes it into a file named
* specialAppInfoFakeDummyForL10nScript.php that is created and deleted during
* l10n string extraction
*/
$fileName = getcwd() . '/appinfo/info.xml';
$strings = [];
if (!file_exists($fileName)) {
exit();
}
$xml = simplexml_load_file($fileName);
if ($xml->name) {
$strings[] = $xml->name->__toString();
}
if ($xml->navigations) {
foreach ($xml->navigations as $navigation) {
$name = $navigation->navigation->name->__toString();
if (!in_array($name, $strings)) {
$strings[] = $name;
}
}
}
print_r($strings);
$content = '<?php' . PHP_EOL;
foreach ($strings as $string) {
$content .= '$l->t("' . $string . '");' . PHP_EOL;
}
file_put_contents('specialAppInfoFakeDummyForL10nScript.php', $content);

2
l10n/.gitignore vendored
View file

@ -1,2 +0,0 @@
*.po
*.pot

View file

@ -1,129 +0,0 @@
[main]
host = https://www.transifex.com
lang_map = bg_BG: bg, cs_CZ: cs, fi_FI: fi, hu_HU: hu, nb_NO: nb, sk_SK: sk, th_TH: th, ja_JP: ja
[nextcloud.core]
file_filter = <lang>/core.po
source_file = templates/core.pot
source_lang = en
type = PO
[nextcloud.files]
file_filter = <lang>/files.po
source_file = templates/files.pot
source_lang = en
type = PO
[nextcloud.settings-1]
file_filter = <lang>/settings.po
source_file = templates/settings.pot
source_lang = en
type = PO
[nextcloud.lib]
file_filter = <lang>/lib.po
source_file = templates/lib.pot
source_lang = en
type = PO
[nextcloud.dav]
file_filter = <lang>/dav.po
source_file = templates/dav.pot
source_lang = en
type = PO
[nextcloud.files_encryption]
file_filter = <lang>/encryption.po
source_file = templates/encryption.pot
source_lang = en
type = PO
[nextcloud.files_external]
file_filter = <lang>/files_external.po
source_file = templates/files_external.pot
source_lang = en
type = PO
[nextcloud.files_sharing]
file_filter = <lang>/files_sharing.po
source_file = templates/files_sharing.pot
source_lang = en
type = PO
[nextcloud.files_trashbin]
file_filter = <lang>/files_trashbin.po
source_file = templates/files_trashbin.pot
source_lang = en
type = PO
[nextcloud.files_versions]
file_filter = <lang>/files_versions.po
source_file = templates/files_versions.pot
source_lang = en
type = PO
[nextcloud.user_ldap]
file_filter = <lang>/user_ldap.po
source_file = templates/user_ldap.pot
source_lang = en
type = PO
[nextcloud.comments]
file_filter = <lang>/comments.po
source_file = templates/comments.pot
source_lang = en
type = PO
[nextcloud.federatedfilesharing]
file_filter = <lang>/federatedfilesharing.po
source_file = templates/federatedfilesharing.pot
source_lang = en
type = PO
[nextcloud.federation]
file_filter = <lang>/federation.po
source_file = templates/federation.pot
source_lang = en
type = PO
[nextcloud.oauth2]
file_filter = <lang>/oauth2.po
source_file = templates/oauth2.pot
source_lang = en
type = PO
[nextcloud.sharebymail]
file_filter = <lang>/sharebymail.po
source_file = templates/sharebymail.pot
source_lang = en
type = PO
[nextcloud.systemtags]
file_filter = <lang>/systemtags.po
source_file = templates/systemtags.pot
source_lang = en
type = PO
[nextcloud.updatenotification]
file_filter = <lang>/updatenotification.po
source_file = templates/updatenotification.pot
source_lang = en
type = PO
[nextcloud.theming]
file_filter = <lang>/theming.po
source_file = templates/theming.pot
source_lang = en
type = PO
[nextcloud.twofactor_backupcodes]
file_filter = <lang>/twofactor_backupcodes.po
source_file = templates/twofactor_backupcodes.pot
source_lang = en
type = PO
[nextcloud.workflowengine]
file_filter = <lang>/workflowengine.po
source_file = templates/workflowengine.pot
source_lang = en
type = PO

View file

@ -1,227 +0,0 @@
#!/usr/bin/perl
use strict;
use Locale::PO;
use Cwd;
use Data::Dumper;
use File::Path;
sub crawlPrograms{
my( $dir, $ignore ) = @_;
my @found = ();
opendir( DIR, $dir );
my @files = readdir( DIR );
closedir( DIR );
@files = sort( @files );
foreach my $i ( @files ){
next if substr( $i, 0, 1 ) eq '.';
if( $i eq 'l10n' && !$ignore ){
push( @found, $dir );
}
elsif( -d $dir.'/'.$i ){
push( @found, crawlPrograms( $dir.'/'.$i ));
}
}
return @found;
}
sub crawlFiles{
my( $dir ) = @_;
my @found = ();
opendir( DIR, $dir );
my @files = readdir( DIR );
closedir( DIR );
@files = sort( @files );
foreach my $i ( @files ){
next if substr( $i, 0, 1 ) eq '.';
next if $i eq 'l10n';
if( -d $dir.'/'.$i ){
push( @found, crawlFiles( $dir.'/'.$i ));
}
else{
push(@found,$dir.'/'.$i) if $i =~ /.*(?<!\.min)\.js$/ || $i =~ /\.php$/;
}
}
return @found;
}
sub readIgnorelist{
return () unless -e 'l10n/ignorelist';
my %ignore = ();
open(IN,'l10n/ignorelist');
while(<IN>){
my $line = $_;
chomp($line);
$ignore{"./$line"}++;
}
close(IN);
return %ignore;
}
sub getPluralInfo {
my( $info ) = @_;
# get string
$info =~ s/.*Plural-Forms: (.+)\\n.*/$1/;
$info =~ s/^(.*)\\n.*/$1/g;
return $info;
}
sub init() {
# let's get the version from stdout of xgettext
my $out = `xgettext --version`;
# we assume the first line looks like this 'xgettext (GNU gettext-tools) 0.19.3'
$out = substr $out, 29, index($out, "\n")-29;
$out =~ s/^\s+|\s+$//g;
$out = "v" . $out;
my $actual = version->parse($out);
# 0.18.3 introduced JavaScript as a language option
my $expected = version->parse('v0.18.3');
if ($actual < $expected) {
die( "Minimum expected version of xgettext is " . $expected . ". Detected: " . $actual );
}
}
init();
my $task = shift( @ARGV );
my $place = '..';
die( "Usage: l10n.pl task\ntask: read, write\n" ) unless $task && $place;
# Our current position
my $whereami = cwd();
die( "Program must be executed in a l10n-folder called 'l10n'" ) unless $whereami =~ m/\/l10n$/;
# Where are i18n-files?
my @dirs = crawlPrograms( $place, 1 );
# Languages
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 '.';
}
if( $task eq 'read' ){
rmtree( 'templates' );
mkdir( 'templates' ) unless -d 'templates';
print "Mode: reading\n";
foreach my $dir ( @dirs ){
my @temp = split( /\//, $dir );
my $app = pop( @temp );
chdir( $dir );
# parses the app info and creates an dummy file specialAppInfoFakeDummyForL10nScript.php
`php $whereami/../build/l10nParseAppInfo.php`;
my @totranslate = crawlFiles('.');
my %ignore = readIgnorelist();
my $output = "${whereami}/templates/$app.pot";
print " Processing $app\n";
foreach my $file ( @totranslate ){
next if $ignore{$file};
my $keywords = '';
if( $file =~ /\.js$/ ){
$keywords = '--keyword=t:2 --keyword=n:2,3';
}
else{
$keywords = '--keyword=t --keyword=n:1,2';
}
my $language = ( $file =~ /\.js$/ ? 'Javascript' : 'PHP');
my $joinexisting = ( -e $output ? '--join-existing' : '');
print " Reading $file\n";
`xgettext --output="$output" $joinexisting $keywords --language=$language "$file" --add-comments=TRANSLATORS --from-code=UTF-8 --package-version="8.0.0" --package-name="ownCloud Core" --msgid-bugs-address="translations\@owncloud.org"`;
}
rmtree( "specialAppInfoFakeDummyForL10nScript.php" );
chdir( $whereami );
}
}
elsif( $task eq 'write' ){
print "Mode: write\n";
foreach my $dir ( @dirs ){
my @temp = split( /\//, $dir );
my $app = pop( @temp );
chdir( $dir.'/l10n' );
print " Processing $app\n";
foreach my $language ( @languages ){
next if $language eq 'templates';
my $input = "${whereami}/$language/$app.po";
next unless -e $input;
print " Language $language\n";
my $array = Locale::PO->load_file_asarray( $input );
# Create array
my @strings = ();
my @js_strings = ();
my $plurals;
TRANSLATIONS: foreach my $string ( @{$array} ){
if( $string->msgid() eq '""' ){
# Translator information
$plurals = getPluralInfo( $string->msgstr());
}
elsif( defined( $string->msgstr_n() )){
# plural translations
my @variants = ();
my $msgid = $string->msgid();
$msgid =~ s/^"(.*)"$/$1/;
my $msgid_plural = $string->msgid_plural();
$msgid_plural =~ s/^"(.*)"$/$1/;
my $identifier = "_" . $msgid."_::_".$msgid_plural . "_";
foreach my $variant ( sort { $a <=> $b} keys( %{$string->msgstr_n()} )){
next TRANSLATIONS if $string->msgstr_n()->{$variant} eq '""';
push( @variants, $string->msgstr_n()->{$variant} );
}
push( @strings, "\"$identifier\" => array(".join(",", @variants).")");
push( @js_strings, "\"$identifier\" : [".join(",", @variants)."]");
}
else{
# singular translations
next TRANSLATIONS if $string->msgstr() eq '""';
push( @strings, $string->msgid()." => ".$string->msgstr());
push( @js_strings, $string->msgid()." : ".$string->msgstr());
}
}
next if $#strings == -1; # Skip empty files
for (@strings) {
s/\$/\\\$/g;
}
# delete old php file
unlink "$language.php";
# Write js file
open( OUT, ">$language.js" );
print OUT "OC.L10N.register(\n \"$app\",\n {\n ";
print OUT join( ",\n ", @js_strings );
print OUT "\n},\n\"$plurals\");\n";
close( OUT );
# Write json file
open( OUT, ">$language.json" );
print OUT "{ \"translations\": ";
print OUT "{\n ";
print OUT join( ",\n ", @js_strings );
print OUT "\n},\"pluralForm\" :\"$plurals\"\n}";
close( OUT );
}
chdir( $whereami );
}
}
else{
print "unknown task!\n";
}

View file

@ -1,24 +0,0 @@
#!/usr/bin/env bash
lang=(ach ady af_ZA ak am_ET ar ast az bal be bg_BG bn_BD bn_IN bs ca cs_CZ cy_GB da de de_AT de_DE el en_GB en@pirate eo es es_AR es_CL es_MX et_EE eu fa fi_FI fil fr fy_NL gl gu he hi hr hu_HU hy ia id io is it ja jv ka_GE km kn ko ku_IQ la lb lo lt_LT lv mg mk ml ml_IN mn mr ms_MY mt_MT my_MM nb_NO nds ne nl nn_NO nqo oc or_IN pa pl pt_BR pt_PT ro ru si_LK sk_SK sl sq sr sr@latin su sv sw_KE ta_IN ta_LK te tg_TJ th_TH tl_PH tr tzl tzm ug uk ur_PK uz vi yo zh_CN zh_HK zh_TW)
ignore=""
for fignore in "${lang[@]}"; do
ignore=${ignore}"-not -name ${fignore}.js -not -name ${fignore}.json "
done
find ../lib/l10n -type f $ignore -delete
find ../settings/l10n -type f $ignore -delete
find ../core/l10n -type f $ignore -delete
find ../apps/files/l10n -type f $ignore -delete
find ../apps/encryption/l10n -type f $ignore -delete
find ../apps/files_external/l10n -type f $ignore -delete
find ../apps/files_sharing/l10n -type f $ignore -delete
find ../apps/files_trashbin/l10n -type f $ignore -delete
find ../apps/files_versions/l10n -type f $ignore -delete
find ../apps/user_ldap/l10n -type f $ignore -delete
find ../apps/user_webdavauth/l10n -type f $ignore -delete