1272343SngieNOTE	implicit vs. explicit repetitions : 2009-02-02
2272343Sngie
3272343Sngie# Glenn Fowler <gsf@research.att.com>
4272343Sngie# conforming matches (column 4) must match one of the following BREs
5272343Sngie#	NOMATCH
6272343Sngie#	(0,.)\((\(.\),\(.\))(?,?)(\2,\3)\)*
7272343Sngie#	(0,.)\((\(.\),\(.\))(\2,\3)(?,?)\)*
8272343Sngie# i.e., each 3-tuple has two identical elements and one (?,?)
9272343Sngie
10272343SngieE	((..)|(.))				NULL		NOMATCH
11272343SngieE	((..)|(.))((..)|(.))			NULL		NOMATCH
12272343SngieE	((..)|(.))((..)|(.))((..)|(.))		NULL		NOMATCH
13272343Sngie
14272343SngieE	((..)|(.)){1}				NULL		NOMATCH
15272343SngieE	((..)|(.)){2}				NULL		NOMATCH
16272343SngieE	((..)|(.)){3}				NULL		NOMATCH
17272343Sngie
18272343SngieE	((..)|(.))*				NULL		(0,0)
19272343Sngie
20272343SngieE	((..)|(.))				a		(0,1)(0,1)(?,?)(0,1)
21272343SngieE	((..)|(.))((..)|(.))			a		NOMATCH
22272343SngieE	((..)|(.))((..)|(.))((..)|(.))		a		NOMATCH
23272343Sngie
24272343SngieE	((..)|(.)){1}				a		(0,1)(0,1)(?,?)(0,1)
25272343SngieE	((..)|(.)){2}				a		NOMATCH
26272343SngieE	((..)|(.)){3}				a		NOMATCH
27272343Sngie
28272343SngieE	((..)|(.))*				a		(0,1)(0,1)(?,?)(0,1)
29272343Sngie
30272343SngieE	((..)|(.))				aa		(0,2)(0,2)(0,2)(?,?)
31272343SngieE	((..)|(.))((..)|(.))			aa		(0,2)(0,1)(?,?)(0,1)(1,2)(?,?)(1,2)
32272343SngieE	((..)|(.))((..)|(.))((..)|(.))		aa		NOMATCH
33272343Sngie
34272343SngieE	((..)|(.)){1}				aa		(0,2)(0,2)(0,2)(?,?)
35272343SngieE	((..)|(.)){2}				aa		(0,2)(1,2)(?,?)(1,2)
36272343SngieE	((..)|(.)){3}				aa		NOMATCH
37272343Sngie
38272343SngieE	((..)|(.))*				aa		(0,2)(0,2)(0,2)(?,?)
39272343Sngie
40272343SngieE	((..)|(.))				aaa		(0,2)(0,2)(0,2)(?,?)
41272343SngieE	((..)|(.))((..)|(.))			aaa		(0,3)(0,2)(0,2)(?,?)(2,3)(?,?)(2,3)
42272343SngieE	((..)|(.))((..)|(.))((..)|(.))		aaa		(0,3)(0,1)(?,?)(0,1)(1,2)(?,?)(1,2)(2,3)(?,?)(2,3)
43272343Sngie
44272343SngieE	((..)|(.)){1}				aaa		(0,2)(0,2)(0,2)(?,?)
45272343SngieE	((..)|(.)){2}				aaa		(0,3)(2,3)(?,?)(2,3)
46272343SngieE	((..)|(.)){3}				aaa		(0,3)(2,3)(?,?)(2,3)
47272343Sngie
48272343SngieE	((..)|(.))*				aaa		(0,3)(2,3)(?,?)(2,3)
49272343Sngie
50272343SngieE	((..)|(.))				aaaa		(0,2)(0,2)(0,2)(?,?)
51272343SngieE	((..)|(.))((..)|(.))			aaaa		(0,4)(0,2)(0,2)(?,?)(2,4)(2,4)(?,?)
52272343SngieE	((..)|(.))((..)|(.))((..)|(.))		aaaa		(0,4)(0,2)(0,2)(?,?)(2,3)(?,?)(2,3)(3,4)(?,?)(3,4)
53272343Sngie
54272343SngieE	((..)|(.)){1}				aaaa		(0,2)(0,2)(0,2)(?,?)
55272343SngieE	((..)|(.)){2}				aaaa		(0,4)(2,4)(2,4)(?,?)
56272343SngieE	((..)|(.)){3}				aaaa		(0,4)(3,4)(?,?)(3,4)
57272343Sngie
58272343SngieE	((..)|(.))*				aaaa		(0,4)(2,4)(2,4)(?,?)
59272343Sngie
60272343SngieE	((..)|(.))				aaaaa		(0,2)(0,2)(0,2)(?,?)
61272343SngieE	((..)|(.))((..)|(.))			aaaaa		(0,4)(0,2)(0,2)(?,?)(2,4)(2,4)(?,?)
62272343SngieE	((..)|(.))((..)|(.))((..)|(.))		aaaaa		(0,5)(0,2)(0,2)(?,?)(2,4)(2,4)(?,?)(4,5)(?,?)(4,5)
63272343Sngie
64272343SngieE	((..)|(.)){1}				aaaaa		(0,2)(0,2)(0,2)(?,?)
65272343SngieE	((..)|(.)){2}				aaaaa		(0,4)(2,4)(2,4)(?,?)
66272343SngieE	((..)|(.)){3}				aaaaa		(0,5)(4,5)(?,?)(4,5)
67272343Sngie
68272343SngieE	((..)|(.))*				aaaaa		(0,5)(4,5)(?,?)(4,5)
69272343Sngie
70272343SngieE	((..)|(.))				aaaaaa		(0,2)(0,2)(0,2)(?,?)
71272343SngieE	((..)|(.))((..)|(.))			aaaaaa		(0,4)(0,2)(0,2)(?,?)(2,4)(2,4)(?,?)
72272343SngieE	((..)|(.))((..)|(.))((..)|(.))		aaaaaa		(0,6)(0,2)(0,2)(?,?)(2,4)(2,4)(?,?)(4,6)(4,6)(?,?)
73272343Sngie
74272343SngieE	((..)|(.)){1}				aaaaaa		(0,2)(0,2)(0,2)(?,?)
75272343SngieE	((..)|(.)){2}				aaaaaa		(0,4)(2,4)(2,4)(?,?)
76272343SngieE	((..)|(.)){3}				aaaaaa		(0,6)(4,6)(4,6)(?,?)
77272343Sngie
78272343SngieE	((..)|(.))*				aaaaaa		(0,6)(4,6)(4,6)(?,?)
79272343Sngie
80272343SngieNOTE	additional repetition tests graciously provided by Chris Kuklewicz www.haskell.org 2009-02-02
81272343Sngie
82272343Sngie# These test a bug in OS X / FreeBSD / NetBSD, and libtree. 
83272343Sngie# Linux/GLIBC gets the {8,} and {8,8} wrong.
84272343Sngie
85272343Sngie:HA#100:E	X(.?){0,}Y	X1234567Y	(0,9)(7,8)
86272343Sngie:HA#101:E	X(.?){1,}Y	X1234567Y	(0,9)(7,8)
87272343Sngie:HA#102:E	X(.?){2,}Y	X1234567Y	(0,9)(7,8)
88272343Sngie:HA#103:E	X(.?){3,}Y	X1234567Y	(0,9)(7,8)
89272343Sngie:HA#104:E	X(.?){4,}Y	X1234567Y	(0,9)(7,8)
90272343Sngie:HA#105:E	X(.?){5,}Y	X1234567Y	(0,9)(7,8)
91272343Sngie:HA#106:E	X(.?){6,}Y	X1234567Y	(0,9)(7,8)
92272343Sngie:HA#107:E	X(.?){7,}Y	X1234567Y	(0,9)(7,8)
93272343Sngie:HA#108:E	X(.?){8,}Y	X1234567Y	(0,9)(8,8)
94272343Sngie:HA#110:E	X(.?){0,8}Y	X1234567Y	(0,9)(7,8)
95272343Sngie:HA#111:E	X(.?){1,8}Y	X1234567Y	(0,9)(7,8)
96272343Sngie:HA#112:E	X(.?){2,8}Y	X1234567Y	(0,9)(7,8)
97272343Sngie:HA#113:E	X(.?){3,8}Y	X1234567Y	(0,9)(7,8)
98272343Sngie:HA#114:E	X(.?){4,8}Y	X1234567Y	(0,9)(7,8)
99272343Sngie:HA#115:E	X(.?){5,8}Y	X1234567Y	(0,9)(7,8)
100272343Sngie:HA#116:E	X(.?){6,8}Y	X1234567Y	(0,9)(7,8)
101272343Sngie:HA#117:E	X(.?){7,8}Y	X1234567Y	(0,9)(7,8)
102272343Sngie:HA#118:E	X(.?){8,8}Y	X1234567Y	(0,9)(8,8)
103272343Sngie
104272343Sngie# These test a fixed bug in my regex-tdfa that did not keep the expanded
105272343Sngie# form properly grouped, so right association did the wrong thing with
106272343Sngie# these ambiguous patterns (crafted just to test my code when I became
107272343Sngie# suspicious of my implementation).  The first subexpression should use
108272343Sngie# "ab" then "a" then "bcd".
109272343Sngie
110272343Sngie# OS X / FreeBSD / NetBSD badly fail many of these, with impossible
111272343Sngie# results like (0,6)(4,5)(6,6).
112272343Sngie
113272343Sngie:HA#260:E	(a|ab|c|bcd){0,}(d*)	ababcd	(0,6)(3,6)(6,6)
114272343Sngie:HA#261:E	(a|ab|c|bcd){1,}(d*)	ababcd	(0,6)(3,6)(6,6)
115272343Sngie:HA#262:E	(a|ab|c|bcd){2,}(d*)	ababcd	(0,6)(3,6)(6,6)
116272343Sngie:HA#263:E	(a|ab|c|bcd){3,}(d*)	ababcd	(0,6)(3,6)(6,6)
117272343Sngie:HA#264:E	(a|ab|c|bcd){4,}(d*)	ababcd	NOMATCH
118272343Sngie:HA#265:E	(a|ab|c|bcd){0,10}(d*)	ababcd	(0,6)(3,6)(6,6)
119272343Sngie:HA#266:E	(a|ab|c|bcd){1,10}(d*)	ababcd	(0,6)(3,6)(6,6)
120272343Sngie:HA#267:E	(a|ab|c|bcd){2,10}(d*)	ababcd	(0,6)(3,6)(6,6)
121272343Sngie:HA#268:E	(a|ab|c|bcd){3,10}(d*)	ababcd	(0,6)(3,6)(6,6)
122272343Sngie:HA#269:E	(a|ab|c|bcd){4,10}(d*)	ababcd	NOMATCH
123272343Sngie:HA#270:E	(a|ab|c|bcd)*(d*)	ababcd	(0,6)(3,6)(6,6)
124272343Sngie:HA#271:E	(a|ab|c|bcd)+(d*)	ababcd	(0,6)(3,6)(6,6)
125272343Sngie
126272343Sngie# The above worked on Linux/GLIBC but the following often fail.
127272343Sngie# They also trip up OS X / FreeBSD / NetBSD:
128272343Sngie
129272343Sngie:HA#280:E	(ab|a|c|bcd){0,}(d*)	ababcd	(0,6)(3,6)(6,6)
130272343Sngie:HA#281:E	(ab|a|c|bcd){1,}(d*)	ababcd	(0,6)(3,6)(6,6)
131272343Sngie:HA#282:E	(ab|a|c|bcd){2,}(d*)	ababcd	(0,6)(3,6)(6,6)
132272343Sngie:HA#283:E	(ab|a|c|bcd){3,}(d*)	ababcd	(0,6)(3,6)(6,6)
133272343Sngie:HA#284:E	(ab|a|c|bcd){4,}(d*)	ababcd	NOMATCH
134272343Sngie:HA#285:E	(ab|a|c|bcd){0,10}(d*)	ababcd	(0,6)(3,6)(6,6)
135272343Sngie:HA#286:E	(ab|a|c|bcd){1,10}(d*)	ababcd	(0,6)(3,6)(6,6)
136272343Sngie:HA#287:E	(ab|a|c|bcd){2,10}(d*)	ababcd	(0,6)(3,6)(6,6)
137272343Sngie:HA#288:E	(ab|a|c|bcd){3,10}(d*)	ababcd	(0,6)(3,6)(6,6)
138272343Sngie:HA#289:E	(ab|a|c|bcd){4,10}(d*)	ababcd	NOMATCH
139272343Sngie:HA#290:E	(ab|a|c|bcd)*(d*)	ababcd	(0,6)(3,6)(6,6)
140272343Sngie:HA#291:E	(ab|a|c|bcd)+(d*)	ababcd	(0,6)(3,6)(6,6)
141