NAME

CodeGen::Cpppp::AntiCharacter - AntiCharacters combine with characters to produce nothing

VERSION

version 0.002

SYNOPSIS

my $anticomma= CodeGen::Cpppp::AntiCharacter->new(qr/,/);
say '1,2,3,' . $anticomma;  # 1,2,3\n
say '1,2,3' . $anticomma;   # 1,2,3\n

my $antiword= CodeGen::Cpppp::AntiCharacter->new(qr/\w+/);
say "apple,bananna" . $antiword; # apple,\n

# skip over whitespace, but preserve the whitespace
my $anticomma= CodeGen::Cpppp::AntiCharacter->new(qr/,/, qr/\s*/);
say "1,2,\n  " . $anticomma;  # "1,2\n  \n"

DESCRIPTION

Anticharacter is an object that eliminates characters at the end of a string when it is concatenated to that string. It has an optional second parameter of characters to ignore while looking for the characters to remove.

If the concatenation does not remove all of the target characters, the concatenation returns another object which can continue the hunt.

Anticharacters do not work with join, only with regular concatenation. Stringifying an anticharacter ends the search and returns a simple string of anything that had accumulated during the search for the characters to remove.

CONSTRUCTOR

new

$antichar= $class->new( $negate_regex, $skip_regex = undef );

Return a new AntiCharacter object. The $negate_regex is required, and should be the pattern you want to find on the end of a string as if you had written

s/$negate_regex\Z//

The optional $skip_regex is a pattern to ignore, as if you had written

s/$negate_regex($skip_regex)\Z/$1/

METHODS

concat

This is the method invoked when an AntiCharacter is concatenated with anything else.

$maybe_antichar= $antichar->concat( $other_thing, $reverse );

If reverse is false, meaning $other_thing is being appended to the antichar, the result is a new AntiCharacter with that string as an additional suffix.

If reverse is true, meaning $other_thing is a prefix of the AntiCharacter, this checks to see if the $negate_regex can be applied and does not reach the start of the string, meaning it has negated exactly what it was supposed to. In that case it returns a plain string. If the entire string would be consumed, it returns another anticharacter in case further concatenations find a larger match to remove. If the negate pattern does not match, this returns a plain string assuming the anticharacter will never match.

AUTHOR

Michael Conrad <mike@nrdvana.net>

COPYRIGHT AND LICENSE

This software is copyright (c) 2023 by Michael Conrad.

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