disabled bool
b []byte
f func(l *absurllexer)
+
+ nextPos int
+}
+
+func (p *prefix) find(bs []byte, start int) bool {
+ if p.disabled {
+ return false
+ }
+
+ if p.nextPos == -1 {
+ idx := bytes.Index(bs[start:], p.b)
+
+ if idx == -1 {
+ p.disabled = true
+ // Find the closest match
+ return false
+ }
+
+ p.nextPos = start + idx + len(p.b)
+ }
+
+ return true
}
func newPrefixState() []*prefix {
break
}
- nextPos := -1
-
var match *prefix
for _, p := range prefixes {
- if p.disabled {
+ if !p.find(l.content, l.pos) {
continue
}
- idx := bytes.Index(l.content[l.pos:], p.b)
- if idx == -1 {
- p.disabled = true
- // Find the closest match
- } else if nextPos == -1 || idx < nextPos {
- nextPos = idx
+ if match == nil || p.nextPos < match.nextPos {
match = p
}
}
- if nextPos == -1 {
+ if match == nil {
// Done!
l.pos = contentLength
break
} else {
- l.pos += nextPos + len(match.b)
+ l.pos = match.nextPos
+ match.nextPos = -1
match.f(l)
}
}
-
// Done!
if l.pos > l.start {
l.emit()