Compare commits
2 Commits
c5c733d14c
...
f4f563c530
| Author | SHA1 | Date | |
|---|---|---|---|
| f4f563c530 | |||
| ff20bbef2c |
@@ -20,13 +20,9 @@ type Set[V any] struct {
|
|||||||
// The behavior is undefined if the key already has a value.
|
// The behavior is undefined if the key already has a value.
|
||||||
func (s *Set[V]) Add(key string, val V) {
|
func (s *Set[V]) Add(key string, val V) {
|
||||||
k := util.ToChars([]byte(key))
|
k := util.ToChars([]byte(key))
|
||||||
i, ok := slices.BinarySearchFunc(s.keys, k, func(a, b util.Chars) int {
|
i, _ := slices.BinarySearchFunc(s.keys, k, func(a, b util.Chars) int {
|
||||||
return bytes.Compare(a.Bytes(), b.Bytes())
|
return bytes.Compare(a.Bytes(), b.Bytes())
|
||||||
})
|
})
|
||||||
if ok {
|
|
||||||
s.vals[i] = val
|
|
||||||
return
|
|
||||||
}
|
|
||||||
s.keys = slices.Insert(s.keys, i, k)
|
s.keys = slices.Insert(s.keys, i, k)
|
||||||
s.vals = slices.Insert(s.vals, i, val)
|
s.vals = slices.Insert(s.vals, i, val)
|
||||||
}
|
}
|
||||||
|
|||||||
6
main.go
6
main.go
@@ -163,11 +163,7 @@ func skillHandler(data discord.SlashCommandInteractionData, e *handler.CommandEv
|
|||||||
func skillAutocomplete(e *handler.AutocompleteEvent) error {
|
func skillAutocomplete(e *handler.AutocompleteEvent) error {
|
||||||
q := e.Data.String("query")
|
q := e.Data.String("query")
|
||||||
opts := skillGlobalAuto().Find(nil, q)
|
opts := skillGlobalAuto().Find(nil, q)
|
||||||
r := make([]discord.AutocompleteChoice, min(len(opts), 25))
|
return e.AutocompleteResult(opts[:min(len(opts), 25)])
|
||||||
for i, k := range opts[:min(len(opts), len(r))] {
|
|
||||||
r[i] = discord.AutocompleteChoiceString{Name: k, Value: k}
|
|
||||||
}
|
|
||||||
return e.AutocompleteResult(r)
|
|
||||||
}
|
}
|
||||||
|
|
||||||
func skillButton(data discord.ButtonInteractionData, e *handler.ComponentEvent) error {
|
func skillButton(data discord.ButtonInteractionData, e *handler.ComponentEvent) error {
|
||||||
|
|||||||
6
skill.go
6
skill.go
@@ -118,11 +118,11 @@ func isDebuff(s horse.Skill) bool {
|
|||||||
return false
|
return false
|
||||||
}
|
}
|
||||||
|
|
||||||
var skillGlobalAuto = sync.OnceValue(func() *autocomplete.Set[string] {
|
var skillGlobalAuto = sync.OnceValue(func() *autocomplete.Set[discord.AutocompleteChoice] {
|
||||||
var set autocomplete.Set[string]
|
var set autocomplete.Set[discord.AutocompleteChoice]
|
||||||
for _, id := range global.OrderedSkills {
|
for _, id := range global.OrderedSkills {
|
||||||
s := global.AllSkills[id]
|
s := global.AllSkills[id]
|
||||||
set.Add(s.Name, s.Name)
|
set.Add(s.Name, discord.AutocompleteChoiceString{Name: s.Name, Value: s.Name})
|
||||||
}
|
}
|
||||||
return &set
|
return &set
|
||||||
})
|
})
|
||||||
|
|||||||
Reference in New Issue
Block a user