Update:Duh, the ':0:' is part of the regexp. Just add the third argument to split, as JavaFan stated above.
@FIELDS=split(/:/, "$RECORD");
You are splitting the text version of your regular expression on the ':' character, and since the regexp has that character in it, the split does the wrong thing.
Perhaps something along the lines of:
my ($TNAME, $TVALU, $TFILE, $REGEX, $REST); if ($RECORD =~ m/^([^:]+):([^:]+):([^:]+):(.+):([^:]+):$/) { $TNAME = $1; $TVALU = $2; $TFILE = $3; $REGEX = $4; $REST = $5;
Basically, you want to remove everything that is not the regexp (which do not contain ':'), and everything that is left ((.+)) is the regular expression.
Either that, or figure out how to escape the ':' character in the text file. If there are a variable number of fields in the configuration file, then escaping the character might be a better solution.
Changing the number of fields in the configuration file will require alteration of the parsing code. Escaping the ':' character could provide a more resilient solution against added fields.
On a side note, the chomp($REGEX) is useless, since it comes in from the middle of the line.
On another side note, quoting the $RECORD variable in the split statement is a useless operation.
My wife is walking for a cure for MS. Please consider supporting her.
In reply to Re: Test RegEx
by MidLifeXis
in thread Test RegEx
by Saved
| For: | Use: | ||
| & | & | ||
| < | < | ||
| > | > | ||
| [ | [ | ||
| ] | ] |