41 lines
739 B
Go
41 lines
739 B
Go
package query
|
|
|
|
import (
|
|
"strings"
|
|
)
|
|
|
|
type ISearchable interface {
|
|
Test( string ) bool
|
|
GetKey() *string
|
|
}
|
|
|
|
type Searchable struct {
|
|
Key *string
|
|
SearchData *[] *string
|
|
}
|
|
|
|
func ( this *Searchable ) Test( val string ) bool {
|
|
|
|
data := this.SearchData
|
|
if data == nil {
|
|
return false
|
|
}
|
|
|
|
for _, v := range *data {
|
|
if strings.Contains( *v, val ) {
|
|
return true
|
|
}
|
|
}
|
|
return false
|
|
}
|
|
|
|
func ( this *Searchable ) GetKey() *string {
|
|
return this.Key
|
|
}
|
|
|
|
type ByKey [] ISearchable
|
|
|
|
func (a ByKey) Len() int { return len(a) }
|
|
func (a ByKey) Swap(i, j int) { a[i], a[j] = a[j], a[i] }
|
|
func (a ByKey) Less(i, j int) bool { return *a[i].GetKey() < *a[j].GetKey() }
|