NAME

Locale::TextDomain::OO::Lexicon::Role::StoreFilter - Filters the lexicon data before stored

$Id: StoreFilter.pm 573 2015-02-07 20:59:51Z steffenw $

$HeadURL: svn+ssh://steffenw@svn.code.sf.net/p/perl-gettext-oo/code/module/trunk/lib/Locale/TextDomain/OO/Lexicon/Role/StoreFilter.pm $

VERSION

1.017

DESCRIPTION

This module filters the lexicon data before stored.

The idea is: Not all parts of lexicon are used by other programming languages.

Implements attributes "filter_language", "filter_category", "filter_domain" and "filter_project". There it is possible to store undef for ignore filter, a string to check equal, a regex reference to match or a code reference to do some more complicate things.

That filter removes also the key "plural_code" from header. That is an already prepared Perl code reference to calculate what plural form should used. The other language has to create the code again from key header key "plural". That contains that pseudo code from po/mo file without ; and/or \n at the end.

SYNOPSIS

with qw(
    Locale::TextDomain::OO::Lexicon::Role::StoreFilter
);

Usage of that optional filter

use Locale::TextDomain::OO::Lexicon::Store...;

my $obj = Locale::TextDomain::OO::Lexicon::Store...->new(
    ...
    # all parameters optional
    filter_language => undef,
    filter_category => 'cat1',
    filter_domain   => qr{ \A dom }xms,
    filter_project  => sub {
        my $filter_name = shift;   # $filter_name eq 'filter_project'
        return $_ eq 'my project'; # $_ contains the value
    },
);
$obj->copy;
$obj->clear_filter;
$obj->filter_language('en');
$obj->remove;
$obj->to_...;

SUBROUTINES/METHODS

method filter_language, filter_category, filter_domain, filter_project

Set a filter as undef, string, regex or code reference.

method clear_filter

Set filter_language, filter_category, filter_domain, filter_project to undef.

$obj->clear_filter;

method copy

Copies lexicon entries with matching filter from singleton lexicon to data (new lexicon).

$obj->copy;

method remove

Removes lexicon entries with matching filter from data (new lexicon).

$obj->remove;

method data

Get back that filtered lexicon data.

$data = $obj->data;

EXAMPLE

Inside of this distribution is a directory named example. Run this *.pl files.

DIAGNOSTICS

none

CONFIGURATION AND ENVIRONMENT

none

DEPENDENCIES

Carp

Clone

Locale::TextDomain::OO::Singleton::Lexicon

Locale::TextDomain::OO::Util::JoinSplitLexiconKeys

Moo::Role

MooX::Types::MooseLike::Base

namespace::autoclean

INCOMPATIBILITIES

not known

BUGS AND LIMITATIONS

none

SEE ALSO

Locale::TextDoamin::OO

AUTHOR

Steffen Winkler

LICENSE AND COPYRIGHT

Copyright (c) 2013 - 2015, Steffen Winkler <steffenw at cpan.org>. All rights reserved.

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