NAME
I18N::Handle - A common i18n handler for web frameworks and applications.
DESCRIPTION
***THIS MODULE IS STILL IN DEVELOPMENT***
I18N::Handle is a common handler for web frameworks and applications.
You can use App::I18N to generate po/mo files, then use this module
to handle these languages.
SYNOPSIS
Ideas are welcome. just drop me a line.
option import
takes the same arguments as Locale::Maketext::Lexicon takes. it's language => [ format => source ].
use I18N::Handle;
my $hl = I18N::Handle->new(
import => {
en => [ Gettext => 'po/en.po' ],
fr => [ Gettext => 'po/fr.po' ],
jp => [ Gettext => 'po/jp.po' ],
})->accept( qw(en fr) )->speak( 'en' );
Or a simple way to import gettext po files: This will transform the args to the args that import
option takes:
use I18N::Handle;
my $hl = I18N::Handle->new(
Gettext => {
en => 'po/en.po',
fr => 'po/fr.po',
jp => [ 'po/jp.po' , 'po2/jp.po' ],
})->accept( qw(en fr) )->speak( 'en' );
print _('Hello world');
$hl->speak( 'fr' );
$hl->speak( 'jp' );
$hl->speaking; # return 'jp'
my @langs = $hl->can_speak(); # return 'en', 'fr', 'jp'
OPTIONS
- format => { language => source , ... }
-
Format could be Gettext | Msgcat | Slurp | Tie.
use I18N::Handle; my $hl = I18N::Handle->new( Gettext => { en => 'po/en.po', fr => 'po/fr.po', jp => [ 'po/jp.po' , 'po2/jp.po' ], }); $hl->speak( 'en' );
po
=> 'path' | [ path1 , path2 ]-
Suppose you have these files:
po/en.po po/zh_TW.po
When using:
I18N::Handle->new( po => 'po' );
will be found. can you can get these langauges:
[ en , zh-tw ]
locale
=> 'path' | [ path1 , path2 ]import
=> Arguments to Locale::Maketext::Lexicon
OPTIONAL OPTIONS
style
=> style ... (Optional)-
The style could be
gettext
. loc
=> global loc function name (Optional)-
The default loc function name is
_
.
PUBLIC METHODS
new
singleton( options )
If you need a singleton I18N::Handle, this is a helper function to return the singleton object.
speak( language )
setup current language. language, can be en
, fr
and so on..
speaking()
get current speaking language name.
can_speak()
return a list that currently supported.
accept( language name list )
setup accept languages.
$hl->accpet( qw(en fr) );
fallback( language )
setup fallback language. when speak() fails , fallback to this language.
$hl->fallback( 'en' );
PRIVATE METHODS
_unify_langtag
_scan_po_files
_scan_locale_files
USE CASES
Handling po files
$hl = I18N::Handle->new(
po => 'path/to/po',
style => 'gettext' # use gettext style format (default)
)->speak( 'en' );
print _('Hello world');
Handling locale
If you need to bind the locale directory structure like this:
po/en/LC_MESSAGES/app.po
po/en/LC_MESSAGES/app.mo
po/zh_tw/LC_MESSAGES/app.po
po/zh_tw/LC_MESSAGES/app.mo
You can just pass the locale
option:
$hl = I18N::Handle->new(
locale => 'path/to/locale'
)->speak( 'en_US' );
or just use import
:
$hl = I18N::Handle->new(
import => { '*' => 'locale/*/LC_MESSAGES/hello.mo' } );
Handling json files
not implemented yet
Ensure you have json files:
json/en.json
json/fr.json
json/ja.json
Then specify the json
option:
$hl = I18N::Handle->new( json => 'json' );
Singleton
If you need a singleton I18N::Handle, this is a helper function to return the singleton object:
$hl = I18N::Handle->singleton( locale => 'path/to/locale' );
In your applications, might be like this:
sub get_i18n {
my $class = shift;
return I18N::Handle->singleton( ... options ... )
}
Connect to a remote i18n server
not implemented yet
Connect to a translation server:
$handle = I18N::Handle->new(
server => 'translate.me' )->speak( 'en_US' );
Binding with database
not implemented yet
Connect to a database:
$handle = I18N::Handle->new(
dsn => 'DBI:mysql:database=$database;host=$hostname;port=$port;'
);
Binding with Google translation service
not implemented yet
Connect to google translation:
$handle = I18N::Handle->new( google => "" );
Exporting loc function to Text::Xslate
my $tx = Text::Xslate->new(
path => ['templates'],
cache_dir => ".xslate_cache",
cache => 1,
function => { "_" => \&_ } );
Then you can use _
function inside your Text::Xslate templates:
<: _('Hello') :>
AUTHOR
Yoan Lin <cornelius.howl {at} gmail.com>
SEE ALSO
LICENSE
This library is free software; you can redistribute it and/or modify it under the same terms as Perl itself.