NAME Amon2::Plugin::L10N - L10N support for Amon2 DESCRIPTION Amon2::Plugin::L10N is L10N support plugin for Amon2. Implementation L10N for your App in YourProj.pm __PACKAGE__->load_plugins('L10N' => { default_lang => 'en', # default is en accept_langs => [qw/ en ja zh-tw zh-cn fr /], # default is ['en'] po_dir => 'po', # default is po }); in your YourProj::Web::ViewFunction use Text::Xslate (); sub l { my $string = shift; my @args = map { Text::Xslate::html_escape($_) } @_; # escape arguments Text::Xslate::mark_raw( YourProj->context->loc($string, @args) ); } in your tmpl/foo.tt [% l('Hello! %1', 'username') %] in your some class package YourProj::M::Foo; sub bar { YourProj->context->loc('hello! %1', $username); } hook of before language detection __PACKAGE__->load_plugins('L10N' => { accept_langs => [qw/ en ja zh-tw zh-cn fr /], before_detection_hook => sub { my $c = shift; return unless ref($c); my $accept_re = qr/\A(?:en|ja|zh-tw)\z/; my $lang = $c->req->param('lang'); if ($lang && $lang =~ $accept_re) { $c->session->set( lang => $lang ); return $lang; } elsif (! defined $lang) { $lang = $c->session->get('lang'); if ($lang && $lang =~ $accept_re) { return $lang; } } $c->session->set( lang => '' ); return; # through }, }); hook of after language detection __PACKAGE__->load_plugins('L10N' => { accept_langs => [qw/ en ja zh zh-tw zh-cn fr /], after_detection_hook => sub { my($c, $lang) = shift; return 'zh' if $lang =~ /\Azh(?:-.+)\z/; return $lang; }, }); you can customize the po files name __PACKAGE__->load_plugins('L10N' => { accept_langs => [qw/ zh-tw zh-cn zh /], po_file_langs => [qw/ zh-tw zh-cn /], # zh.po is not exists file after_detection_hook => sub { my($c, $lang) = shift; return 'zh-cn' if $lang eq 'zh'; # use zh-cn.po file return $lang; }, }); for your CLI __PACKAGE__->load_plugins('L10N' => { default_lang => 'ja', accept_langs => [qw/ en ja /], before_detection_hook => sub { my $c = shift; return unless $NEV{CLI_MODE}; # CLI_MODE is example key return 'ja' if $ENV{LANG} =~ /ja/i; return 'en' if $ENV{LANG} =~ /en/i; return; # use default lang }, }); you can set Locale::Maketext::Lexicon options # in your MyApp.pm __PACKAGE__->load_plugins('L10N' => { accept_langs => [qw/ ja /], lexicon_options => { _auto => 0, }, }); you can implement L10N class yourself package L10N; use strict; use warnings; use parent 'Locale::Maketext'; use File::Spec; use Locale::Maketext::Lexicon +{ 'ja' => [ Gettext => File::Spec->catfile('t', 'po', 'ja.po') ], _preload => 1, _style => 'gettext', _decode => 1, }; # in your MyApp.pm __PACKAGE__->load_plugins('L10N' => { accept_langs => [qw/ ja /], l10n_class => 'L10N', }); Translation Step installing dependent module of amon2-xgettext.pl $ cpanm --with-suggests Amon2::Plugin::L10N dependnt module list in the cpanfile file. write your application run amon2-xgettext.pl $ cd your_amon2_proj_base_dir $ perl amon2-xgettext.pl en ja fr zh-tw edit .po files $ vim po/ja.po $ vim po/zh-tw.po Add Amon2 Context Method $c->l10n_language_detection Language that is detected will return. $c->loc($message), $c->loc('foo %1 .. %2 ...', @args); It will return the text in the appropriate language. AUTHOR Kazuhiro Osawa <yappo {at} shibuya {dot} pl> COPYRIGHT Copyright 2013- Kazuhiro Osawa LICENSE This library is free software; you can redistribute it and/or modify it under the same terms as Perl itself. SEE ALSO Amon2, Locale::Maketext::Lexicon, HTTP::AcceptLanguage, amon2-xgettext.pl