Merge pull request #25 from velour/MarkovBabblerPlugin

do not learn from commands to the babbler
This commit is contained in:
Chris Sexton 2016-05-16 12:30:40 -04:00
commit b048890b05
2 changed files with 52 additions and 13 deletions

View File

@ -3,7 +3,6 @@
package babbler package babbler
import ( import (
// "database/sql"
"fmt" "fmt"
"math/rand" "math/rand"
"strings" "strings"
@ -80,10 +79,15 @@ func (p *BabblerPlugin) Message(message msg.Message) bool {
lowercase := strings.ToLower(message.Body) lowercase := strings.ToLower(message.Body)
tokens := strings.Fields(lowercase) tokens := strings.Fields(lowercase)
addToMarkovChain(p.babblers[message.User.Name], lowercase) if len(tokens) == 2 && tokens[1] == "says" {
saying := p.babble(tokens[0])
if len(tokens) == 4 && strings.Contains(lowercase, "initialize babbler for ") { if saying == "" {
who := tokens[len(tokens)-1] p.Bot.SendMessage(message.Channel, "Ze ain't said nothin'")
}
p.Bot.SendMessage(message.Channel, saying)
return true
} else if len(tokens) == 4 && strings.Index(lowercase, "initialize babbler for ") == 0 {
who := tokens[3]
if _, ok := p.babblers[who]; !ok { if _, ok := p.babblers[who]; !ok {
babbler, err := getMarkovChain(p.db, who) babbler, err := getMarkovChain(p.db, who)
if err == nil { if err == nil {
@ -94,16 +98,35 @@ func (p *BabblerPlugin) Message(message msg.Message) bool {
p.Bot.SendMessage(message.Channel, "Okay.") p.Bot.SendMessage(message.Channel, "Okay.")
return true return true
} }
} else if strings.Index(lowercase, "batch learn for ") == 0 {
who := tokens[3]
if _, ok := p.babblers[who]; !ok {
p.babblers[who] = newBabbler()
} }
if len(tokens) == 2 && tokens[1] == "says" { body := strings.Join(tokens[4:], " ")
saying := p.babble(tokens[0]) body = strings.ToLower(body)
if saying == "" {
p.Bot.SendMessage(message.Channel, "Ze ain't said nothin'") for _, a := range strings.Split(body, ".") {
for _, b := range strings.Split(a, "!") {
for _, c := range strings.Split(b, "?") {
for _, d := range strings.Split(c, "\n") {
trimmed := strings.TrimSpace(d)
if trimmed != "" {
addToMarkovChain(p.babblers[who], trimmed)
} }
p.Bot.SendMessage(message.Channel, saying) }
}
}
}
p.Bot.SendMessage(message.Channel, "Phew that was tiring.")
return true return true
} else {
addToMarkovChain(p.babblers[message.User.Name], lowercase)
} }
return false return false
} }

View File

@ -45,6 +45,22 @@ func TestBabbler(t *testing.T) {
assert.Contains(t, mb.Messages[0], "message") assert.Contains(t, mb.Messages[0], "message")
} }
func TestBabblerBatch(t *testing.T) {
mb := bot.NewMockBot()
c := New(mb)
c.config.Babbler.DefaultUsers = []string{"seabass"}
assert.NotNil(t, c)
seabass := makeMessage("batch learn for seabass This is a message! This is another message. This is not a long message? This is not a message! This is not another message. This is a long message?")
res := c.Message(seabass)
assert.Len(t, c.babblers, 2)
assert.Len(t, mb.Messages, 1)
res = c.Message(makeMessage("!seabass says"))
assert.Len(t, mb.Messages, 2)
assert.True(t, res)
assert.Contains(t, mb.Messages[1], "this is")
assert.Contains(t, mb.Messages[1], "message")
}
func TestHelp(t *testing.T) { func TestHelp(t *testing.T) {
mb := bot.NewMockBot() mb := bot.NewMockBot()
c := New(mb) c := New(mb)