forked from firfircelik/agstring
-
Notifications
You must be signed in to change notification settings - Fork 0
/
Copy pathcontains.go
70 lines (61 loc) · 1.69 KB
/
contains.go
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
package agstring
import (
"strings"
"github.com/thoas/go-funk"
)
// ContainsSubString checks if the searched string is a sub string of
// the any string in the source slice
func ContainsSubString(src []string, searched string) bool {
return IndexContainingSubString(src, searched) != -1
}
// ContainsAny checks if source slice contains any of given strings
func ContainsAny(src []string, qs ...string) bool {
for _, q := range qs {
if funk.ContainsString(src, q) {
return true
}
}
return false
}
// StringContainsAny is similar to ContainsAny but source is a string
func StringContainsAny(s string, ls ...string) bool {
return StringIndexContainingSubString(s, ls...) != -1
}
// ContainsAll checks if given slice contains all searched strings
func ContainsAll(holder []string, searched ...string) bool {
for _, s := range searched {
if !funk.ContainsString(holder, s) {
return false
}
}
return true
}
// StringContainsAll checks if given string contains all searched strings
func StringContainsAll(holder string, searched ...string) bool {
for _, s := range searched {
if !strings.Contains(holder, s) {
return false
}
}
return true
}
// IndexContainingSubString returns the first index in given slice
// which contains the searched string
func IndexContainingSubString(holder []string, searched string) int {
for i := range holder {
if strings.Contains(holder[i], searched) {
return i
}
}
return -1
}
// StringIndexContainingSubString returns the first index in given slice
// which is a sub string of the source string
func StringIndexContainingSubString(s string, ls ...string) int {
for i := range ls {
if strings.Contains(s, ls[i]) {
return i
}
}
return -1
}