blob: 5da792f1f0413f6b5665321df9efbdfa885c96fd (
plain)
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
|
# Before `make install' is performed this script should be runnable with
# `make test'. After `make install' it should work as `perl test.pl'
use 5.008001;
use strict;
use warnings;
######################### We start with some black magic to print on failure.
# Change 1..1 below to 1..last_test_to_print .
# (It may become useful if the test is moved to ./t subdirectory.)
my $loaded = 0;
BEGIN { $| = 1; print "1..19\n"; }
END {print "not ok 1\n" unless $loaded;}
use Text::Balanced qw ( extract_bracketed );
$loaded = 1;
print "ok 1\n";
my $count=2;
use vars qw( $DEBUG );
sub debug { print "\t>>>",@_ if $DEBUG }
######################### End of black magic.
## no critic (BuiltinFunctions::ProhibitStringyEval)
my $cmd = "print";
my $neg = 0;
my $str;
while (defined($str = <DATA>))
{
chomp $str;
if ($str =~ s/\A# USING://) { $neg = 0; $cmd = $str; next; }
elsif ($str =~ /\A# TH[EI]SE? SHOULD FAIL/) { $neg = 1; next; }
elsif (!$str || $str =~ /\A#/) { $neg = 0; next }
$str =~ s/\\n/\n/g;
debug "\tUsing: $cmd\n";
debug "\t on: [$str]\n";
my $var = eval "() = $cmd";
debug "\t list got: [$var]\n";
debug "\t list left: [$str]\n";
print "not " if (substr($str,pos($str),1) eq ';')==$neg;
print "ok ", $count++;
print " ($@)" if $@ && $DEBUG;
print "\n";
pos $str = 0;
$var = eval $cmd;
$var = "<undef>" unless defined $var;
debug "\t scalar got: [$var]\n";
debug "\t scalar left: [$str]\n";
print "not " if ($str =~ '\A;')==$neg;
print "ok ", $count++;
print " ($@)" if $@ && $DEBUG;
print "\n";
}
__DATA__
# USING: extract_bracketed($str);
{a nested { and } are okay as are () and <> pairs and escaped \}'s };
{a nested\n{ and } are okay as are\n() and <> pairs and escaped \}'s };
# USING: extract_bracketed($str,'{}');
{a nested { and } are okay as are unbalanced ( and < pairs and escaped \}'s };
# THESE SHOULD FAIL
{an unmatched nested { isn't okay, nor are ( and < };
{an unbalanced nested [ even with } and ] to match them;
# USING: extract_bracketed($str,'<"`q>');
<a q{uoted} ">" unbalanced right bracket of /(q>)/ either sort (`>>>""">>>>`) is okay >;
# USING: extract_bracketed($str,'<">');
<a quoted ">" unbalanced right bracket is okay >;
# USING: extract_bracketed($str,'<"`>');
<a quoted ">" unbalanced right bracket of either sort (`>>>""">>>>`) is okay >;
# THIS SHOULD FAIL
<a misquoted '>' unbalanced right bracket is bad >;
|