# This file tests the auxiliary pattern conversion features of the PCRE2
# library, in non-UTF mode.
#forbid_utf
#newline_default lf any anycrlf
# -------- Tests of glob conversion --------
# Set the glob separator explicitly so that different OS defaults are not a
# problem. Then test various errors.
#pattern convert=glob_basic,convert_glob_separator=/
/abc/posix
** The convert and posix modifiers are mutually exclusive
# Separator must be / \ or .
/a*b/convert_glob_separator=%
** Invalid glob separator '%'
# Can't have separator in a class
"[ab/cd]"
(?s)\A(?!/)[ab/cd]\z
"[,-/]"
(?s)\A(?!/)[,-/]\z
/[ab/
** Pattern conversion error at offset 3: missing terminating ] for character class
# Length check
/abc/convert_length=11
** Pattern conversion error at offset 3: no more memory
/abc/convert_length=12
(?s)\Aabc\z
# Now some actual tests
/a?b[]xy]*c/
(?s)\Aa[^/]b(?!/)[\]xy](*COMMIT)[^/]*?c\z
azb]1234c
0: azb]1234c
# Tests from the gitwildmatch list, with some additions
/foo/
(?s)\Afoo\z
foo
0: foo
/= Expect no match
No match
bar
No match
//
(?s)\A\z
\
0:
/???/
(?s)\A[^/][^/][^/]\z
foo
0: foo
\= Expect no match
foobar
No match
/*/
(?s)\A[^/]*?\z
foo
0: foo
\
0:
/f*/
(?s)\Af(*COMMIT)[^/]*?\z
foo
0: foo
f
0: f
/*f/
(?s)\A[^/]*?f\z
oof
0: oof
\= Expect no match
foo
No match
/*foo*/
(?s)\A[^/]*?foo(*COMMIT)[^/]*?\z
foo
0: foo
food
0: food
aprilfool
0: aprilfool
/*ob*a*r*/
(?s)\A[^/]*?ob(*COMMIT)[^/]*?a(*COMMIT)[^/]*?r(*COMMIT)[^/]*?\z
foobar
0: foobar
/*ab/
(?s)\A[^/]*?ab\z
aaaaaaabababab
0: aaaaaaabababab
/foo\*/
(?s)\Afoo\*\z
foo*
0: foo*
/foo\*bar/
(?s)\Afoo\*bar\z
\= Expect no match
foobar
No match
/f\\oo/
(?s)\Af\\oo\z
f\\oo
0: f\oo
/*[al]?/
(?s)\A[^/]*?(?!/)[al][^/]\z
ball
0: ball
/[ten]/
(?s)\A(?!/)[ten]\z
\= Expect no match
ten
No match
/t[a-g]n/
(?s)\At(?!/)[a-g]n\z
ten
0: ten
/a[]]b/
(?s)\Aa(?!/)[\]]b\z
a]b
0: a]b
/a[]a-]b/
** Pattern conversion error at offset 7: missing terminating ] for character class
/a[]-]b/
** Pattern conversion error at offset 6: missing terminating ] for character class
a-b
a]b
\= Expect no match
aab
/a[]a-z]b/
(?s)\Aa(?!/)[\]a-z]b\z
aab
0: aab
/]/
(?s)\A\]\z
]
0: ]
/t[!a-g]n/
(?s)\At[^/a-g]n\z
ton
0: ton
\= Expect no match
ten
No match
'[[:alpha:]][[:digit:]][[:upper:]]'
(?s)\A(?!/)[[:alpha:]](?!/)[[:digit:]](?!/)[[:upper:]]\z
a1B
0: a1B
'[[:digit:][:upper:][:space:]]'
(?s)\A(?!/)[[:digit:][:upper:][:space:]]\z
A
0: A
1
0: 1
\ \=
0:
\= Expect no match
a
No match
.
No match
'[a-c[:digit:]x-z]'
(?s)\A(?!/)[a-c[:digit:]x-z]\z
5
0: 5
b
0: b
y
0: y
\= Expect no match
q
No match
# End of gitwildmatch tests
/*.j?g/
(?s)\A[^/]*?\.j[^/]g\z
pic01.jpg
0: pic01.jpg
.jpg
0: .jpg
pic02.jxg
0: pic02.jxg
\= Expect no match
pic03.j/g
No match
/A[+-0]B/
(?s)\AA(?!/)[+-0]B\z
A+B
0: A+B
A.B
0: A.B
A0B
0: A0B
\= Expect no match
A/B
No match
/*x?z/
(?s)\A[^/]*?x[^/]z\z
abc.xyz
0: abc.xyz
\= Expect no match
.xyz
0: .xyz
/?x?z/
(?s)\A[^/]x[^/]z\z
axyz
0: axyz
\= Expect no match
.xyz
0: .xyz
"[,-0]x?z"
(?s)\A(?!/)[,-0]x[^/]z\z
,xyz
0: ,xyz
\= Expect no match
/xyz
No match
.xyz
0: .xyz
".x*"
(?s)\A\.x(*COMMIT)[^/]*?\z
.xabc
0: .xabc
/a[--0]z/
(?s)\Aa(?!/)[\--0]z\z
a-z
0: a-z
a.z
0: a.z
a0z
0: a0z
\= Expect no match
a/z
No match
a1z
No match
/<[a-c-d]>/
(?s)\A<(?!/)[a-c-d]>\z
0:
0:
0:
0:
<->
0: <->
/a[[:digit:].]z/
(?s)\Aa(?!/)[[:digit:].]z\z
a1z
0: a1z
a.z
0: a.z
\= Expect no match
a:z
No match
/a[[:digit].]z/
** Pattern conversion error at offset 10: missing terminating ] for character class
a[.]z
a:.]z
ad.]z
/<[[:a[:digit:]b]>/
** Pattern conversion error at offset 6: missing terminating ] for character class
<[>
<:>
<9>
\= Expect no match
/a*b/convert_glob_separator=\
(?s)\Aa(*COMMIT)[^\\]*?b\z
/a*b/convert_glob_separator=.
(?s)\Aa(*COMMIT)[^\.]*?b\z
/a*b/convert_glob_separator=/
(?s)\Aa(*COMMIT)[^/]*?b\z
# Non control character checking
/A\B\\C\D/
(?s)\AAB\\CD\z
/\\{}\?\*+\[\]()|.^$/
(?s)\A\\\{\}\?\*\+\[\]\(\)\|\.\^\$\z
/*a*\/*b*/
(?s)\A[^/]*?a(*COMMIT)[^/]*?/(*COMMIT)[^/]*?b(*COMMIT)[^/]*?\z
/?a?\/?b?/
(?s)\A[^/]a[^/]/[^/]b[^/]\z
/[a\\b\c][]][-][\]\-]/
(?s)\A(?!/)[a\\bc](?!/)[\]](?!/)[\-](?!/)[\]\-]\z
/[^a\\b\c][!]][!-][^\]\-]/
(?s)\A[^/a\\bc][^/\]][^/\-][^/\]\-]\z
/[[:alpha:][:xdigit:][:word:]]/
(?s)\A(?!/)[[:alpha:][:xdigit:][:word:]]\z
/[[:alpha:/
** Pattern conversion error at offset 9: missing terminating ] for character class
/[[:alpha:]/
** Pattern conversion error at offset 10: missing terminating ] for character class
/[[:alphaa:]]/
** Pattern conversion error at offset 11: unknown POSIX class name
/[[:xdigi:]]/
** Pattern conversion error at offset 10: unknown POSIX class name
/[[:xdigit::]]/
** Pattern conversion error at offset 10: missing terminating ] for character class
/****/
(?s)
/**\/abc/
(?s)(?:\A|[^/])abc\z
/abc\/**/
(?s)\Aabc/
/abc\/**\/abc/
(?s)\Aabc/(*COMMIT)(?:.*?/)??abc\z
#pattern convert=unset:posix_extended
/a[[:>:]z/
a[[:>:]z
Failed: error 130 at offset 4: unknown POSIX class name
/<[[:a[:digit:]b]>/
<[[:a[:digit:]b]>
<[>
0: <[>
<:>
0: <:>
0:
<9>
0: <9>
0:
\= Expect no match
No match
/a+\1b\\c|d[ab\c]/
a+1b\\c|d[ab\\c]
/a[[:<:]]b[[:>:]]/
a[[:<:]]b[[:>:]]
/<[]bc]>/
<[]bc]>
<]>
0: <]>
0:
0:
/<[^]bc]>/
<[^]bc]>
<.>
0: <.>
\= Expect no match
<]>
No match
No match
/(a)\1b/
(a)1b
a1b
0: a1b
1: a
\= Expect no match
aab
No match
/(ab)c)d]/
(ab)c\)d\]
Xabc)d]Y
0: abc)d]
1: ab
/a***b/
a*b
#pattern convert=unset:posix_basic
/a*b+c\+[def](ab)\(cd\)/
a*b\+c+[def]\(ab\)(cd)
/\(a\)\1b/
(a)\1b
aab
0: aab
1: a
\= Expect no match
a1b
No match
/how.to how\.to/
how.to how\.to
/^how to \^how to/
^how to \^how to
/^*abc/
^\*abc
/*abc/
\*abc
X*abcY
0: *abc
/**abc/
\**abc
XabcY
0: abc
X*abcY
0: *abc
X**abcY
0: **abc
/^b\(c^d\)\(^e^f\)/
^b(c\^d)(^e\^f)
/a***b/
a*b
#pattern convert=unset
/abc/
# End of testinput24