1NOTE implicit vs. explicit repetitions : 2009-02-02 2 3# Glenn Fowler <[email protected]> 4# conforming matches (column 4) must match one of the following BREs 5# NOMATCH 6# (0,.)\((\(.\),\(.\))(?,?)(\2,\3)\)* 7# (0,.)\((\(.\),\(.\))(\2,\3)(?,?)\)* 8# i.e., each 3-tuple has two identical elements and one (?,?) 9 10NOTE additional repetition tests graciously provided by Chris Kuklewicz www.haskell.org 2009-02-02 11 12:HA#100:E X(.?){0,}Y X1234567Y (0,9)(7,8) 13:HA#101:E X(.?){1,}Y X1234567Y (0,9)(7,8) 14:HA#102:E X(.?){2,}Y X1234567Y (0,9)(7,8) 15:HA#103:E X(.?){3,}Y X1234567Y (0,9)(7,8) 16:HA#104:E X(.?){4,}Y X1234567Y (0,9)(7,8) 17:HA#105:E X(.?){5,}Y X1234567Y (0,9)(7,8) 18:HA#106:E X(.?){6,}Y X1234567Y (0,9)(7,8) 19:HA#107:E X(.?){7,}Y X1234567Y (0,9)(7,8) 20:HA#108:E X(.?){8,}Y X1234567Y (0,9)(8,8) 21#:HA#110:E X(.?){0,8}Y X1234567Y (0,9)(7,8) 22:HA#110:E X(.?){0,8}Y X1234567Y (0,9)(8,8) RE2/Go 23#:HA#111:E X(.?){1,8}Y X1234567Y (0,9)(7,8) 24:HA#111:E X(.?){1,8}Y X1234567Y (0,9)(8,8) RE2/Go 25#:HA#112:E X(.?){2,8}Y X1234567Y (0,9)(7,8) 26:HA#112:E X(.?){2,8}Y X1234567Y (0,9)(8,8) RE2/Go 27#:HA#113:E X(.?){3,8}Y X1234567Y (0,9)(7,8) 28:HA#113:E X(.?){3,8}Y X1234567Y (0,9)(8,8) RE2/Go 29#:HA#114:E X(.?){4,8}Y X1234567Y (0,9)(7,8) 30:HA#114:E X(.?){4,8}Y X1234567Y (0,9)(8,8) RE2/Go 31#:HA#115:E X(.?){5,8}Y X1234567Y (0,9)(7,8) 32:HA#115:E X(.?){5,8}Y X1234567Y (0,9)(8,8) RE2/Go 33#:HA#116:E X(.?){6,8}Y X1234567Y (0,9)(7,8) 34:HA#116:E X(.?){6,8}Y X1234567Y (0,9)(8,8) RE2/Go 35#:HA#117:E X(.?){7,8}Y X1234567Y (0,9)(7,8) 36:HA#117:E X(.?){7,8}Y X1234567Y (0,9)(8,8) RE2/Go 37:HA#118:E X(.?){8,8}Y X1234567Y (0,9)(8,8) 38 39# These test a fixed bug in my regex-tdfa that did not keep the expanded 40# form properly grouped, so right association did the wrong thing with 41# these ambiguous patterns (crafted just to test my code when I became 42# suspicious of my implementation). The first subexpression should use 43# "ab" then "a" then "bcd". 44 45# OS X / FreeBSD / NetBSD badly fail many of these, with impossible 46# results like (0,6)(4,5)(6,6). 47 48:HA#260:E (a|ab|c|bcd){0,}(d*) ababcd (0,1)(0,1)(1,1) 49:HA#261:E (a|ab|c|bcd){1,}(d*) ababcd (0,1)(0,1)(1,1) 50:HA#262:E (a|ab|c|bcd){2,}(d*) ababcd (0,6)(3,6)(6,6) 51:HA#263:E (a|ab|c|bcd){3,}(d*) ababcd (0,6)(3,6)(6,6) 52:HA#264:E (a|ab|c|bcd){4,}(d*) ababcd NOMATCH 53:HA#265:E (a|ab|c|bcd){0,10}(d*) ababcd (0,1)(0,1)(1,1) 54:HA#266:E (a|ab|c|bcd){1,10}(d*) ababcd (0,1)(0,1)(1,1) 55:HA#267:E (a|ab|c|bcd){2,10}(d*) ababcd (0,6)(3,6)(6,6) 56:HA#268:E (a|ab|c|bcd){3,10}(d*) ababcd (0,6)(3,6)(6,6) 57:HA#269:E (a|ab|c|bcd){4,10}(d*) ababcd NOMATCH 58:HA#270:E (a|ab|c|bcd)*(d*) ababcd (0,1)(0,1)(1,1) 59:HA#271:E (a|ab|c|bcd)+(d*) ababcd (0,1)(0,1)(1,1) 60 61# The above worked on Linux/GLIBC but the following often fail. 62# They also trip up OS X / FreeBSD / NetBSD: 63 64#:HA#280:E (ab|a|c|bcd){0,}(d*) ababcd (0,6)(3,6)(6,6) 65:HA#280:E (ab|a|c|bcd){0,}(d*) ababcd (0,6)(4,5)(5,6) RE2/Go 66#:HA#281:E (ab|a|c|bcd){1,}(d*) ababcd (0,6)(3,6)(6,6) 67:HA#281:E (ab|a|c|bcd){1,}(d*) ababcd (0,6)(4,5)(5,6) RE2/Go 68#:HA#282:E (ab|a|c|bcd){2,}(d*) ababcd (0,6)(3,6)(6,6) 69:HA#282:E (ab|a|c|bcd){2,}(d*) ababcd (0,6)(4,5)(5,6) RE2/Go 70#:HA#283:E (ab|a|c|bcd){3,}(d*) ababcd (0,6)(3,6)(6,6) 71:HA#283:E (ab|a|c|bcd){3,}(d*) ababcd (0,6)(4,5)(5,6) RE2/Go 72:HA#284:E (ab|a|c|bcd){4,}(d*) ababcd NOMATCH 73#:HA#285:E (ab|a|c|bcd){0,10}(d*) ababcd (0,6)(3,6)(6,6) 74:HA#285:E (ab|a|c|bcd){0,10}(d*) ababcd (0,6)(4,5)(5,6) RE2/Go 75#:HA#286:E (ab|a|c|bcd){1,10}(d*) ababcd (0,6)(3,6)(6,6) 76:HA#286:E (ab|a|c|bcd){1,10}(d*) ababcd (0,6)(4,5)(5,6) RE2/Go 77#:HA#287:E (ab|a|c|bcd){2,10}(d*) ababcd (0,6)(3,6)(6,6) 78:HA#287:E (ab|a|c|bcd){2,10}(d*) ababcd (0,6)(4,5)(5,6) RE2/Go 79#:HA#288:E (ab|a|c|bcd){3,10}(d*) ababcd (0,6)(3,6)(6,6) 80:HA#288:E (ab|a|c|bcd){3,10}(d*) ababcd (0,6)(4,5)(5,6) RE2/Go 81:HA#289:E (ab|a|c|bcd){4,10}(d*) ababcd NOMATCH 82#:HA#290:E (ab|a|c|bcd)*(d*) ababcd (0,6)(3,6)(6,6) 83:HA#290:E (ab|a|c|bcd)*(d*) ababcd (0,6)(4,5)(5,6) RE2/Go 84#:HA#291:E (ab|a|c|bcd)+(d*) ababcd (0,6)(3,6)(6,6) 85:HA#291:E (ab|a|c|bcd)+(d*) ababcd (0,6)(4,5)(5,6) RE2/Go 86