NAME

Nile::Lang - Language file manager.

SYNOPSIS

$lang = $self->app->lang;

# load language file from the current active or default language, file extension is xml.
$lang->load("general");

# load and append another language file
$lang->load("accounts");

# load language file of specific language.
$lang->load($file, $lang);

# get language variables from the active langauge
say $lang->get("site_name");
say $lang->get("first_name");
say $lang->get("last_name");
    
# get language variables of specific installed language.
say $lang->get("site_name", 'en-US');

# automatic getter support
say $lang->email; # same as $lang->get('email');

# get a group of language variables.
@text = $lang->list(@names);

# set language variables.
$lang->set("email_label", 'Email:');
$lang->set(%vars);

# automatic setter support
$lang->email('ahmed@mewsoft.com'); # same as $lang->set('email', 'ahmed@mewsoft.com');

DESCRIPTION

Nile::Lang - Language file manager.

file()

# set output file name for saving
$lang->file($file);

# get output file name
$file = $lang->file();

Get and set the output language file name used when saving or updating. The default file extension is xml.

encoding()

# get encoding used to read/write the language files, default is 'UTF-8'.
$encoding = $lang->encoding();

# set encoding used to read/write the langauge files, default is 'UTF-8'.
$lang->encoding('UTF-8');

Get and set encoding used to read/write the language files. The default encoding is 'UTF-8'.

load()

# load language file from the current active or default language, file extension is xml.
$lang->load("general");

# load and append another language file
$lang->load("accounts");

# load language file of specific language.
$lang->load($file, $lang);

Load language files from the current active or specific language. The default file extension is xml. This method can be chained $lang-load($file)->load($register)>;

add()

# load a list of language files from the current active or default language, file extension is xml.
$lang->add("general", "register", "contact");

Load a list of language files from the current active or specific language. The default file extension is xml. This method can be chained $lang-load($file, $lang)->add(@files)>;

reload()

# reload a list of language files from the current active or default language, file extension is xml.
$lang->reload("general", "register");

Reload a list of language files from the current active or specific language. The default file extension is xml. This method can be chained.

lang()

# get active language for the language object.
$lang = $lang->lang();

# set active language for the language object.
$lang->lang("en-US");

Get and set active language used when loading or writing the language files.

clear()

# clear all loaded language data.
$lang = $lang->clear();

# clear all loaded language data of sepcific language.
$lang->clear("en-US");

Clear all loaded language data or sepcific language or all languages. This does not delete the data from files.

vars()

# get all loaded language data as hash or hash ref.
%data = $lang->vars();
$data_ref = $lang->vars();

# get all loaded language data of sepcific language as hash or hash ref.
%data = $lang->vars("en-US");
$data_ref = $lang->vars("en-US");

Returns all loaded language data as a hash or hash reference of sepcific language or all languages.

get()

# get language variables from the active langauge
say $lang->get("site_name");
say $lang->get("first_name");
say $lang->get("last_name");
    
# get language variables of specific installed language.
say $lang->get("site_name", 'en-US');

# automatic getter support
say $lang->email; # same as $lang->get('email');

Returns language variables from the active or specific installed language.

set()

# set language variables.
$lang->set("email_label", 'Email:');
$lang->set(%vars);

# automatic setter support
$lang->email('ahmed@mewsoft.com'); # same as $lang->set('email', 'ahmed@mewsoft.com');

Set language variables of the active language.

list()

# get a list of language variables.
@text = $lang->list(@names);

Set a list of language variables from the active language.

keys()

# returns all language variables names.
@names = $lang->keys($);

Returns all language variables names.

exists()

# check if a langugage variable exist or not.
$found = $lang->exists($name);

Check if a langugage variable exist or not.

delete()

# delete langugage variables.
$lang->delete(@names);

Delete a list of language variables.

get_file()

# returns language file data from the active or default language, default file extension is xml.
%data = $lang->get_file("contacts");
$data_ref = $lang->get_file("contacts");

# returns language file data from specific language, default file extension is xml.
%data = $lang->get_file("contacts", "en-US");
$data_ref = $lang->get_file("contacts", "en-US");

Returns language file data as a hash or hash reference from the active or specific language. The default file extension is xml.

save()

# write the output file.
$lang->save($file);

Save changes to the output file. If no file name it will update the loaded file name.

translate()

# scan and replace the language variables $passes times in language $lang
$content = $lang->translate($content, $lang, $passes) 

# pass content by ref for better speed
$lang->translate(\$content, $lang, $passes) 

# use current language and default passes
$content = $lang->translate($content);
$lang->translate(\$content);

# use specific language and passes
$lang->translate($content, "en-US", 3);

Translate language variables inside contents to their language values. It scans the content for the langauge variables surrounded by the curly braces {var_name} and replaces them with their values from the loaded language files.

translate_file()

$content = $lang->translate_file($file, $lang, $passes);

# use current langauge and default passes
$content = $lang->translate_file($file);
$content = $lang->translate_file($file, $lang);

Loads and translates a file. The $file argument must be the full system file path.

Bugs

This project is available on github at https://github.com/mewsoft/Nile.

HOMEPAGE

Please visit the project's homepage at https://metacpan.org/release/Nile.

SOURCE

Source repository is at https://github.com/mewsoft/Nile.

SEE ALSO

See Nile for details about the complete framework.

AUTHOR

Ahmed Amin Elsheshtawy, احمد امين الششتاوى <mewsoft@cpan.org> Website: http://www.mewsoft.com

COPYRIGHT AND LICENSE

Copyright (C) 2014-2015 by Dr. Ahmed Amin Elsheshtawy احمد امين الششتاوى mewsoft@cpan.org, support@mewsoft.com, https://github.com/mewsoft/Nile, http://www.mewsoft.com

This library is free software; you can redistribute it and/or modify it under the same terms as Perl itself.