Locale::Babelfish - Perl I18n using https://github.com/nodeca/babelfish format.
version 2.13
Библиотека локализации.
Locale::Babelfish
package Foo;
use Locale::Babelfish ();
my $bf = Locale::Babelfish->new( { dirs => [ '/path/to/dictionaries' ] } );
print $bf->t('dictionary.firstkey.nextkey', { foo => 'bar' } );
More sophisticated example:
package Foo::Bar;
use Locale::Babelfish ();
my $bf = Locale::Babelfish->new( {
# configuration
dirs => [ '/path/to/dictionaries' ],
default_locale => [ 'ru_RU' ], # By default en_US
} );
# using default locale
print $bf->t( 'dictionary.akey' );
print $bf->t( 'dictionary.firstkey.nextkey', { foo => 'bar' } );
# using specified locale
print $bf->t( 'dictionary.firstkey.nextkey', { foo => 'bar' }, 'by_BY' );
# using scalar as count or value variable
print $bf->t( 'dictionary.firstkey.nextkey', 90 );
# same as
print $bf->t( 'dictionary.firstkey.nextkey', { count => 90, value => 90 } );
# set locale
$bf->locale( 'en_US' );
print $bf->t( 'dictionary.firstkey.nextkey', { foo => 'bar' } );
# Get current locale
print $bf->locale;
#{varname} Echoes value of variable ((Singular|Plural1|Plural2)):variable Plural form ((Singular|Plural1|Plural2)) Short plural form for "count" variable
Example:
I have #{nails_count} ((nail|nails)):nails_count
or short form
I have #{count} ((nail|nails))
or with zero and onу plural forms:
I have ((=0 no nails|=1 a nail|#{nails_count} nail|#{nails_count} nails)):nails_count
Module support only YAML format. Create dictionary file like: dictionary.en_US.yaml where
dictionary
is name of dictionary and en_US
- its locale.
profile:
apps:
forums:
new_topic: New topic
last_post:
title : Last message
demo:
apples: I have #{count} ((apple|apples))
list:
- some content #{data}
- some other content #{data}
Словари грузятся при создании экземпляра, сразу в плоской форме $self->{dictionaries}->{ru_RU}->{dictname_key}...
Причем все скалярные значения, при необходимости (есть спецсимволы Babelfish), преобразуются в ссылки на скаляры (флаг - "нужно скомпилировать").
Метод t_or_undef получает значение по указанному ключу.
Если это ссылка на скаляр, то парсит и компилирует строку.
Если это ссылка на массив, то работаем со всеми элементами массива как со скалярами, собираем полученные результаты компиляции в новый массив и возвращаем ссылку на этот массив.
Результат компиляции либо ссылка на подпрограмму, либо просто строка.
Если это ссылка на подпрограмму, мы просто вызываем ее с плоскими параметрами.
Если просто строка, то возвращаем её as is.
Поддерживается опция watch.
-
locale
Если указана локаль, устанавливет её. Если нет - возвращает.
-
on_watcher_change
Перечитывает все словари.
-
look_for_watchers
Обновляет словари оп мере необходимости, через "on_watcher_change".
-
t_or_undef
$self->t_or_undef( 'main.key.subkey' , { paaram1 => 1 , param2 => 'test' } , 'ru' );
Локализация по ключу.
первой частью в ключе $key должен идти словарь, например, main.key параметр языка не обязательный.
$params - хэш параметров
-
t
$self->t( 'main.key.subkey' , { paaram1 => 1 , param2 => 'test' } , 'ru' );
Локализация по ключу.
первой частью в ключе $key должен идти словарь, например, main.key параметр языка не обязательный.
$params - хэш параметров
-
has_any_value
$self->has_any_value( 'main.key.subkey' );
Проверяет есть ли ключ в словаре
первой частью в ключе должен идти словарь, например, main.
-
load_dictionaries
Загружает все yaml словари с диска
-
load_dictionary
Загружает один yaml словарь с диска
-
phrase_need_compilation
$self->phrase_need_compilation( $phrase, $key ) $class->phrase_need_compilation( $phrase, $key )
Определяет, требуется ли компиляция фразы.
Используется также при компиляции плюралов (вложенные выражения).
-
prepare_to_compile
$self->prepare_to_compile()
Либо маркирует как refscalar строки в словарях, требующие компиляции, либо просто компилирует их.
-
detect_locale
$self->detect_locale( $locale );
Определяем какой язык будет использован. приоритет $locale, далее default_locale.
-
set_fallback
$self->set_fallback( 'by_BY', 'ru_RU', 'en_US'); $self->set_fallback( 'by_BY', [ 'ru_RU', 'en_US' ] );
Для указанной локали устанавливает список локалей, на которые будет производится откат в случае отсутствия фразы в указанной.
Например, в вышеуказанных примерах при отсутствии фразы в белорусской локали будет затем искаться фраза в русской локали, затем в англоамериканской.
-
_flat_hash_keys
_flat_hash_keys( $hash, '', $result );
Внутренняя, рекурсивная. Преобразует хэш любой вложенности в строку, где ключи хешей разделены точками.
-
_process_list_items
_process_list_items( $dictionary_values);
Обрабатывает ключи словарей содержащие списки, и оборачивает в функцию для компиляции списка. Поддерживаются вложенные структуры в виде hashref и arrayref
- Akzhan Abdulin [email protected]
- Igor Mironov [email protected]
- Victor Efimov [email protected]
- REG.RU LLC
- Kirill Sysoev [email protected]
- Alexandr Tkach [email protected]
This software is Copyright (c) 2014 by REG.RU LLC.
This is free software, licensed under:
The MIT (X11) License