1
0
mirror of https://github.com/golang/go synced 2024-11-23 00:40:08 -07:00

bytes, strings: add ContainsFunc

Fixes #54386.

Change-Id: I78747da337ed6129e4f7426dd0483a644bed82e3
Reviewed-on: https://go-review.googlesource.com/c/go/+/460216
TryBot-Result: Gopher Robot <gobot@golang.org>
Reviewed-by: Matthew Dempsky <mdempsky@google.com>
Reviewed-by: Ian Lance Taylor <iant@google.com>
Run-TryBot: hopehook <hopehook@golangcn.org>
Auto-Submit: Ian Lance Taylor <iant@golang.org>
This commit is contained in:
hopehook 2023-01-03 16:23:16 +08:00 committed by Gopher Robot
parent 43f9b826c3
commit 0b3f58c48e
5 changed files with 34 additions and 0 deletions

2
api/next/54386.txt Normal file
View File

@ -0,0 +1,2 @@
pkg bytes, func ContainsFunc([]uint8, func(int32) bool) bool #54386
pkg strings, func ContainsFunc(string, func(int32) bool) bool #54386

View File

@ -86,6 +86,11 @@ func ContainsRune(b []byte, r rune) bool {
return IndexRune(b, r) >= 0 return IndexRune(b, r) >= 0
} }
// ContainsFunc reports whether any of the UTF-8-encoded code points r within b satisfy f(r).
func ContainsFunc(b []byte, f func(rune) bool) bool {
return IndexFunc(b, f) >= 0
}
// IndexByte returns the index of the first instance of c in b, or -1 if c is not present in b. // IndexByte returns the index of the first instance of c in b, or -1 if c is not present in b.
func IndexByte(b []byte, c byte) int { func IndexByte(b []byte, c byte) int {
return bytealg.IndexByte(b, c) return bytealg.IndexByte(b, c)

View File

@ -1847,6 +1847,17 @@ func TestContainsRune(t *testing.T) {
} }
} }
func TestContainsFunc(t *testing.T) {
for _, ct := range ContainsRuneTests {
if ContainsFunc(ct.b, func(r rune) bool {
return ct.r == r
}) != ct.expected {
t.Errorf("ContainsFunc(%q, func(%q)) = %v, want %v",
ct.b, ct.r, !ct.expected, ct.expected)
}
}
}
var makeFieldsInput = func() []byte { var makeFieldsInput = func() []byte {
x := make([]byte, 1<<20) x := make([]byte, 1<<20)
// Input is ~10% space, ~10% 2-byte UTF-8, rest ASCII non-space. // Input is ~10% space, ~10% 2-byte UTF-8, rest ASCII non-space.

View File

@ -69,6 +69,11 @@ func ContainsRune(s string, r rune) bool {
return IndexRune(s, r) >= 0 return IndexRune(s, r) >= 0
} }
// ContainsFunc reports whether any Unicode code points r within s satisfy f(r).
func ContainsFunc(s string, f func(rune) bool) bool {
return IndexFunc(s, f) >= 0
}
// LastIndex returns the index of the last instance of substr in s, or -1 if substr is not present in s. // LastIndex returns the index of the last instance of substr in s, or -1 if substr is not present in s.
func LastIndex(s, substr string) int { func LastIndex(s, substr string) int {
n := len(substr) n := len(substr)

View File

@ -1535,6 +1535,17 @@ func TestContainsRune(t *testing.T) {
} }
} }
func TestContainsFunc(t *testing.T) {
for _, ct := range ContainsRuneTests {
if ContainsFunc(ct.str, func(r rune) bool {
return ct.r == r
}) != ct.expected {
t.Errorf("ContainsFunc(%q, func(%q)) = %v, want %v",
ct.str, ct.r, !ct.expected, ct.expected)
}
}
}
var EqualFoldTests = []struct { var EqualFoldTests = []struct {
s, t string s, t string
out bool out bool