1
0
Fork 0
mirror of https://github.com/diamondburned/cchat-mock.git synced 2024-12-28 22:26:45 +00:00
cchat-mock/internal/session/commander.go

115 lines
2.5 KiB
Go
Raw Normal View History

2020-10-04 20:47:41 +00:00
package session
import (
"fmt"
"strconv"
"strings"
"github.com/Pallinder/go-randomdata"
"github.com/diamondburned/cchat"
"github.com/diamondburned/cchat-mock/internal/internet"
"github.com/diamondburned/cchat/text"
"github.com/pkg/errors"
)
type Commander struct{}
2020-10-14 20:24:53 +00:00
func (c *Commander) Run(cmds []string) ([]byte, error) {
2020-10-04 20:47:41 +00:00
switch cmd := arg(cmds, 0); cmd {
case "ls":
2020-10-14 20:24:53 +00:00
return []byte("Commands: ls, random"), nil
2020-10-04 20:47:41 +00:00
case "random":
// callback used to generate stuff and stream into readcloser
var generator func() string
// number of times to generate the word
var times = 1
switch arg(cmds, 1) {
case "paragraph":
generator = randomdata.Paragraph
case "noun":
generator = randomdata.Noun
case "silly_name":
generator = randomdata.SillyName
default:
2020-10-14 20:24:53 +00:00
return nil, errors.New("Usage: random <paragraph|noun|silly_name> [repeat]")
2020-10-04 20:47:41 +00:00
}
if n := arg(cmds, 2); n != "" {
i, err := strconv.Atoi(n)
if err != nil {
2020-10-14 20:24:53 +00:00
return nil, errors.Wrap(err, "Failed to parse repeat number")
2020-10-04 20:47:41 +00:00
}
times = i
}
2020-10-14 20:24:53 +00:00
var err error
2020-10-04 20:47:41 +00:00
for i := 0; i < times; i++ {
// Yes, we're simulating this even in something as trivial as a
// command prompt.
2020-10-14 20:24:53 +00:00
if err = internet.SimulateAustralian(); err == nil {
return []byte(generator()), nil
2020-10-04 20:47:41 +00:00
}
}
2020-10-14 20:24:53 +00:00
return nil, err
2020-10-04 20:47:41 +00:00
default:
2020-10-14 20:24:53 +00:00
return nil, fmt.Errorf("Unknown command: %q", cmd)
2020-10-04 20:47:41 +00:00
}
}
func (s *Commander) AsCompleter() cchat.Completer { return s }
func (s *Commander) Complete(words []string, i int64) []cchat.CompletionEntry {
switch {
case strings.HasPrefix("ls", words[i]):
return newCompEntries("ls")
case strings.HasPrefix("random", words[i]):
return newCompEntries(
"random paragraph",
"random noun",
"random silly_name",
)
case lookbackCheck(words, i, "random", "paragraph"):
return newCompEntries("paragraph")
case lookbackCheck(words, i, "random", "noun"):
return newCompEntries("noun")
case lookbackCheck(words, i, "random", "silly_name"):
return newCompEntries("silly_name")
default:
return nil
}
}
// completion will only override `this'.
func lookbackCheck(words []string, i int64, prev, this string) bool {
return strings.HasPrefix(this, words[i]) && i > 0 && words[i-1] == prev
}
func newCompEntries(raws ...string) []cchat.CompletionEntry {
var entries = make([]cchat.CompletionEntry, len(raws))
for i, raw := range raws {
entries[i] = cchat.CompletionEntry{
Raw: raw,
Text: text.Plain(raw),
}
}
return entries
}
func arg(sl []string, i int) string {
if i >= len(sl) {
return ""
}
return sl[i]
}