From 42724e0b914649039e23f3104474a5b4c91f7aac Mon Sep 17 00:00:00 2001 From: diamondburned Date: Sat, 14 Nov 2020 22:27:55 -0800 Subject: [PATCH] Bot: Fixed CustomParser trim not using aliases and plumbs --- bot/ctx_call.go | 24 +++++++++++++++++++----- 1 file changed, 19 insertions(+), 5 deletions(-) diff --git a/bot/ctx_call.go b/bot/ctx_call.go index 1677a71..ffef177 100644 --- a/bot/ctx_call.go +++ b/bot/ctx_call.go @@ -261,12 +261,10 @@ func (ctx *Context) callMessageCreate(mc *gateway.MessageCreateEvent, value refl // have erroneous hanging quotes. parseErr = nil - content = strings.TrimSpace(content) - content = strings.TrimPrefix(content, cmd.Command) + content = trimPrefixStringAndSlice(content, sub.Command, sub.Aliases) - if !sub.IsPlumbed() { - content = strings.TrimSpace(content) - content = strings.TrimPrefix(content, sub.Command) + if !sub.IsPlumbed() && cmd.Command != "" { + content = trimPrefixStringAndSlice(content, cmd.Command, cmd.Aliases) } // Call the method with the raw unparsed command: @@ -377,6 +375,22 @@ func searchStringAndSlice(str string, isString string, otherStrings []string) bo return false } +// trimPrefixStringAndSlice behaves similarly to searchStringAndSlice, but it +// trims the prefix and the surrounding spaces after a match. +func trimPrefixStringAndSlice(str string, prefix string, prefixes []string) string { + if strings.HasPrefix(str, prefix) { + return strings.TrimSpace(str[len(prefix):]) + } + + for _, prefix := range prefixes { + if strings.HasPrefix(str, prefix) { + return strings.TrimSpace(str[len(prefix):]) + } + } + + return str +} + func errNoBreak(err error) error { if errors.Is(err, Break) { return nil