2003-12-04 09:04:57 +01:00
|
|
|
;
|
|
|
|
;
|
|
|
|
; this file contains a script of tests to run through regress.exe
|
|
|
|
;
|
|
|
|
; comments start with a semicolon and proceed to the end of the line
|
|
|
|
;
|
|
|
|
; changes to regular expression compile flags start with a "-" as the first
|
|
|
|
; non-whitespace character and consist of a list of the printable names
|
|
|
|
; of the flags, for example "match_default"
|
|
|
|
;
|
|
|
|
; Other lines contain a test to perform using the current flag status
|
|
|
|
; the first token contains the expression to compile, the second the string
|
|
|
|
; to match it against. If the second string is "!" then the expression should
|
|
|
|
; not compile, that is the first string is an invalid regular expression.
|
|
|
|
; This is then followed by a list of integers that specify what should match,
|
|
|
|
; each pair represents the starting and ending positions of a subexpression
|
|
|
|
; starting with the zeroth subexpression (the whole match).
|
|
|
|
; A value of -1 indicates that the subexpression should not take part in the
|
|
|
|
; match at all, if the first value is -1 then no part of the expression should
|
|
|
|
; match the string.
|
|
|
|
;
|
|
|
|
; Tests taken from BOOST testsuite and adapted to glibc regex.
|
|
|
|
;
|
|
|
|
; Boost Software License - Version 1.0 - August 17th, 2003
|
|
|
|
;
|
|
|
|
; Permission is hereby granted, free of charge, to any person or organization
|
|
|
|
; obtaining a copy of the software and accompanying documentation covered by
|
|
|
|
; this license (the "Software") to use, reproduce, display, distribute,
|
|
|
|
; execute, and transmit the Software, and to prepare derivative works of the
|
|
|
|
; Software, and to permit third-parties to whom the Software is furnished to
|
|
|
|
; do so, all subject to the following:
|
|
|
|
;
|
|
|
|
; The copyright notices in the Software and this entire statement, including
|
|
|
|
; the above license grant, this restriction and the following disclaimer,
|
|
|
|
; must be included in all copies of the Software, in whole or in part, and
|
|
|
|
; all derivative works of the Software, unless such copies or derivative
|
|
|
|
; works are solely in the form of machine-executable object code generated by
|
|
|
|
; a source language processor.
|
|
|
|
;
|
|
|
|
; THE SOFTWARE IS PROVIDED "AS IS", WITHOUT WARRANTY OF ANY KIND, EXPRESS OR
|
|
|
|
; IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF MERCHANTABILITY,
|
|
|
|
; FITNESS FOR A PARTICULAR PURPOSE, TITLE AND NON-INFRINGEMENT. IN NO EVENT
|
|
|
|
; SHALL THE COPYRIGHT HOLDERS OR ANYONE DISTRIBUTING THE SOFTWARE BE LIABLE
|
|
|
|
; FOR ANY DAMAGES OR OTHER LIABILITY, WHETHER IN CONTRACT, TORT OR OTHERWISE,
|
|
|
|
; ARISING FROM, OUT OF OR IN CONNECTION WITH THE SOFTWARE OR THE USE OR OTHER
|
|
|
|
; DEALINGS IN THE SOFTWARE.
|
|
|
|
;
|
|
|
|
|
|
|
|
- match_default normal REG_EXTENDED
|
|
|
|
|
|
|
|
;
|
|
|
|
; try some really simple literals:
|
|
|
|
a a 0 1
|
|
|
|
Z Z 0 1
|
|
|
|
Z aaa -1 -1
|
|
|
|
Z xxxxZZxxx 4 5
|
|
|
|
|
|
|
|
; and some simple brackets:
|
|
|
|
(a) zzzaazz 3 4 3 4
|
|
|
|
() zzz 0 0 0 0
|
|
|
|
() "" 0 0 0 0
|
|
|
|
( !
|
|
|
|
) ) 0 1
|
|
|
|
(aa !
|
|
|
|
aa) baa)b 1 4
|
|
|
|
a b -1 -1
|
|
|
|
\(\) () 0 2
|
|
|
|
\(a\) (a) 0 3
|
|
|
|
\() () 0 2
|
|
|
|
(\) !
|
|
|
|
p(a)rameter ABCparameterXYZ 3 12 4 5
|
|
|
|
[pq](a)rameter ABCparameterXYZ 3 12 4 5
|
|
|
|
|
|
|
|
; now try escaped brackets:
|
|
|
|
- match_default bk_parens REG_BASIC
|
|
|
|
\(a\) zzzaazz 3 4 3 4
|
|
|
|
\(\) zzz 0 0 0 0
|
|
|
|
\(\) "" 0 0 0 0
|
|
|
|
\( !
|
|
|
|
\) !
|
|
|
|
\(aa !
|
|
|
|
aa\) !
|
|
|
|
() () 0 2
|
|
|
|
(a) (a) 0 3
|
|
|
|
(\) !
|
|
|
|
\() !
|
|
|
|
|
|
|
|
; now move on to "." wildcards
|
|
|
|
- match_default normal REG_EXTENDED REG_STARTEND
|
|
|
|
. a 0 1
|
|
|
|
. \n 0 1
|
|
|
|
. \r 0 1
|
|
|
|
. \0 0 1
|
|
|
|
|
|
|
|
;
|
|
|
|
; now move on to the repetion ops,
|
|
|
|
; starting with operator *
|
|
|
|
- match_default normal REG_EXTENDED
|
|
|
|
a* b 0 0
|
|
|
|
ab* a 0 1
|
|
|
|
ab* ab 0 2
|
|
|
|
ab* sssabbbbbbsss 3 10
|
|
|
|
ab*c* a 0 1
|
|
|
|
ab*c* abbb 0 4
|
|
|
|
ab*c* accc 0 4
|
|
|
|
ab*c* abbcc 0 5
|
|
|
|
*a !
|
|
|
|
\<* !
|
|
|
|
\>* !
|
|
|
|
\n* \n\n 0 2
|
|
|
|
\** ** 0 2
|
|
|
|
\* * 0 1
|
|
|
|
|
|
|
|
; now try operator +
|
|
|
|
ab+ a -1 -1
|
|
|
|
ab+ ab 0 2
|
|
|
|
ab+ sssabbbbbbsss 3 10
|
|
|
|
ab+c+ a -1 -1
|
|
|
|
ab+c+ abbb -1 -1
|
|
|
|
ab+c+ accc -1 -1
|
|
|
|
ab+c+ abbcc 0 5
|
|
|
|
+a !
|
|
|
|
\<+ !
|
|
|
|
\>+ !
|
|
|
|
\n+ \n\n 0 2
|
|
|
|
\+ + 0 1
|
|
|
|
\+ ++ 0 1
|
|
|
|
\++ ++ 0 2
|
|
|
|
|
|
|
|
; now try operator ?
|
|
|
|
- match_default normal REG_EXTENDED
|
|
|
|
a? b 0 0
|
|
|
|
ab? a 0 1
|
|
|
|
ab? ab 0 2
|
|
|
|
ab? sssabbbbbbsss 3 5
|
|
|
|
ab?c? a 0 1
|
|
|
|
ab?c? abbb 0 2
|
|
|
|
ab?c? accc 0 2
|
|
|
|
ab?c? abcc 0 3
|
|
|
|
?a !
|
|
|
|
\<? !
|
|
|
|
\>? !
|
|
|
|
\n? \n\n 0 1
|
|
|
|
\? ? 0 1
|
|
|
|
\? ?? 0 1
|
|
|
|
\?? ?? 0 1
|
|
|
|
|
|
|
|
; now try operator {}
|
|
|
|
- match_default normal REG_EXTENDED
|
|
|
|
a{2} a -1 -1
|
|
|
|
a{2} aa 0 2
|
|
|
|
a{2} aaa 0 2
|
|
|
|
a{2,} a -1 -1
|
|
|
|
a{2,} aa 0 2
|
|
|
|
a{2,} aaaaa 0 5
|
|
|
|
a{2,4} a -1 -1
|
|
|
|
a{2,4} aa 0 2
|
|
|
|
a{2,4} aaa 0 3
|
|
|
|
a{2,4} aaaa 0 4
|
|
|
|
a{2,4} aaaaa 0 4
|
|
|
|
a{} !
|
|
|
|
a{2 !
|
|
|
|
a} a} 0 2
|
|
|
|
\{\} {} 0 2
|
|
|
|
|
|
|
|
- match_default normal REG_BASIC
|
|
|
|
a\{2\} a -1 -1
|
|
|
|
a\{2\} aa 0 2
|
|
|
|
a\{2\} aaa 0 2
|
|
|
|
a\{2,\} a -1 -1
|
|
|
|
a\{2,\} aa 0 2
|
|
|
|
a\{2,\} aaaaa 0 5
|
|
|
|
a\{2,4\} a -1 -1
|
|
|
|
a\{2,4\} aa 0 2
|
|
|
|
a\{2,4\} aaa 0 3
|
|
|
|
a\{2,4\} aaaa 0 4
|
|
|
|
a\{2,4\} aaaaa 0 4
|
|
|
|
{} {} 0 2
|
|
|
|
|
|
|
|
; now test the alternation operator |
|
|
|
|
- match_default normal REG_EXTENDED
|
|
|
|
a|b a 0 1
|
|
|
|
a|b b 0 1
|
|
|
|
a(b|c) ab 0 2 1 2
|
|
|
|
a(b|c) ac 0 2 1 2
|
|
|
|
a(b|c) ad -1 -1 -1 -1
|
|
|
|
a\| a| 0 2
|
|
|
|
|
|
|
|
; now test the set operator []
|
|
|
|
- match_default normal REG_EXTENDED
|
|
|
|
; try some literals first
|
|
|
|
[abc] a 0 1
|
|
|
|
[abc] b 0 1
|
|
|
|
[abc] c 0 1
|
|
|
|
[abc] d -1 -1
|
|
|
|
[^bcd] a 0 1
|
|
|
|
[^bcd] b -1 -1
|
|
|
|
[^bcd] d -1 -1
|
|
|
|
[^bcd] e 0 1
|
|
|
|
a[b]c abc 0 3
|
|
|
|
a[ab]c abc 0 3
|
|
|
|
a[^ab]c adc 0 3
|
|
|
|
a[]b]c a]c 0 3
|
|
|
|
a[[b]c a[c 0 3
|
|
|
|
a[-b]c a-c 0 3
|
|
|
|
a[^]b]c adc 0 3
|
|
|
|
a[^-b]c adc 0 3
|
|
|
|
a[b-]c a-c 0 3
|
|
|
|
a[b !
|
|
|
|
a[] !
|
|
|
|
|
|
|
|
; then some ranges
|
|
|
|
[b-e] a -1 -1
|
|
|
|
[b-e] b 0 1
|
|
|
|
[b-e] e 0 1
|
|
|
|
[b-e] f -1 -1
|
|
|
|
[^b-e] a 0 1
|
|
|
|
[^b-e] b -1 -1
|
|
|
|
[^b-e] e -1 -1
|
|
|
|
[^b-e] f 0 1
|
|
|
|
a[1-3]c a2c 0 3
|
|
|
|
a[3-1]c !
|
|
|
|
a[1-3-5]c !
|
|
|
|
a[1- !
|
|
|
|
|
|
|
|
; and some classes
|
|
|
|
a[[:alpha:]]c abc 0 3
|
|
|
|
a[[:unknown:]]c !
|
|
|
|
a[[: !
|
|
|
|
a[[:alpha !
|
|
|
|
a[[:alpha:] !
|
|
|
|
a[[:alpha,:] !
|
|
|
|
a[[:]:]]b !
|
|
|
|
a[[:-:]]b !
|
|
|
|
a[[:alph:]] !
|
|
|
|
a[[:alphabet:]] !
|
|
|
|
[[:alnum:]]+ -%@a0X_- 3 6
|
|
|
|
[[:alpha:]]+ -%@aX_0- 3 5
|
|
|
|
[[:blank:]]+ "a \tb" 1 4
|
|
|
|
[[:cntrl:]]+ a\n\tb 1 3
|
|
|
|
[[:digit:]]+ a019b 1 4
|
|
|
|
[[:graph:]]+ " a%b " 1 4
|
|
|
|
[[:lower:]]+ AabC 1 3
|
|
|
|
; This test fails with STLPort, disable for now as this is a corner case anyway...
|
|
|
|
;[[:print:]]+ "\na b\n" 1 4
|
|
|
|
[[:punct:]]+ " %-&\t" 1 4
|
|
|
|
[[:space:]]+ "a \n\t\rb" 1 5
|
|
|
|
[[:upper:]]+ aBCd 1 3
|
|
|
|
[[:xdigit:]]+ p0f3Cx 1 5
|
|
|
|
|
|
|
|
; now test flag settings:
|
|
|
|
- escape_in_lists REG_NO_POSIX_TEST
|
|
|
|
[\n] \n 0 1
|
|
|
|
- REG_NO_POSIX_TEST
|
|
|
|
|
|
|
|
; line anchors
|
|
|
|
- match_default normal REG_EXTENDED
|
|
|
|
^ab ab 0 2
|
|
|
|
^ab xxabxx -1 -1
|
|
|
|
ab$ ab 0 2
|
|
|
|
ab$ abxx -1 -1
|
|
|
|
- match_default match_not_bol match_not_eol normal REG_EXTENDED REG_NOTBOL REG_NOTEOL
|
|
|
|
^ab ab -1 -1
|
|
|
|
^ab xxabxx -1 -1
|
|
|
|
ab$ ab -1 -1
|
|
|
|
ab$ abxx -1 -1
|
|
|
|
|
|
|
|
; back references
|
|
|
|
- match_default normal REG_PERL
|
|
|
|
a(b)\2c !
|
|
|
|
a(b\1)c !
|
|
|
|
a(b*)c\1d abbcbbd 0 7 1 3
|
|
|
|
a(b*)c\1d abbcbd -1 -1
|
|
|
|
a(b*)c\1d abbcbbbd -1 -1
|
|
|
|
^(.)\1 abc -1 -1
|
|
|
|
a([bc])\1d abcdabbd 4 8 5 6
|
|
|
|
; strictly speaking this is at best ambiguous, at worst wrong, this is what most
|
|
|
|
; re implimentations will match though.
|
|
|
|
a(([bc])\2)*d abbccd 0 6 3 5 3 4
|
|
|
|
|
|
|
|
a(([bc])\2)*d abbcbd -1 -1
|
|
|
|
a((b)*\2)*d abbbd 0 5 1 4 2 3
|
|
|
|
; perl only:
|
|
|
|
(ab*)[ab]*\1 ababaaa 0 7 0 1
|
|
|
|
(a)\1bcd aabcd 0 5 0 1
|
|
|
|
(a)\1bc*d aabcd 0 5 0 1
|
|
|
|
(a)\1bc*d aabd 0 4 0 1
|
|
|
|
(a)\1bc*d aabcccd 0 7 0 1
|
|
|
|
(a)\1bc*[ce]d aabcccd 0 7 0 1
|
|
|
|
^(a)\1b(c)*cd$ aabcccd 0 7 0 1 4 5
|
|
|
|
|
|
|
|
; posix only:
|
|
|
|
- match_default extended REG_EXTENDED
|
|
|
|
(ab*)[ab]*\1 ababaaa 0 7 0 1
|
|
|
|
|
|
|
|
;
|
|
|
|
; word operators:
|
|
|
|
\w a 0 1
|
|
|
|
\w z 0 1
|
|
|
|
\w A 0 1
|
|
|
|
\w Z 0 1
|
|
|
|
\w _ 0 1
|
|
|
|
\w } -1 -1
|
|
|
|
\w ` -1 -1
|
|
|
|
\w [ -1 -1
|
|
|
|
\w @ -1 -1
|
|
|
|
; non-word:
|
|
|
|
\W a -1 -1
|
|
|
|
\W z -1 -1
|
|
|
|
\W A -1 -1
|
|
|
|
\W Z -1 -1
|
|
|
|
\W _ -1 -1
|
|
|
|
\W } 0 1
|
|
|
|
\W ` 0 1
|
|
|
|
\W [ 0 1
|
|
|
|
\W @ 0 1
|
|
|
|
; word start:
|
|
|
|
\<abcd " abcd" 2 6
|
|
|
|
\<ab cab -1 -1
|
|
|
|
\<ab "\nab" 1 3
|
|
|
|
\<tag ::tag 2 5
|
|
|
|
;word end:
|
|
|
|
abc\> abc 0 3
|
|
|
|
abc\> abcd -1 -1
|
|
|
|
abc\> abc\n 0 3
|
|
|
|
abc\> abc:: 0 3
|
|
|
|
; word boundary:
|
|
|
|
\babcd " abcd" 2 6
|
|
|
|
\bab cab -1 -1
|
|
|
|
\bab "\nab" 1 3
|
|
|
|
\btag ::tag 2 5
|
|
|
|
abc\b abc 0 3
|
|
|
|
abc\b abcd -1 -1
|
|
|
|
abc\b abc\n 0 3
|
|
|
|
abc\b abc:: 0 3
|
|
|
|
; within word:
|
|
|
|
\B ab 1 1
|
|
|
|
a\Bb ab 0 2
|
|
|
|
a\B ab 0 1
|
|
|
|
a\B a -1 -1
|
|
|
|
a\B "a " -1 -1
|
|
|
|
|
|
|
|
;
|
|
|
|
; buffer operators:
|
|
|
|
\`abc abc 0 3
|
|
|
|
\`abc \nabc -1 -1
|
|
|
|
\`abc " abc" -1 -1
|
|
|
|
abc\' abc 0 3
|
|
|
|
abc\' abc\n -1 -1
|
|
|
|
abc\' "abc " -1 -1
|
|
|
|
|
|
|
|
;
|
|
|
|
; now follows various complex expressions designed to try and bust the matcher:
|
|
|
|
a(((b)))c abc 0 3 1 2 1 2 1 2
|
|
|
|
a(b|(c))d abd 0 3 1 2 -1 -1
|
|
|
|
a(b|(c))d acd 0 3 1 2 1 2
|
|
|
|
a(b*|c)d abbd 0 4 1 3
|
|
|
|
; just gotta have one DFA-buster, of course
|
|
|
|
a[ab]{20} aaaaabaaaabaaaabaaaab 0 21
|
|
|
|
; and an inline expansion in case somebody gets tricky
|
|
|
|
a[ab][ab][ab][ab][ab][ab][ab][ab][ab][ab][ab][ab][ab][ab][ab][ab][ab][ab][ab][ab] aaaaabaaaabaaaabaaaab 0 21
|
|
|
|
; and in case somebody just slips in an NFA...
|
|
|
|
a[ab][ab][ab][ab][ab][ab][ab][ab][ab][ab][ab][ab][ab][ab][ab][ab][ab][ab][ab][ab](wee|week)(knights|night) aaaaabaaaabaaaabaaaabweeknights 0 31 21 24 24 31
|
|
|
|
; one really big one
|
|
|
|
1234567890123456789012345678901234567890123456789012345678901234567890 a1234567890123456789012345678901234567890123456789012345678901234567890b 1 71
|
|
|
|
; fish for problems as brackets go past 8
|
|
|
|
[ab][cd][ef][gh][ij][kl][mn] xacegikmoq 1 8
|
|
|
|
[ab][cd][ef][gh][ij][kl][mn][op] xacegikmoq 1 9
|
|
|
|
[ab][cd][ef][gh][ij][kl][mn][op][qr] xacegikmoqy 1 10
|
|
|
|
[ab][cd][ef][gh][ij][kl][mn][op][q] xacegikmoqy 1 10
|
|
|
|
; and as parenthesis go past 9:
|
|
|
|
(a)(b)(c)(d)(e)(f)(g)(h) zabcdefghi 1 9 1 2 2 3 3 4 4 5 5 6 6 7 7 8 8 9
|
|
|
|
(a)(b)(c)(d)(e)(f)(g)(h)(i) zabcdefghij 1 10 1 2 2 3 3 4 4 5 5 6 6 7 7 8 8 9 9 10
|
|
|
|
(a)(b)(c)(d)(e)(f)(g)(h)(i)(j) zabcdefghijk 1 11 1 2 2 3 3 4 4 5 5 6 6 7 7 8 8 9 9 10 10 11
|
|
|
|
(a)(b)(c)(d)(e)(f)(g)(h)(i)(j)(k) zabcdefghijkl 1 12 1 2 2 3 3 4 4 5 5 6 6 7 7 8 8 9 9 10 10 11 11 12
|
|
|
|
(a)d|(b)c abc 1 3 -1 -1 1 2
|
|
|
|
_+((www)|(ftp)|(mailto)):_* "_wwwnocolon _mailto:" 12 20 13 19 -1 -1 -1 -1 13 19
|
|
|
|
|
|
|
|
; subtleties of matching
|
|
|
|
;a(b)?c\1d acd 0 3 -1 -1
|
|
|
|
; POSIX is about the following test:
|
|
|
|
a(b)?c\1d acd -1 -1 -1 -1
|
|
|
|
a(b?c)+d accd 0 4 2 3
|
|
|
|
(wee|week)(knights|night) weeknights 0 10 0 3 3 10
|
|
|
|
.* abc 0 3
|
|
|
|
a(b|(c))d abd 0 3 1 2 -1 -1
|
|
|
|
a(b|(c))d acd 0 3 1 2 1 2
|
|
|
|
a(b*|c|e)d abbd 0 4 1 3
|
|
|
|
a(b*|c|e)d acd 0 3 1 2
|
|
|
|
a(b*|c|e)d ad 0 2 1 1
|
|
|
|
a(b?)c abc 0 3 1 2
|
|
|
|
a(b?)c ac 0 2 1 1
|
|
|
|
a(b+)c abc 0 3 1 2
|
|
|
|
a(b+)c abbbc 0 5 1 4
|
|
|
|
a(b*)c ac 0 2 1 1
|
|
|
|
(a|ab)(bc([de]+)f|cde) abcdef 0 6 0 1 1 6 3 5
|
|
|
|
a([bc]?)c abc 0 3 1 2
|
|
|
|
a([bc]?)c ac 0 2 1 1
|
|
|
|
a([bc]+)c abc 0 3 1 2
|
|
|
|
a([bc]+)c abcc 0 4 1 3
|
|
|
|
a([bc]+)bc abcbc 0 5 1 3
|
|
|
|
a(bb+|b)b abb 0 3 1 2
|
|
|
|
a(bbb+|bb+|b)b abb 0 3 1 2
|
|
|
|
a(bbb+|bb+|b)b abbb 0 4 1 3
|
|
|
|
a(bbb+|bb+|b)bb abbb 0 4 1 2
|
|
|
|
(.*).* abcdef 0 6 0 6
|
|
|
|
(a*)* bc 0 0 0 0
|
|
|
|
xyx*xz xyxxxxyxxxz 5 11
|
|
|
|
|
|
|
|
; do we get the right subexpression when it is used more than once?
|
|
|
|
a(b|c)*d ad 0 2 -1 -1
|
|
|
|
a(b|c)*d abcd 0 4 2 3
|
|
|
|
a(b|c)+d abd 0 3 1 2
|
|
|
|
a(b|c)+d abcd 0 4 2 3
|
|
|
|
a(b|c?)+d ad 0 2 1 1
|
|
|
|
a(b|c){0,0}d ad 0 2 -1 -1
|
|
|
|
a(b|c){0,1}d ad 0 2 -1 -1
|
|
|
|
a(b|c){0,1}d abd 0 3 1 2
|
|
|
|
a(b|c){0,2}d ad 0 2 -1 -1
|
|
|
|
a(b|c){0,2}d abcd 0 4 2 3
|
|
|
|
a(b|c){0,}d ad 0 2 -1 -1
|
|
|
|
a(b|c){0,}d abcd 0 4 2 3
|
|
|
|
a(b|c){1,1}d abd 0 3 1 2
|
|
|
|
a(b|c){1,2}d abd 0 3 1 2
|
|
|
|
a(b|c){1,2}d abcd 0 4 2 3
|
|
|
|
a(b|c){1,}d abd 0 3 1 2
|
|
|
|
a(b|c){1,}d abcd 0 4 2 3
|
|
|
|
a(b|c){2,2}d acbd 0 4 2 3
|
|
|
|
a(b|c){2,2}d abcd 0 4 2 3
|
|
|
|
a(b|c){2,4}d abcd 0 4 2 3
|
|
|
|
a(b|c){2,4}d abcbd 0 5 3 4
|
|
|
|
a(b|c){2,4}d abcbcd 0 6 4 5
|
|
|
|
a(b|c){2,}d abcd 0 4 2 3
|
|
|
|
a(b|c){2,}d abcbd 0 5 3 4
|
2003-12-28 00:40:06 +01:00
|
|
|
; perl only: these conflict with the POSIX test below
|
|
|
|
;a(b|c?)+d abcd 0 4 3 3
|
|
|
|
;a(b+|((c)*))+d abd 0 3 2 2 2 2 -1 -1
|
|
|
|
;a(b+|((c)*))+d abcd 0 4 3 3 3 3 2 3
|
2003-12-04 09:04:57 +01:00
|
|
|
|
|
|
|
; posix only:
|
|
|
|
- match_default extended REG_EXTENDED REG_STARTEND
|
|
|
|
|
2003-12-28 00:40:06 +01:00
|
|
|
a(b|c?)+d abcd 0 4 2 3
|
|
|
|
a(b|((c)*))+d abcd 0 4 2 3 2 3 2 3
|
|
|
|
a(b+|((c)*))+d abd 0 3 1 2 -1 -1 -1 -1
|
|
|
|
a(b+|((c)*))+d abcd 0 4 2 3 2 3 2 3
|
2003-12-04 09:04:57 +01:00
|
|
|
a(b|((c)*))+d ad 0 2 1 1 1 1 -1 -1
|
2003-12-28 00:40:06 +01:00
|
|
|
a(b|((c)*))*d abcd 0 4 2 3 2 3 2 3
|
|
|
|
a(b+|((c)*))*d abd 0 3 1 2 -1 -1 -1 -1
|
|
|
|
a(b+|((c)*))*d abcd 0 4 2 3 2 3 2 3
|
2003-12-04 09:04:57 +01:00
|
|
|
a(b|((c)*))*d ad 0 2 1 1 1 1 -1 -1
|
|
|
|
|
|
|
|
- match_default normal REG_PERL
|
|
|
|
; try to match C++ syntax elements:
|
|
|
|
; line comment:
|
|
|
|
//[^\n]* "++i //here is a line comment\n" 4 28
|
|
|
|
; block comment:
|
|
|
|
/\*([^*]|\*+[^*/])*\*+/ "/* here is a block comment */" 0 29 26 27
|
|
|
|
/\*([^*]|\*+[^*/])*\*+/ "/**/" 0 4 -1 -1
|
|
|
|
/\*([^*]|\*+[^*/])*\*+/ "/***/" 0 5 -1 -1
|
|
|
|
/\*([^*]|\*+[^*/])*\*+/ "/****/" 0 6 -1 -1
|
|
|
|
/\*([^*]|\*+[^*/])*\*+/ "/*****/" 0 7 -1 -1
|
|
|
|
/\*([^*]|\*+[^*/])*\*+/ "/*****/*/" 0 7 -1 -1
|
|
|
|
; preprossor directives:
|
|
|
|
^[[:blank:]]*#([^\n]*\\[[:space:]]+)*[^\n]* "#define some_symbol" 0 19 -1 -1
|
|
|
|
^[[:blank:]]*#([^\n]*\\[[:space:]]+)*[^\n]* "#define some_symbol(x) #x" 0 25 -1 -1
|
|
|
|
; perl only:
|
|
|
|
^[[:blank:]]*#([^\n]*\\[[:space:]]+)*[^\n]* "#define some_symbol(x) \\ \r\n foo();\\\r\n printf(#x);" 0 53 30 42
|
|
|
|
; literals:
|
|
|
|
((0x[[:xdigit:]]+)|([[:digit:]]+))u?((int(8|16|32|64))|L)? 0xFF 0 4 0 4 0 4 -1 -1 -1 -1 -1 -1 -1 -1
|
|
|
|
((0x[[:xdigit:]]+)|([[:digit:]]+))u?((int(8|16|32|64))|L)? 35 0 2 0 2 -1 -1 0 2 -1 -1 -1 -1 -1 -1
|
|
|
|
((0x[[:xdigit:]]+)|([[:digit:]]+))u?((int(8|16|32|64))|L)? 0xFFu 0 5 0 4 0 4 -1 -1 -1 -1 -1 -1 -1 -1
|
|
|
|
((0x[[:xdigit:]]+)|([[:digit:]]+))u?((int(8|16|32|64))|L)? 0xFFL 0 5 0 4 0 4 -1 -1 4 5 -1 -1 -1 -1
|
|
|
|
((0x[[:xdigit:]]+)|([[:digit:]]+))u?((int(8|16|32|64))|L)? 0xFFFFFFFFFFFFFFFFuint64 0 24 0 18 0 18 -1 -1 19 24 19 24 22 24
|
|
|
|
; strings:
|
|
|
|
'([^\\']|\\.)*' '\\x3A' 0 6 4 5
|
|
|
|
'([^\\']|\\.)*' '\\'' 0 4 1 3
|
|
|
|
'([^\\']|\\.)*' '\\n' 0 4 1 3
|
|
|
|
|
|
|
|
; finally try some case insensitive matches:
|
|
|
|
- match_default normal REG_EXTENDED REG_ICASE
|
|
|
|
; upper and lower have no meaning here so they fail, however these
|
|
|
|
; may compile with other libraries...
|
|
|
|
;[[:lower:]] !
|
|
|
|
;[[:upper:]] !
|
|
|
|
0123456789@abcdefghijklmnopqrstuvwxyz\[\\\]\^_`ABCDEFGHIJKLMNOPQRSTUVWXYZ\{\|\} 0123456789@ABCDEFGHIJKLMNOPQRSTUVWXYZ[\\]\^_`abcdefghijklmnopqrstuvwxyz\{\|\} 0 72
|
|
|
|
|
|
|
|
; known and suspected bugs:
|
|
|
|
- match_default normal REG_EXTENDED
|
|
|
|
\( ( 0 1
|
|
|
|
\) ) 0 1
|
|
|
|
\$ $ 0 1
|
|
|
|
\^ ^ 0 1
|
|
|
|
\. . 0 1
|
|
|
|
\* * 0 1
|
|
|
|
\+ + 0 1
|
|
|
|
\? ? 0 1
|
|
|
|
\[ [ 0 1
|
|
|
|
\] ] 0 1
|
|
|
|
\| | 0 1
|
|
|
|
\\ \\ 0 1
|
|
|
|
# # 0 1
|
|
|
|
\# # 0 1
|
|
|
|
a- a- 0 2
|
|
|
|
\- - 0 1
|
|
|
|
\{ { 0 1
|
|
|
|
\} } 0 1
|
|
|
|
0 0 0 1
|
|
|
|
1 1 0 1
|
|
|
|
9 9 0 1
|
|
|
|
b b 0 1
|
|
|
|
B B 0 1
|
|
|
|
< < 0 1
|
|
|
|
> > 0 1
|
|
|
|
w w 0 1
|
|
|
|
W W 0 1
|
|
|
|
` ` 0 1
|
|
|
|
' ' 0 1
|
|
|
|
\n \n 0 1
|
|
|
|
, , 0 1
|
|
|
|
a a 0 1
|
|
|
|
f f 0 1
|
|
|
|
n n 0 1
|
|
|
|
r r 0 1
|
|
|
|
t t 0 1
|
|
|
|
v v 0 1
|
|
|
|
c c 0 1
|
|
|
|
x x 0 1
|
|
|
|
: : 0 1
|
|
|
|
(\.[[:alnum:]]+){2} "w.a.b " 1 5 3 5
|
|
|
|
|
|
|
|
- match_default normal REG_EXTENDED REG_ICASE
|
|
|
|
a A 0 1
|
|
|
|
A a 0 1
|
|
|
|
[abc]+ abcABC 0 6
|
|
|
|
[ABC]+ abcABC 0 6
|
|
|
|
[a-z]+ abcABC 0 6
|
|
|
|
[A-Z]+ abzANZ 0 6
|
|
|
|
[a-Z]+ abzABZ 0 6
|
|
|
|
[A-z]+ abzABZ 0 6
|
|
|
|
[[:lower:]]+ abyzABYZ 0 8
|
|
|
|
[[:upper:]]+ abzABZ 0 6
|
|
|
|
[[:alpha:]]+ abyzABYZ 0 8
|
|
|
|
[[:alnum:]]+ 09abyzABYZ 0 10
|
|
|
|
|
|
|
|
; word start:
|
|
|
|
\<abcd " abcd" 2 6
|
|
|
|
\<ab cab -1 -1
|
|
|
|
\<ab "\nab" 1 3
|
|
|
|
\<tag ::tag 2 5
|
|
|
|
;word end:
|
|
|
|
abc\> abc 0 3
|
|
|
|
abc\> abcd -1 -1
|
|
|
|
abc\> abc\n 0 3
|
|
|
|
abc\> abc:: 0 3
|
|
|
|
|
|
|
|
; collating elements and rewritten set code:
|
|
|
|
- match_default normal REG_EXTENDED REG_STARTEND
|
|
|
|
;[[.zero.]] 0 0 1
|
|
|
|
;[[.one.]] 1 0 1
|
|
|
|
;[[.two.]] 2 0 1
|
|
|
|
;[[.three.]] 3 0 1
|
|
|
|
[[.a.]] baa 1 2
|
|
|
|
;[[.right-curly-bracket.]] } 0 1
|
|
|
|
;[[.NUL.]] \0 0 1
|
|
|
|
[[:<:]z] !
|
|
|
|
[a[:>:]] !
|
|
|
|
[[=a=]] a 0 1
|
|
|
|
;[[=right-curly-bracket=]] } 0 1
|
|
|
|
- match_default normal REG_EXTENDED REG_STARTEND REG_ICASE
|
|
|
|
[[.A.]] A 0 1
|
|
|
|
[[.A.]] a 0 1
|
|
|
|
[[.A.]-b]+ AaBb 0 4
|
|
|
|
[A-[.b.]]+ AaBb 0 4
|
|
|
|
[[.a.]-B]+ AaBb 0 4
|
|
|
|
[a-[.B.]]+ AaBb 0 4
|
|
|
|
- match_default normal REG_EXTENDED REG_STARTEND
|
|
|
|
[[.a.]-c]+ abcd 0 3
|
|
|
|
[a-[.c.]]+ abcd 0 3
|
|
|
|
[[:alpha:]-a] !
|
|
|
|
[a-[:alpha:]] !
|
|
|
|
|
|
|
|
; try mutli-character ligatures:
|
|
|
|
;[[.ae.]] ae 0 2
|
|
|
|
;[[.ae.]] aE -1 -1
|
|
|
|
;[[.AE.]] AE 0 2
|
|
|
|
;[[.Ae.]] Ae 0 2
|
|
|
|
;[[.ae.]-b] a -1 -1
|
|
|
|
;[[.ae.]-b] b 0 1
|
|
|
|
;[[.ae.]-b] ae 0 2
|
|
|
|
;[a-[.ae.]] a 0 1
|
|
|
|
;[a-[.ae.]] b -1 -1
|
|
|
|
;[a-[.ae.]] ae 0 2
|
|
|
|
- match_default normal REG_EXTENDED REG_STARTEND REG_ICASE
|
|
|
|
;[[.ae.]] AE 0 2
|
|
|
|
;[[.ae.]] Ae 0 2
|
|
|
|
;[[.AE.]] Ae 0 2
|
|
|
|
;[[.Ae.]] aE 0 2
|
|
|
|
;[[.AE.]-B] a -1 -1
|
|
|
|
;[[.Ae.]-b] b 0 1
|
|
|
|
;[[.Ae.]-b] B 0 1
|
|
|
|
;[[.ae.]-b] AE 0 2
|
|
|
|
|
|
|
|
- match_default normal REG_EXTENDED REG_STARTEND REG_NO_POSIX_TEST
|
|
|
|
\s+ "ab ab" 2 5
|
|
|
|
\S+ " abc " 2 5
|
|
|
|
|
|
|
|
- match_default normal REG_EXTENDED REG_STARTEND
|
|
|
|
\`abc abc 0 3
|
|
|
|
\`abc aabc -1 -1
|
|
|
|
abc\' abc 0 3
|
|
|
|
abc\' abcd -1 -1
|
|
|
|
abc\' abc\n\n -1 -1
|
|
|
|
abc\' abc 0 3
|
|
|
|
|
|
|
|
; extended repeat checking to exercise new algorithms:
|
|
|
|
ab.*xy abxy_ 0 4
|
|
|
|
ab.*xy ab_xy_ 0 5
|
|
|
|
ab.*xy abxy 0 4
|
|
|
|
ab.*xy ab_xy 0 5
|
|
|
|
ab.* ab 0 2
|
|
|
|
ab.* ab__ 0 4
|
|
|
|
|
|
|
|
ab.{2,5}xy ab__xy_ 0 6
|
|
|
|
ab.{2,5}xy ab____xy_ 0 8
|
|
|
|
ab.{2,5}xy ab_____xy_ 0 9
|
|
|
|
ab.{2,5}xy ab__xy 0 6
|
|
|
|
ab.{2,5}xy ab_____xy 0 9
|
|
|
|
ab.{2,5} ab__ 0 4
|
|
|
|
ab.{2,5} ab_______ 0 7
|
|
|
|
ab.{2,5}xy ab______xy -1 -1
|
|
|
|
ab.{2,5}xy ab_xy -1 -1
|
|
|
|
|
|
|
|
ab.*?xy abxy_ 0 4
|
|
|
|
ab.*?xy ab_xy_ 0 5
|
|
|
|
ab.*?xy abxy 0 4
|
|
|
|
ab.*?xy ab_xy 0 5
|
|
|
|
ab.*? ab 0 2
|
|
|
|
ab.*? ab__ 0 4
|
|
|
|
|
|
|
|
ab.{2,5}?xy ab__xy_ 0 6
|
|
|
|
ab.{2,5}?xy ab____xy_ 0 8
|
|
|
|
ab.{2,5}?xy ab_____xy_ 0 9
|
|
|
|
ab.{2,5}?xy ab__xy 0 6
|
|
|
|
ab.{2,5}?xy ab_____xy 0 9
|
|
|
|
ab.{2,5}? ab__ 0 4
|
|
|
|
ab.{2,5}? ab_______ 0 7
|
|
|
|
ab.{2,5}?xy ab______xy -1 -1
|
|
|
|
ab.{2,5}xy ab_xy -1 -1
|
|
|
|
|
|
|
|
; again but with slower algorithm variant:
|
|
|
|
- match_default REG_EXTENDED
|
|
|
|
; now again for single character repeats:
|
|
|
|
|
|
|
|
ab_*xy abxy_ 0 4
|
|
|
|
ab_*xy ab_xy_ 0 5
|
|
|
|
ab_*xy abxy 0 4
|
|
|
|
ab_*xy ab_xy 0 5
|
|
|
|
ab_* ab 0 2
|
|
|
|
ab_* ab__ 0 4
|
|
|
|
|
|
|
|
ab_{2,5}xy ab__xy_ 0 6
|
|
|
|
ab_{2,5}xy ab____xy_ 0 8
|
|
|
|
ab_{2,5}xy ab_____xy_ 0 9
|
|
|
|
ab_{2,5}xy ab__xy 0 6
|
|
|
|
ab_{2,5}xy ab_____xy 0 9
|
|
|
|
ab_{2,5} ab__ 0 4
|
|
|
|
ab_{2,5} ab_______ 0 7
|
|
|
|
ab_{2,5}xy ab______xy -1 -1
|
|
|
|
ab_{2,5}xy ab_xy -1 -1
|
|
|
|
|
|
|
|
ab_*?xy abxy_ 0 4
|
|
|
|
ab_*?xy ab_xy_ 0 5
|
|
|
|
ab_*?xy abxy 0 4
|
|
|
|
ab_*?xy ab_xy 0 5
|
|
|
|
ab_*? ab 0 2
|
|
|
|
ab_*? ab__ 0 4
|
|
|
|
|
|
|
|
ab_{2,5}?xy ab__xy_ 0 6
|
|
|
|
ab_{2,5}?xy ab____xy_ 0 8
|
|
|
|
ab_{2,5}?xy ab_____xy_ 0 9
|
|
|
|
ab_{2,5}?xy ab__xy 0 6
|
|
|
|
ab_{2,5}?xy ab_____xy 0 9
|
|
|
|
ab_{2,5}? ab__ 0 4
|
|
|
|
ab_{2,5}? ab_______ 0 7
|
|
|
|
ab_{2,5}?xy ab______xy -1 -1
|
|
|
|
ab_{2,5}xy ab_xy -1 -1
|
|
|
|
|
|
|
|
; and again for sets:
|
|
|
|
ab[_,;]*xy abxy_ 0 4
|
|
|
|
ab[_,;]*xy ab_xy_ 0 5
|
|
|
|
ab[_,;]*xy abxy 0 4
|
|
|
|
ab[_,;]*xy ab_xy 0 5
|
|
|
|
ab[_,;]* ab 0 2
|
|
|
|
ab[_,;]* ab__ 0 4
|
|
|
|
|
|
|
|
ab[_,;]{2,5}xy ab__xy_ 0 6
|
|
|
|
ab[_,;]{2,5}xy ab____xy_ 0 8
|
|
|
|
ab[_,;]{2,5}xy ab_____xy_ 0 9
|
|
|
|
ab[_,;]{2,5}xy ab__xy 0 6
|
|
|
|
ab[_,;]{2,5}xy ab_____xy 0 9
|
|
|
|
ab[_,;]{2,5} ab__ 0 4
|
|
|
|
ab[_,;]{2,5} ab_______ 0 7
|
|
|
|
ab[_,;]{2,5}xy ab______xy -1 -1
|
|
|
|
ab[_,;]{2,5}xy ab_xy -1 -1
|
|
|
|
|
|
|
|
ab[_,;]*?xy abxy_ 0 4
|
|
|
|
ab[_,;]*?xy ab_xy_ 0 5
|
|
|
|
ab[_,;]*?xy abxy 0 4
|
|
|
|
ab[_,;]*?xy ab_xy 0 5
|
|
|
|
ab[_,;]*? ab 0 2
|
|
|
|
ab[_,;]*? ab__ 0 4
|
|
|
|
|
|
|
|
ab[_,;]{2,5}?xy ab__xy_ 0 6
|
|
|
|
ab[_,;]{2,5}?xy ab____xy_ 0 8
|
|
|
|
ab[_,;]{2,5}?xy ab_____xy_ 0 9
|
|
|
|
ab[_,;]{2,5}?xy ab__xy 0 6
|
|
|
|
ab[_,;]{2,5}?xy ab_____xy 0 9
|
|
|
|
ab[_,;]{2,5}? ab__ 0 4
|
|
|
|
ab[_,;]{2,5}? ab_______ 0 7
|
|
|
|
ab[_,;]{2,5}?xy ab______xy -1 -1
|
|
|
|
ab[_,;]{2,5}xy ab_xy -1 -1
|
|
|
|
|
|
|
|
; and again for tricky sets with digraphs:
|
|
|
|
;ab[_[.ae.]]*xy abxy_ 0 4
|
|
|
|
;ab[_[.ae.]]*xy ab_xy_ 0 5
|
|
|
|
;ab[_[.ae.]]*xy abxy 0 4
|
|
|
|
;ab[_[.ae.]]*xy ab_xy 0 5
|
|
|
|
;ab[_[.ae.]]* ab 0 2
|
|
|
|
;ab[_[.ae.]]* ab__ 0 4
|
|
|
|
|
|
|
|
;ab[_[.ae.]]{2,5}xy ab__xy_ 0 6
|
|
|
|
;ab[_[.ae.]]{2,5}xy ab____xy_ 0 8
|
|
|
|
;ab[_[.ae.]]{2,5}xy ab_____xy_ 0 9
|
|
|
|
;ab[_[.ae.]]{2,5}xy ab__xy 0 6
|
|
|
|
;ab[_[.ae.]]{2,5}xy ab_____xy 0 9
|
|
|
|
;ab[_[.ae.]]{2,5} ab__ 0 4
|
|
|
|
;ab[_[.ae.]]{2,5} ab_______ 0 7
|
|
|
|
;ab[_[.ae.]]{2,5}xy ab______xy -1 -1
|
|
|
|
;ab[_[.ae.]]{2,5}xy ab_xy -1 -1
|
|
|
|
|
|
|
|
;ab[_[.ae.]]*?xy abxy_ 0 4
|
|
|
|
;ab[_[.ae.]]*?xy ab_xy_ 0 5
|
|
|
|
;ab[_[.ae.]]*?xy abxy 0 4
|
|
|
|
;ab[_[.ae.]]*?xy ab_xy 0 5
|
|
|
|
;ab[_[.ae.]]*? ab 0 2
|
|
|
|
;ab[_[.ae.]]*? ab__ 0 2
|
|
|
|
|
|
|
|
;ab[_[.ae.]]{2,5}?xy ab__xy_ 0 6
|
|
|
|
;ab[_[.ae.]]{2,5}?xy ab____xy_ 0 8
|
|
|
|
;ab[_[.ae.]]{2,5}?xy ab_____xy_ 0 9
|
|
|
|
;ab[_[.ae.]]{2,5}?xy ab__xy 0 6
|
|
|
|
;ab[_[.ae.]]{2,5}?xy ab_____xy 0 9
|
|
|
|
;ab[_[.ae.]]{2,5}? ab__ 0 4
|
|
|
|
;ab[_[.ae.]]{2,5}? ab_______ 0 4
|
|
|
|
;ab[_[.ae.]]{2,5}?xy ab______xy -1 -1
|
|
|
|
;ab[_[.ae.]]{2,5}xy ab_xy -1 -1
|
|
|
|
|
|
|
|
; new bugs detected in spring 2003:
|
|
|
|
- normal match_continuous REG_NO_POSIX_TEST
|
|
|
|
b abc 1 2
|
|
|
|
|
|
|
|
() abc 0 0 0 0
|
|
|
|
^() abc 0 0 0 0
|
|
|
|
^()+ abc 0 0 0 0
|
|
|
|
^(){1} abc 0 0 0 0
|
|
|
|
^(){2} abc 0 0 0 0
|
|
|
|
^((){2}) abc 0 0 0 0 0 0
|
|
|
|
() "" 0 0 0 0
|
|
|
|
()\1 "" 0 0 0 0
|
|
|
|
()\1 a 0 0 0 0
|
|
|
|
a()\1b ab 0 2 1 1
|
|
|
|
a()b\1 ab 0 2 1 1
|
|
|
|
|
|
|
|
; subtleties of matching with no sub-expressions marked
|
|
|
|
- normal match_nosubs REG_NO_POSIX_TEST
|
|
|
|
a(b?c)+d accd 0 4
|
|
|
|
(wee|week)(knights|night) weeknights 0 10
|
|
|
|
.* abc 0 3
|
|
|
|
a(b|(c))d abd 0 3
|
|
|
|
a(b|(c))d acd 0 3
|
|
|
|
a(b*|c|e)d abbd 0 4
|
|
|
|
a(b*|c|e)d acd 0 3
|
|
|
|
a(b*|c|e)d ad 0 2
|
|
|
|
a(b?)c abc 0 3
|
|
|
|
a(b?)c ac 0 2
|
|
|
|
a(b+)c abc 0 3
|
|
|
|
a(b+)c abbbc 0 5
|
|
|
|
a(b*)c ac 0 2
|
|
|
|
(a|ab)(bc([de]+)f|cde) abcdef 0 6
|
|
|
|
a([bc]?)c abc 0 3
|
|
|
|
a([bc]?)c ac 0 2
|
|
|
|
a([bc]+)c abc 0 3
|
|
|
|
a([bc]+)c abcc 0 4
|
|
|
|
a([bc]+)bc abcbc 0 5
|
|
|
|
a(bb+|b)b abb 0 3
|
|
|
|
a(bbb+|bb+|b)b abb 0 3
|
|
|
|
a(bbb+|bb+|b)b abbb 0 4
|
|
|
|
a(bbb+|bb+|b)bb abbb 0 4
|
|
|
|
(.*).* abcdef 0 6
|
|
|
|
(a*)* bc 0 0
|
|
|
|
|
|
|
|
- normal nosubs REG_NO_POSIX_TEST
|
|
|
|
a(b?c)+d accd 0 4
|
|
|
|
(wee|week)(knights|night) weeknights 0 10
|
|
|
|
.* abc 0 3
|
|
|
|
a(b|(c))d abd 0 3
|
|
|
|
a(b|(c))d acd 0 3
|
|
|
|
a(b*|c|e)d abbd 0 4
|
|
|
|
a(b*|c|e)d acd 0 3
|
|
|
|
a(b*|c|e)d ad 0 2
|
|
|
|
a(b?)c abc 0 3
|
|
|
|
a(b?)c ac 0 2
|
|
|
|
a(b+)c abc 0 3
|
|
|
|
a(b+)c abbbc 0 5
|
|
|
|
a(b*)c ac 0 2
|
|
|
|
(a|ab)(bc([de]+)f|cde) abcdef 0 6
|
|
|
|
a([bc]?)c abc 0 3
|
|
|
|
a([bc]?)c ac 0 2
|
|
|
|
a([bc]+)c abc 0 3
|
|
|
|
a([bc]+)c abcc 0 4
|
|
|
|
a([bc]+)bc abcbc 0 5
|
|
|
|
a(bb+|b)b abb 0 3
|
|
|
|
a(bbb+|bb+|b)b abb 0 3
|
|
|
|
a(bbb+|bb+|b)b abbb 0 4
|
|
|
|
a(bbb+|bb+|b)bb abbb 0 4
|
|
|
|
(.*).* abcdef 0 6
|
|
|
|
(a*)* bc 0 0
|
|
|
|
|