func (n *Nick) String() string { if act, ok := actionMap[n.Action]; ok { return fmt.Sprintf("I last saw %s on %s (%s ago), %s.", n.Nick, n.Timestamp.Format(time.RFC1123), util.TimeSince(n.Timestamp), act(n)) } // No specific message format for the action seen. return fmt.Sprintf("I last saw %s at %s (%s ago).", n.Nick, n.Timestamp.Format(time.RFC1123), util.TimeSince(n.Timestamp)) }
func sd_smoke(bot *bot.Sp0rkle, line *base.Line) { if !smokeRx.MatchString(line.Args[1]) { return } sd := bot.GetDriver(driverName).(*seenDriver) sn := sd.LastSeenDoing(line.Nick, "SMOKE") n, c := line.Storable() if sn != nil { bot.ReplyN(line, "You last went for a smoke %s ago...", util.TimeSince(sn.Timestamp)) sn.StorableNick, sn.StorableChan = n, c sn.Timestamp = time.Now() } else { sn = seen.SawNick(n, c, "SMOKE", "") } if _, err := sd.Upsert(sn.Index(), sn); err != nil { bot.Reply(line, "Failed to store smoke data: %v", err) } }