NAME

Regexp::Ethiopic - Regular Expressions Support for Ethiopic Script.

SYNOPSIS

#
#  Overloading Perl REs:
#
use utf8;
use Regexp::Ethiopic qw(:forms overload setForm);

:

s/([#2#])/setForm($1,$ሳድስ)/eg;
s/([መረበወ]{#2#})/setForm($1,$ሳድስ)/eg;
s/([መረበወ]{#1,3#})/setForm($1,$ሳድስ)/eg;
s/([መረበወ]{#1-3,7#})/setForm($1,$ሳድስ)/eg;
s/([#ፀ#])/subForm('ጸ',$1)/eg;  # substitute, a 'ጸ' for a 'ፀ' in the form found for the 'ፀ'

if ( /[#ኘ#]/ ) {
  #
  # do something
  #
  :
}

:
:

#
#  Without overloading:
#
use utf8;
require Regexp::Ethiopic;

my $string = "[መረበወ]{#1-3,7#}";
my $re = Regexp::Ethiopic::getRe ( $string );

s/abc($re)xyz/"abc".Regexp::Ethipic::setForm($1,6)."xyz"/eg;

DESCRIPTION

The Regexp::Ethiopic module provides POSIX style character class definitions for working with the Ethiopic syllabary. The character classes provided by the Regexp::Ethiopic package correspond to inate properties of the script and are language independent.

The Regexp::Ethiopic package is NOT derived from the Regexp class and may not be instantiated into an object. Regexp::Ethiopic can optionally export the utility functions getForm, setForm, subForm and formatForms (or all with the :utils pragma) to query or set the form of an Ethiopic character. Tags of variables in the form names set to form values may be exported under the :forms pragma.

See the files in the doc/ and examples/ directories that are included with this package.

Substituion Utilities

getForm

A utility function to query the "form" of an Ethiopic syllable. It will return an integer between 1 and 12 corresponding to the [#\d+#] classes.

print getForm ( "አ" ), "\n";  # prints 1

setForm

A utility function to set the form number of a syllable. The form number must be an integer between 1 and 12 corresponding to the [#\d+#] classes.

s/(.)/setForm($1, 1)/eg;

subForm

A utility function to set the form number of a syllable based on the form of another syllable.

s/(\w+)([#ፀ#])/$1.subForm('ጸ', $2)/eg;

formatForms

A utility function somewhat analogous to sprintf for a sequence of syllables:

print formatForms ( "%1%2%3%4", "አበገደ" ), "\n";  # prints አቡጊዳ

LIMITATIONS

The overloading mechanism only applies to the constant part of the RE. The following would not be handled by the Regexp::Ethipic package as expected:

use Regexp::Ethiopic 'overload';

my $x = "ከ";
      :
      :
if ( /[#$x#]/ ) {
      :
      :
}

The package never gets to see the variable $x to then perform the RE expansion. The work around is to use the package as per:

use Regexp::Ethiopic 'overload';

my $x = "ከ";
      :
      :
my $re = Regexp::Ethiopic::getRe ( "[#$x#]" );

if ( /$re/ ) {
      :
      :
}

This works as expected at the cost of one extra step. The overloading and functional modes of the Regexp::Ethiopic package may be used together without conflict.

REQUIRES

Works perfectly with Perl 5.8.0, may work with Perl 5.6.x but has not yet been tested.

BUGS

None presently known.

AUTHOR

Daniel Yacob, dyacob@cpan.org

SEE ALSO

Included with this package:

doc/index.html       examples/overload.pl
examples/utils.pl    examples/asfunction.pl