package match import ( "fmt" "strings" ) type PrefixSuffix struct { Prefix, Suffix string } func (self PrefixSuffix) Index(s string) (int, []int) { prefixIdx := strings.Index(s, self.Prefix) if prefixIdx == -1 { return -1, nil } var resp []int suffixLen := len(self.Suffix) if suffixLen > 0 { var segments []int for sub := s[prefixIdx:]; ; { suffixIdx := strings.LastIndex(sub, self.Suffix) if suffixIdx == -1 { break } segments = append(segments, suffixIdx+suffixLen) sub = sub[:suffixIdx] } segLen := len(segments) if segLen == 0 { return -1, nil } resp = make([]int, segLen) for i, s := range segments { resp[segLen-i-1] = s } } else { resp = append(resp, len(s)-prefixIdx) } return prefixIdx, resp } func (self PrefixSuffix) Len() int { return lenNo } func (self PrefixSuffix) Match(s string) bool { return strings.HasPrefix(s, self.Prefix) && strings.HasSuffix(s, self.Suffix) } func (self PrefixSuffix) String() string { return fmt.Sprintf("", self.Prefix, self.Suffix) }