Refactored Command()
This commit is contained in:
parent
b61571bebf
commit
216cb5d62d
77
bot.go
77
bot.go
@ -47,6 +47,7 @@ var argmap = map[string]int{
|
|||||||
".rmmode": 1,
|
".rmmode": 1,
|
||||||
".dm": 1,
|
".dm": 1,
|
||||||
".resetdm": 1,
|
".resetdm": 1,
|
||||||
|
".quit": 0,
|
||||||
}
|
}
|
||||||
|
|
||||||
func fillCharmap(nick string, cat string, item string, val string) {
|
func fillCharmap(nick string, cat string, item string, val string) {
|
||||||
@ -55,6 +56,7 @@ func fillCharmap(nick string, cat string, item string, val string) {
|
|||||||
|
|
||||||
func (b *Bot) Command(nick string, msg string) {
|
func (b *Bot) Command(nick string, msg string) {
|
||||||
var args = make([]string, len(strings.Split(msg, " ")) - 1)
|
var args = make([]string, len(strings.Split(msg, " ")) - 1)
|
||||||
|
var command = ""
|
||||||
|
|
||||||
for i, j := range strings.Split(msg, " ") {
|
for i, j := range strings.Split(msg, " ") {
|
||||||
if j != " " && i !=0 {
|
if j != " " && i !=0 {
|
||||||
@ -62,49 +64,54 @@ func (b *Bot) Command(nick string, msg string) {
|
|||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
if argmap[strings.Split(msg, " ")[0]] != 1 { return }
|
for i := range argmap {
|
||||||
|
if i == strings.Split(msg, " ")[0] {
|
||||||
|
command = strings.Split(msg, " ")[0]
|
||||||
|
break
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
if argmap[strings.Split(msg, " ")[0]] != len(args) { return }
|
if argmap[strings.Split(msg, " ")[0]] != len(args) { return }
|
||||||
|
|
||||||
fmt.Println("hi");
|
|
||||||
// TODO: Check if mode is enabled and if command can be applied.
|
// TODO: Check if mode is enabled and if command can be applied.
|
||||||
|
|
||||||
if strings.HasPrefix(msg, ".set") {
|
switch command {
|
||||||
|
case ".set":
|
||||||
if nick == dunmas {
|
if nick == dunmas {
|
||||||
fillCharmap(args[0], args[1], args[2], args[3])
|
fillCharmap(args[0], args[1], args[2], args[3])
|
||||||
fmt.Println("[cmd] set - " + args[0] + "'s " + args[2] + "in " + args[1] + " is set to " + args[3] + ".")
|
fmt.Println("[cmd] set - " + args[0] + "'s " + args[2] + "in " + args[1] + " is set to " + args[3])
|
||||||
} else if stringInSlice(nick, admins) && !stringInSlice("nocharoverride", rulemod) {
|
} else if stringInSlice(nick, admins) && !stringInSlice("adminoverride", rulemod) {
|
||||||
fillCharmap(args[0], args[1], args[2], args[3])
|
fillCharmap(args[0], args[1], args[2], args[3])
|
||||||
fmt.Println("[cmd] set - " + args[0] + "'s " + args[2] + " in " + args[1] + " is set to " + args[3] + ".")
|
fmt.Println("[cmd] set - " + args[0] + "'s " + args[2] + " in " + args[1] + " is set to " + args[3])
|
||||||
b.Say(nick + " used override, it's super effective!")
|
b.Say(nick + " used override, it's super effective!")
|
||||||
}
|
}
|
||||||
|
break
|
||||||
|
|
||||||
} else if strings.HasPrefix(msg, ".print") && len(args) == 3 {
|
case ".print":
|
||||||
|
fmt.Println("[cmd] print - " + args[0] + "'s " + args[2] + " in " + args[1])
|
||||||
fmt.Println("[cmd] print - " + args[0] + "'s " + args[2] + " in " + args[1] + ".")
|
b.Say(args[0] + "'s " + args[2] + " is set to " + charmap[args[0]][args[1]][args[2]])
|
||||||
b.Say(args[0] + "'s " + args[2] + " is set to " + charmap[args[0]][args[1]][args[2]] + ".")
|
break
|
||||||
|
|
||||||
} else if strings.HasPrefix(msg, ".mode") && len(args) == 1 {
|
|
||||||
|
|
||||||
|
case ".mode":
|
||||||
if stringInSlice(args[0], rulemod) {
|
if stringInSlice(args[0], rulemod) {
|
||||||
fmt.Println("[cmd] mode - change to " + args[0] + " failed, already set to true")
|
b.Say(args[0] + " is already set to true")
|
||||||
b.Say(args[0] + " is already set to true.")
|
} else if stringInSlice(args[0], modeopt) {
|
||||||
} else {
|
|
||||||
fmt.Println("[cmd] mode - " + args[0])
|
fmt.Println("[cmd] mode - " + args[0])
|
||||||
b.Say(args[0] + " is now enabled.")
|
b.Say(args[0] + " is now enabled")
|
||||||
|
rulemod = append(rulemod, args[0])
|
||||||
}
|
}
|
||||||
|
break
|
||||||
|
|
||||||
} else if strings.HasPrefix(msg, ".rmmode") && len(args) == 1 {
|
case ".rmmode":
|
||||||
|
|
||||||
if removeItemInSlice(args[0], rulemod) {
|
if removeItemInSlice(args[0], rulemod) {
|
||||||
fmt.Println("[cmd] rmmode - " + args[0])
|
fmt.Println("[cmd] rmmode - " + args[0])
|
||||||
b.Say(args[0] + " has been removed from the list of modes.")
|
b.Say(args[0] + " has been removed from the list of modes")
|
||||||
} else {
|
} else {
|
||||||
b.Say(args[0] + " isn't in the list of modes.")
|
b.Say(args[0] + " isn't in the list of modes")
|
||||||
}
|
}
|
||||||
|
break
|
||||||
|
|
||||||
} else if strings.HasPrefix(msg, ".dm") && len(args) == 1 {
|
case ".dm":
|
||||||
|
|
||||||
if len(dunmas) == 0 {
|
if len(dunmas) == 0 {
|
||||||
dunmas = args[0]
|
dunmas = args[0]
|
||||||
fmt.Println("[cmd] dm - " + dunmas)
|
fmt.Println("[cmd] dm - " + dunmas)
|
||||||
@ -112,18 +119,22 @@ func (b *Bot) Command(nick string, msg string) {
|
|||||||
} else {
|
} else {
|
||||||
b.Say("dm has already been set, the current DM is " + dunmas)
|
b.Say("dm has already been set, the current DM is " + dunmas)
|
||||||
}
|
}
|
||||||
|
break
|
||||||
|
|
||||||
} else if msg == ".resetdm" && (nick == dunmas || stringInSlice(nick, admins)) {
|
case ".resetdm":
|
||||||
|
if nick == dunmas || stringInSlice(nick, admins) {
|
||||||
dunmas = ""
|
dunmas = ""
|
||||||
fmt.Println("[cmd] resetdm")
|
fmt.Println("[cmd] resetdm")
|
||||||
b.Say("dm has been reset")
|
b.Say("dm has been reset")
|
||||||
|
}
|
||||||
} else if msg == ".quit" && stringInSlice(nick, admins) {
|
break
|
||||||
|
|
||||||
fmt.Println("[cmd] shutdown from " + nick)
|
|
||||||
os.Exit(1)
|
|
||||||
|
|
||||||
|
case ".quit":
|
||||||
|
if stringInSlice(nick, admins) {
|
||||||
|
fmt.Println("[cmd] shutdown from " + nick)
|
||||||
|
os.Exit(1)
|
||||||
|
}
|
||||||
|
break
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
|
Loading…
Reference in New Issue
Block a user