forked from mirror/glob
67 lines
938 B
Go
67 lines
938 B
Go
|
package match
|
||
|
|
||
|
import (
|
||
|
"fmt"
|
||
|
)
|
||
|
|
||
|
type Row struct {
|
||
|
Matchers Matchers
|
||
|
len int
|
||
|
}
|
||
|
|
||
|
func (self *Row) Add(m Matcher) error {
|
||
|
if l := m.Len(); l == -1 {
|
||
|
return fmt.Errorf("matcher should have fixed length")
|
||
|
}
|
||
|
|
||
|
self.Matchers = append(self.Matchers, m)
|
||
|
return nil
|
||
|
}
|
||
|
|
||
|
func (self Row) Match(s string) bool {
|
||
|
if len(s) < self.Len() {
|
||
|
return false
|
||
|
}
|
||
|
|
||
|
var idx int
|
||
|
for _, m := range self.Matchers {
|
||
|
l := m.Len()
|
||
|
if !m.Match(s[idx : idx+l]) {
|
||
|
return false
|
||
|
}
|
||
|
|
||
|
idx += l
|
||
|
}
|
||
|
|
||
|
return true
|
||
|
}
|
||
|
|
||
|
func (self Row) Len() (l int) {
|
||
|
if self.len == 0 {
|
||
|
for _, m := range self.Matchers {
|
||
|
self.len += m.Len()
|
||
|
}
|
||
|
}
|
||
|
|
||
|
return self.len
|
||
|
}
|
||
|
|
||
|
func (self Row) Index(s string) (int, []int) {
|
||
|
for i := range s {
|
||
|
sub := s[i:]
|
||
|
if self.Match(sub) {
|
||
|
return i, []int{self.Len()}
|
||
|
}
|
||
|
}
|
||
|
|
||
|
return -1, nil
|
||
|
}
|
||
|
|
||
|
func (self Row) Kind() Kind {
|
||
|
return KindMin
|
||
|
}
|
||
|
|
||
|
func (self Row) String() string {
|
||
|
return fmt.Sprintf("[row:%s]", self.Matchers)
|
||
|
}
|