Why not adopt me?
NAME
IRC::Toolkit::Case - IRC case-folding utilities
SYNOPSIS
use IRC::Toolkit::Case;
my $lower = lc_irc( $string, 'rfc1459' );
my $upper = uc_irc( $string, 'ascii' );
if (eq_irc($first, $second, 'strict-rfc1459')) {
...
}
# Or use the '|rfc1459|' operator if using RFC1459 rules:
if ($first |rfc1459| $second) {
}
DESCRIPTION
IRC case-folding utilities.
IRC daemons typically announce their casemap in ISUPPORT (via the CASEMAPPING directive). This should be one of rfc1459
, strict-rfc1459
, or ascii
:
'ascii' a-z --> A-Z
'rfc1459' a-z{}|^ --> A-Z[]\~ (default)
'strict-rfc1459' a-z{}| --> A-Z[]\
If told to convert/compare an unknown casemap, these functions will warn and default to RFC1459 rules.
If you're building a class that tracks an IRC casemapping and manipulates strings accordingly, you may also want to see IRC::Toolkit::Role::CaseMap.
rfc1459 operator
The infix operator |rfc1459|
is provided as a convenience for string comparison using RFC1459 rules:
if ($first |rfc1459| $second) { ... }
# Same as:
if (eq_irc($first, $second)) { ... }
lc_irc
Takes a string and an optional casemap.
Returns the lowercased string.
uc_irc
Takes a string and an optional casemap.
Returns the uppercased string.
eq_irc
Takes a pair of strings and an optional casemap.
Returns boolean true if the strings are equal (per the rules specified by the given casemap).
irc_str
my $str = irc_str( strict => 'Nick^[Abc]' );
if ( $str eq 'nick^{abc}' ) {
# true
}
Takes a casemap and string; if only one argument is provided, it is taken to be the string and a rfc1459
casemap is assumed.
Produces overloaded objects (see IRC::Toolkit::Case::MappedString) that can be stringified or compared; string comparison operators use the specified casemap.
AUTHOR
Jon Portnoy <avenj@cobaltirc.org>
Inspired by IRC::Utils, copyright Chris Williams, Hinrik et al