NAME

String::Index - Perl XS module for strchr()/index() hybrids

SYNOPSIS

use String::Index qw( cindex ncindex crindex ncrindex );

$first_vowel    =   cindex("broadcast", "aeiouy");  # 2
$last_vowel     =  rcindex("broadcast", "aeiouy");  # 6
$first_nonvowel =  ncindex("eerily",    "aeiouy");  # 2
$last_nonvowel  = ncrindex("eerily",    "aeiouy");  # 4

ABSTRACT

This module provides functions that are a cross between Perl's index() and rindex() and C's strchr() and strrchr().

DESCRIPTION

This module provides four functions that are Perl/C hybrids. They allow you to scan a string for the first or last occurrence of any of a set of characters, or not of a set of characters.

Exported on request

There are four functions, which must be exported explicitly.

cindex(STR, CHARS, POSITION)
cindex(STR, CHARS)

It returns the position of the first occurrence of one of CHARS in STR at or after POSITION. If POSITION is omitted, starts searching from the beginning of the string. The return value is based at 0. If none of the characters you are searching for are found, it returns -1.

ncindex(STR, CHARS, POSITION)
ncindex(STR, CHARS)

It returns the position of the first occurrence of a character other than those in the string CHARS in STR at or after POSITION. If POSITION is omitted, starts searching from the beginning of the string. The return value is based at 0. If STR is composed entirely of characters in CHARS, it returns -1.

crindex(STR, CHARS, POSITION)
crindex(STR, CHARS)

Works just like cindex() except that it returns the position of the LAST occurrence of any of CHARS in STR. If POSITION is specified, returns the last occurrence at or before that position.

ncrindex(STR, CHARS, POSITION)
ncrindex(STR, CHARS)

Works just like ncindex() except that it returns the position of the LAST occurrence of any character other than those in CHARS in STR. If POSITION is specified, returns the last occurrence at or before that position.

SEE ALSO

See the man page for strchr().

AUTHOR

Jeff japhy Pinyan, <japhy@pobox.com>

COPYRIGHT AND LICENSE

Copyright 2004 by japhy

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