fix #18128 rfind on empty needle returns rightmost index (#20430)

rfind on empty needle returns haystack len
This commit is contained in:
n5m
2022-09-26 19:39:22 +00:00
committed by GitHub
parent b213913dcb
commit 9ca88a1889
2 changed files with 18 additions and 13 deletions

View File

@@ -360,19 +360,23 @@ template main() =
doAssert "///".rfind("//", start=3) == -1
# searching for empty string
doAssert "".rfind("") == -1
doAssert "abc".rfind("") == -1
doAssert "abc".rfind("", start=1) == -1
doAssert "abc".rfind("", start=2) == -1
doAssert "abc".rfind("", start=3) == -1
doAssert "abc".rfind("", start=4) == -1
doAssert "abc".rfind("", start=400) == -1
doAssert "".rfind("") == 0
doAssert "abc".rfind("") == 3
doAssert "abc".rfind("", start=1) == 3
doAssert "abc".rfind("", start=2) == 3
doAssert "abc".rfind("", start=3) == 3
doAssert "abc".rfind("", start=4) == 4
doAssert "abc".rfind("", start=400) == 400
doAssert "abc".rfind("", start=1, last=3) == -1
doAssert "abc".rfind("", start=1, last=2) == -1
doAssert "abc".rfind("", start=1, last=1) == -1
doAssert "abc".rfind("", start=1, last=0) == -1
doAssert "abc".rfind("", start=1, last = -1) == -1
doAssert "abc".rfind("", start=1, last=3) == 3
doAssert "abc".rfind("", start=1, last=2) == 2
doAssert "abc".rfind("", start=1, last=1) == 1
# This returns the start index instead of the last index
# because start > last
doAssert "abc".rfind("", start=1, last=0) == 1
doAssert "abc".rfind("", start=1, last = -1) == 3
doAssert "abc".rfind("", start=0, last=0) == 0
# when last <= start, searching for non-empty string
block: