package main
import (
- "github.com/zyedidia/tcell"
"regexp"
+
+ "github.com/zyedidia/tcell"
)
var (
messenger.hasPrompt = false
messenger.Clear()
messenger.Reset()
+ if lastSearch != "" {
+ messenger.Message("^P Previous ^N Next")
+ }
}
// HandleSearchEvent takes an event and a view and will do a real time match from the messenger's output
}
if messenger.response == "" {
- v.cursor.ResetSelection()
+ v.Cursor.ResetSelection()
// We don't end the search though
return
}
}
var str string
var charPos int
+ text := v.Buf.String()
if down {
- str = v.buf.text[searchStart:]
+ str = text[searchStart:]
charPos = searchStart
} else {
- str = v.buf.text[:searchStart]
+ str = text[:searchStart]
}
r, err := regexp.Compile(searchStr)
if err != nil {
var match []int
if matches == nil {
// Search the entire buffer now
- matches = r.FindAllStringIndex(v.buf.text, -1)
+ matches = r.FindAllStringIndex(text, -1)
charPos = 0
if matches == nil {
- v.cursor.ResetSelection()
+ v.Cursor.ResetSelection()
return
}
match = matches[0]
}
- v.cursor.curSelection[0] = charPos + match[0]
- v.cursor.curSelection[1] = charPos + match[1]
- v.cursor.x, v.cursor.y = FromCharPos(charPos+match[1]-1, v.buf)
+ if match[0] == match[1] {
+ return
+ }
+
+ v.Cursor.curSelection[0] = charPos + match[0]
+ v.Cursor.curSelection[1] = charPos + match[1]
+ v.Cursor.x, v.Cursor.y = FromCharPos(charPos+match[1]-1, v.Buf)
if v.Relocate() {
v.matches = Match(v)
}