store: fix Select behavior
Fix the behavior of the Select(index int) method to select the last message if an index > len(list) or select from bottom of list for negative indexes. Thanks: akspecs <akspecs@gmail.com> Signed-off-by: Tim Culverhouse <tim@timculverhouse.com> Acked-by: Robin Jarry <robin@jarry.cc>
This commit is contained in:
parent
9203c4b6ef
commit
f8e6478d46
1 changed files with 13 additions and 6 deletions
|
@ -503,12 +503,19 @@ func (store *MessageStore) SelectedIndex() int {
|
|||
}
|
||||
|
||||
func (store *MessageStore) Select(index int) {
|
||||
uids := store.Uids()
|
||||
store.selected = index
|
||||
if store.selected < 0 {
|
||||
store.selected = len(uids) - 1
|
||||
} else if store.selected > len(uids) {
|
||||
store.selected = len(uids)
|
||||
l := len(store.Uids())
|
||||
switch {
|
||||
case l+index < 0:
|
||||
// negative index overruns length of list
|
||||
store.selected = 0
|
||||
case index < 0:
|
||||
// negative index, select from bottom
|
||||
store.selected = l + index
|
||||
case index >= l:
|
||||
// index greater than length, select last
|
||||
store.selected = l - 1
|
||||
default:
|
||||
store.selected = index
|
||||
}
|
||||
store.updateVisual()
|
||||
}
|
||||
|
|
Loading…
Reference in a new issue