From: Chip Salzenberg Date: Wed, 19 Feb 1997 22:43:28 +0000 (+1200) Subject: Include 'study' in regexp.t X-Git-Url: http://git.shadowcat.co.uk/gitweb/gitweb.cgi?a=commitdiff_plain;h=cfa4f241474ab59f4e40e1ae0c286d51ff246f4a;p=p5sagit%2Fp5-mst-13.2.git Include 'study' in regexp.t --- diff --git a/t/op/regexp.t b/t/op/regexp.t index af8a666..c696924 100755 --- a/t/op/regexp.t +++ b/t/op/regexp.t @@ -1,35 +1,37 @@ #!./perl -# $RCSfile: regexp.t,v $$Revision: 4.1 $$Date: 92/08/07 18:28:20 $ - open(TESTS,'op/re_tests') || open(TESTS,'t/op/re_tests') || die "Can't open re_tests"; + while () { } $numtests = $.; -close(TESTS); +seek(TESTS,0,0); +$. = 0; -print "1..$numtests\n"; -open(TESTS,'op/re_tests') || open(TESTS,'t/op/re_tests') - || die "Can't open re_tests"; $| = 1; +print "1..$numtests\n"; +TEST: while () { ($pat, $subject, $result, $repl, $expect) = split(/[\t\n]/,$_); $input = join(':',$pat,$subject,$result,$repl,$expect); $pat = "'$pat'" unless $pat =~ /^'/; - eval "\$match = (\$subject =~ m$pat); \$got = \"$repl\";"; - if ($result eq 'c') { - if ($@ ne '') {print "ok $.\n";} else {print "not ok $.\n";} - } - elsif ($result eq 'n') { - if (!$match) {print "ok $.\n";} else {print "not ok $. $input => $got\n";} - } - else { - if ($match && $got eq $expect) { - print "ok $.\n"; + for $study ("", "study \$match") { + eval "$study; \$match = (\$subject =~ m$pat); \$got = \"$repl\";"; + if ($result eq 'c') { + if ($@ eq '') { print "not ok $.\n"; next TEST } + last; # no need to study a syntax error + } + elsif ($result eq 'n') { + if ($match) { print "not ok $. $input => $got\n"; next TEST } } else { - print "not ok $. $input => $got\n"; + if (!$match || $got ne $expect) { + print "not ok $. $input => $got\n"; + next TEST; + } } } + print "ok $.\n"; } + close(TESTS);