NAME
Regexp::Cherokee - Regular Expressions Support for Cherokee Script.
SYNOPSIS
#
# Overloading Perl REs:
#
use utf8;
use Regexp::Cherokee qw(overload setForm);
:
s/([#2#])/setForm($1,6)/eg;
s/([ᎠᎦᎧᎭ]%2)/setForm($1,6)/eg;
s/([ᎠᎦᎧᎭ]%{1,3})/setForm($1,6)/eg;
s/([ᎠᎦᎧᎭ]%{1-3,7})/setForm($1,6)/eg;
s/([#Ꮎ#])/subForm('Ꮬ',$1)/eg; # substitute, a 'Ꮬ' for a 'Ꮎ' in the form found for the 'Ꮎ'
if ( /[#Ꮜ#]/ ) {
#
# do something
#
:
}
:
:
#
# Without overloading:
#
use utf8;
require Regexp::Cherokee;
my $string = "[ᎠᎦᎧᎭ]%{1-3,7}";
my $re = Regexp::Cherokee::getRe ( $string );
s/abc($re)xyz/"abc".Regexp::Cherokee::setForm($1,6)."xyz"/eg;
DESCRIPTION
The Regexp::Cherokee module provides POSIX style character class definitions for working with the Cherokee syllabary. The character classes provided by the Regexp::Cherokee package correspond to inate properties of the script and are language independent.
The Regexp::Cherokee package is NOT derived from the Regexp class and may not be instantiated into an object. Regexp::Cherokee 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 Cherokee 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 Cherokee 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::Ethiopic package as expected:
use Regexp::Cherokee '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::Cherokee 'overload';
my $x = "Ꭷ";
:
:
my $re = Regexp::Cherokee::getRe ( "[#$x#]" );
if ( /$re/ ) {
:
:
}
This works as expected at the cost of one extra step. The overloading and functional modes of the Regexp::Cherokee 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:
examples/overload.pl examples/utils.p