X-Git-Url: http://git.freeside.biz/gitweb/?a=blobdiff_plain;f=rt%2Fsbin%2Fmerge-rosetta.pl;h=06eedf0980b2053f11b35ff93cb7df38a772d23e;hb=b6dbe0f12dbbe4ea5209367f905f937789b5b607;hp=1c4b9035f904271be52f63cdff5de0caac782c52;hpb=b4b0c7e72d7eaee2fbfc7022022c9698323203dd;p=freeside.git diff --git a/rt/sbin/merge-rosetta.pl b/rt/sbin/merge-rosetta.pl index 1c4b9035f..06eedf098 100644 --- a/rt/sbin/merge-rosetta.pl +++ b/rt/sbin/merge-rosetta.pl @@ -1,41 +1,41 @@ #!/usr/bin/perl -w # BEGIN BPS TAGGED BLOCK {{{ -# +# # COPYRIGHT: -# -# This software is Copyright (c) 1996-2009 Best Practical Solutions, LLC -# -# +# +# This software is Copyright (c) 1996-2011 Best Practical Solutions, LLC +# +# # (Except where explicitly superseded by other copyright notices) -# -# +# +# # LICENSE: -# +# # This work is made available to you under the terms of Version 2 of # the GNU General Public License. A copy of that license should have # been provided with this software, but in any event can be snarfed # from www.gnu.org. -# +# # This work 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 # General Public License for more details. -# +# # You should have received a copy of the GNU General Public License # along with this program; if not, write to the Free Software # Foundation, Inc., 51 Franklin Street, Fifth Floor, Boston, MA # 02110-1301 or visit their web page on the internet at # http://www.gnu.org/licenses/old-licenses/gpl-2.0.html. -# -# +# +# # CONTRIBUTION SUBMISSION POLICY: -# +# # (The following paragraph is not intended to limit the rights granted # to you to modify and distribute this software under the terms of # the GNU General Public License and is only of importance to you if # you choose to contribute your changes and enhancements to the # community by submitting them to Best Practical Solutions, LLC.) -# +# # By intentionally submitting any modifications, corrections or # derivatives to this work, or any other work intended for use with # Request Tracker, to Best Practical Solutions, LLC, you confirm that @@ -44,59 +44,6 @@ # royalty-free, perpetual, license to use, copy, create derivative # works based on those contributions, and sublicense and distribute # those contributions and any derivatives thereof. -# +# # END BPS TAGGED BLOCK }}} -use strict; -use LWP::Simple 'getstore'; -use Locale::PO; -use Locale::Maketext::Extract; -use Archive::Extract; -use File::Temp; -use File::Copy 'copy'; - -my $url = shift or die 'must provide rosseta download url or directory'; - -my $dir; - -if ($url =~ m/http/) { - $dir = File::Temp::tempdir; - my ($fname) = $url =~ m{([^/]+)$}; - print "Downloading $url\n"; - getstore($url => "$dir/$fname"); - print "Extracting $dir/$fname\n"; - my $ae = Archive::Extract->new(archive => "$dir/$fname"); - my $ok = $ae->extract( to => $dir ); -} -else { - $dir = $url; -} - -Locale::Maketext::Lexicon::set_option('use_fuzzy', 1); -Locale::Maketext::Lexicon::set_option('allow_empty', 1); - -for (<$dir/rt/*.po>) { - my ($name) = m/([\w_]+)\.po/; - my $fname = "lib/RT/I18N/$name"; - my $tmp = File::Temp->new; - - print "$_ -> $fname.po\n"; - - # retain the "NOT FOUND IN SOURCE" entries - system("sed -e 's/^#~ //' $_ > $tmp"); - my $ext = Locale::Maketext::Extract->new; - $ext->read_po($tmp); - - my $po_orig = Locale::PO->load_file_ashash("$fname.po"); - # don't want empty vales to override ours. - # don't want fuzzy flag as when uploading to rosetta again it's not accepted by rosetta. - foreach my $msgid ($ext->msgids) { - my $entry = $po_orig->{Locale::PO->quote($msgid)} or next; - my $msgstr = $entry->dequote($entry->{msgstr}) or next; - $ext->set_msgstr($msgid, $msgstr) - if $ext->msgstr($msgid) eq '' && $msgstr; - } - $ext->write_po("$fname.po"); -} - -print "Merging new strings\n"; -system("$^X sbin/extract-message-catalog"); +exec('sbin/rt-message-catalog', 'rosetta', @ARGV);