diff options
author | Lorry Tar Creator <lorry-tar-importer@lorry> | 2016-04-22 04:38:07 +0000 |
---|---|---|
committer | Lorry Tar Creator <lorry-tar-importer@lorry> | 2016-04-22 04:38:07 +0000 |
commit | 28ef1abc10cfbc2c3d2747c008eb2300858d0426 (patch) | |
tree | 41208fb8f393e6cb6cc8f939623ad47a0db17876 /tests/repetition-overflow | |
download | grep-tarball-master.tar.gz |
Diffstat (limited to 'tests/repetition-overflow')
-rwxr-xr-x | tests/repetition-overflow | 19 |
1 files changed, 19 insertions, 0 deletions
diff --git a/tests/repetition-overflow b/tests/repetition-overflow new file mode 100755 index 0000000..35d928b --- /dev/null +++ b/tests/repetition-overflow @@ -0,0 +1,19 @@ +#!/bin/sh +# These would fail (i.e., match erroneously) prior to grep-2.11. +. "${srcdir=.}/init.sh"; path_prepend_ ../src + +xp1=4294967297 # 2^32+1 +xp2=4294967298 # 2^32+2 + +fail=0 + +# Before grep-2.11, when DFA-matching, a repetition count exceeding the +# range of "unsigned int" would silently wrap around. Hence, 2^32+1 +# would be treated just like "1", and both of these would mistakenly match. + +echo abc | grep -E "b{$xp1}" > out 2> /dev/null; test $? = 2 || fail=1 +compare /dev/null out || fail=1 +echo abbc | grep -E "b{1,$xp2}" > out 2> /dev/null; test $? = 2 || fail=1 +compare /dev/null out || fail=1 + +Exit $fail |