#!/usr/bin/perl # Copyright (C) 2010 Tamil s.a.r.l. # # This file is part of Koha. # # Koha is free software; you can redistribute it and/or modify it under the # terms of the GNU General Public License as published by the Free Software # Foundation; either version 2 of the License, or (at your option) any later # version. # # Koha 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 Koha; if not, write to the Free Software Foundation, Inc., # 51 Franklin Street, Fifth Floor, Boston, MA 02110-1301 USA. package Main; use strict; use warnings; use LangInstaller; use Getopt::Long; use Pod::Usage; my $verbose = 0; my $pref = 0; my $all = 0; GetOptions( 'v|verbose' => \$verbose, 'p' => \$pref, 'a|all' => \$all, ); sub usage { pod2usage( -verbose => 2 ); exit; } usage() if $#ARGV != 1 && $#ARGV != 0; my ($cmd, $lang) = @ARGV; $cmd = lc $cmd; if ( $cmd =~ /create|install|update/ ) { my $installer = LangInstaller->new( $lang, $pref ); if ( $cmd !~ /create/ && $lang && not $lang ~~ $installer->{langs} ) { print "Unsupported language: $lang\n"; exit; } if ( $all ) { usage() if $cmd eq 'create'; for my $lang ( @{$installer->{langs}} ) { $installer->set_lang( $lang ); $installer->$cmd(); } } else { $installer->$cmd(); } } else { usage(); } =head1 NAME translate - Handle templates and preferences translation =head1 SYNOPSYS translate create fr-FR translate update fr-FR translate install fr-FR translate -p install fr-FR translate install =head1 DESCRIPTION In Koha, three categories of information are translated based on standard GNU .po files: opac templates pages, intranet templates and system preferences. The script is a wrapper. It allows to quickly create/update/install .po files for a given language or for all available languages. =head1 USAGE =over =item translate create F Create 3 .po files in F subdirectory: (1) from opac pages templates, (2) intranet templates, and (3) from preferences. English 'en' version of templates and preferences are used as references. =over =item F-opac.po Contains extracted text from english (en) OPAC templates found in /koha-tmpl/opac-tmpl/prog/en/ directory. =item F-intranet.po Contains extracted text from english (en) intranet templates found in /koha-tmpl/intranet-tmpl/prog/en/ directory. =item F-pref.po Contains extracted text from english (en) preferences. They are found in files located in /koha-tmpl/intranet-tmpl/prog/en/admin/preferences directory. =back =item translate [-p] update F Update .po files in F directory, named F-*.po. Without F, all available languages are updated. With -p option, only preferences .po file is updated. =item translate [-p] install F Use .po files to translate the english version of templayes and preferences files and copy those files in the appropriate directory. Without F, all available languages are installed. With -p option, only preferences .po file is updated. =back =cut