def endPointVote(self):
self.getchan().msg("Voting has ended!")
- votelist = sorted(self.voteamounts.items(), key=lambda item: item[1]) #sort into list of tuples: [(option, number_of_votes), ...]
+ votelist = sorted(self.voteamounts.items(), key=lambda item: (item[1], -item[0])) #sort into list of tuples: [(option, number_of_votes), ...]
for i in range(len(votelist)-1):
item = votelist[i]
self.getchan().msg("%s place: %s (%s votes)" % (len(votelist)-i, item[0], item[1]))
elif self.nextqid is not None:
nextqid = self.nextqid
nextq = self.questions[nextqid]
+ if len(nextq) > 2: nextq[2] = 0 # Unset the time it was last asked.
self.nextqid = None
else:
nextqid = random.randrange(0, len(self.questions))
qtext += "\00304,01"+qword+"\00301,01"+chr(spacer) #a-z
if not self.getbot().fastmsg(self.chan, qtext): #if message is too long:
if not self.getbot().fastmsg(self.chan, "\00312,01Next up: " + ("(%5d)" % (random.randint(0,99999))) + "\00304,01" + nextq[0]):
- if nextqid is None: nextqid = "manual"
- self.getbot().slowmsg(self.chan, "(Unable to ask question #%s: line too long)" % (nextqid))
- return self._nextquestion(iteration) #retry; don't increment the iteration
+ if not self.getbot().fastmsg(self.chan, "Next up: " + nextq[0]):
+ if nextqid is None: nextqid = "manual"
+ self.getbot().slowmsg(self.chan, "(Unable to ask question #%s: line too long)" % (nextqid))
+ return self._nextquestion(iteration) #retry; don't increment the iteration
self.curq = nextq
self.curqid = nextqid
else:
return len(self.db['users'])+1
+ def get_streak(self, user):
+ user = str(user).lower()
+ if user in self.db['streaks']:
+ return self.db['streaks'][user]
+ else:
+ return [0,0]
+
def targetuser(self, user):
if len(self.db['ranks']) == 0: return "no one is ranked!"
response += ". New score: %d. Rank: %d. Target: %s %s" % (state.addpoint(user), state.rank(user), state.targetuser(user), state.targetpoints(user))
bot.fastmsg(chan, response)
+ user_lower = str(user).lower()
+ new_max_streak = ""
+ if user_lower not in state.db['streaks']:
+ state.db['streaks'][user_lower] = [0, 0]
+ if state.streak > state.db['streaks'][user_lower][0]:
+ state.db['streaks'][user_lower] = [state.streak, time.time()]
+ new_max_streak = " That's a new record for them!"
+
if state.streak >= 3:
- bot.msg(chan, "\00312%s\003 is on a streak! \00307%d\003 answers correct in a row!" % (user, state.streak))
+ bot.msg(chan, "\00312%s\003 is on a streak! \00307%d\003 answers correct in a row!%s" % (user, state.streak, new_max_streak))
if state.hintsgiven == 0:
bot.msg(chan, "\00312%s\003 got an extra point for getting it before the hints! New score: %d." % (user, state.addpoint(user)))
@lib.hook(needchan=False, wantchan=True)
@lib.help("[<user>]", "shows how many points you or someone has")
def points(bot, user, chan, realtarget, *args):
- if chan is not None: eplyto = chan
+ if chan is not None: replyto = chan
else: replyto = user
if len(args) != 0: who = args[0]
bot.msg(user, "Failed to set questionpause.")
@lib.hook(glevel=1, needchan=False)
-@lib.help("[@category] <full question>", "finds a qid given a complete question")
+@lib.help("[@category] <question>", "finds a question (qid) given a (partial) question")
@lib.argsGE(1)
def findq(bot, user, chan, realtarget, *args):
args = list(args)
else:
questions = state.questions
- if len(args) == 0:
- bot.msg(user, "You need to specify the question.")
- return
-
- searchkey = ' '.join(args).lower()
- matches = [str(i) for i in range(len(questions)) if questions[i][0].lower() == searchkey]
- if len(matches) > 1:
- bot.msg(user, "Multiple matches: %s" % (', '.join(matches)))
- elif len(matches) == 1:
- bot.msg(user, "One match: %s" % (matches[0]))
- else:
- bot.msg(user, "No match.")
+ pattern = re.escape(' '.join(args))
+ return _findq(questions, pattern)
@lib.hook(glevel=1, needchan=False)
-@lib.help("[@<category>] <regex>", "finds a qid given a regex or partial question")
+@lib.help("[@<category>] <regex>", "finds a question (qid) given a regex")
@lib.argsGE(1)
def findqre(bot, user, chan, realtarget, *args):
args = list(args)
questions = state.db['questions'][cat]
else:
questions = state.questions
+ pattern = ' '.join(args)
+ return _findq(questions, pattern)
- if len(args) == 0:
- bot.msg(user, "You need to specify a search string.")
- return
+@lib.hook(glevel=1, needchan=False)
+@lib.help("[@<category>] <phrase>", "finds a question (qid) given a (partial) question or answer")
+@lib.argsGE(1)
+def findqa(bot, user, chan, realtarget, *args):
+ args = list(args)
+ if args[0].startswith("@"):
+ cat = args.pop(0)[1:].lower()
+ questions = state.db['questions'][cat]
+ else:
+ questions = state.questions
+ pattern = ' '.join(args)
+ return _findq(questions, pattern, True)
- searcher = re.compile(' '.join(args), re.IGNORECASE)
- matches = [str(i) for i in range(len(questions)) if searcher.search(questions[i][0]) is not None]
+def _findq(questions, pattern, check_answers=False):
+ searcher = re.compile(pattern, re.IGNORECASE)
+ matches = [i for i in range(len(questions)) if searcher.search(questions[i][0]) is not None or (check_answers and searcher.search(questions[i][1]) is not None)]
if len(matches) > 25:
- bot.msg(user, "Too many matches! (>25)")
+ return "Too many matches! (>25)"
elif len(matches) > 1:
- bot.msg(user, "Multiple matches: %s" % (', '.join(matches)))
+ return "Multiple matches: %s" % (', '.join(str(x) for x in matches))
elif len(matches) == 1:
- bot.msg(user, "One match: %s" % (matches[0]))
+ i = matches[0]
+ return "One match: %s %s*%s" % (i, questions[i][0], questions[i][1])
else:
- bot.msg(user, "No match.")
+ return "No match."
@lib.hook(glevel=lib.STAFF, needchan=False)
@lib.help("[@<category>] <qid>", "displays the q*a for a qid", "category defaults to current")
else:
bot.msg(user, "Category does not exist.")
+@lib.hook(needchan=False)
+@lib.help("[<nick>]", "shows a user's (or your own) max streak")
+def streak(bot, user, chan, realtarget, *args):
+ if chan is not None: replyto = chan
+ else: replyto = user
+
+ if len(args) != 0: who = args[0]
+ else: who = user
+
+ streak = state.get_streak(who)
+ bot.msg(replyto, "%s's highest streak is %d, set %s" % (who, streak[0], time.strftime("%d %b %Y %H:%M:%S %Z", time.gmtime(streak[1]))))
+
+@lib.hook(needchan=False)
+@lib.help(None, "shows top streaks of all time")
+def topstreaks(bot, user, chan, realtarget, *args):
+ db = state.db['streaks']
+ streaks = [(nick, db[nick][0], db[nick][1]) for nick in db.keys()]
+ streaks.sort(key=lambda v: v[1], reverse=True)
+ return "Top streaks of all time: %s (%d), %s (%d), %s (%d)." % (streaks[0][0], streaks[0][1], streaks[1][0], streaks[1][1], streaks[2][0], streaks[2][1])
+
+@lib.hook(glevel=lib.MANAGER, needchan=False)
+@lib.help("<nick> <new streak> [<timestamp>]", "set a user's max streak")
+@lib.argsGE(2)
+def setstreak(bot, user, chan, realtarget, *args):
+ temp = 0
+ target = args[0].lower()
+ try:
+ newstreak = int(args[1])
+ except ValueError:
+ return "Error: <new streak> must be integer"
+ timestamp = time.time()
+ if len(args) > 2:
+ try:
+ timestamp = int(args[2])
+ except ValueError:
+ return "Error: <timestamp> must be integer (unix timestamp)"
+
+ if target in state.db['streaks']:
+ temp = state.db['streaks'][target]
+ if newstreak == 0:
+ del state.db['streaks'][target]
+ if newstreak > 0:
+ state.db['streaks'][target] = [newstreak, timestamp]
+ return "Done. Streak used to be %d set %d" % (temp[0], temp[1])
+
@lib.hook(needchan=False)
def triviahelp(bot, user, chan, realtarget, *args):
bot.slowmsg(user, "START")
bot.slowmsg(user, "TOP10")
bot.slowmsg(user, "POINTS [<user>]")
bot.slowmsg(user, "RANK [<user>]")
+ bot.slowmsg(user, "STREAK [<user>]")
+ bot.slowmsg(user, "TOPSTREAKS")
bot.slowmsg(user, "BADQ <reason> (include info to identify question)")
if user.glevel >= 1:
bot.slowmsg(user, "SKIP (KNOWN)")
bot.slowmsg(user, "HINTTIMER <float seconds> (ADMIN)")
bot.slowmsg(user, "HINTNUM <hints> (ADMIN)")
bot.slowmsg(user, "QUESTIONPAUSE <float seconds> (ADMIN)")
+ bot.slowmsg(user, "SETSTREAK <nick> <streak> (ADMIN)")
@lib.hooknum(332) # topic is...
@lib.hooknum(331) # no topic set
# "nine", "ten", "eleven", "twelve", "thirteen", "fourteen", "fifteen",
# "sixteen", "seventeen", "eighteen", "nineteen", "twenty"
# ][num]
+
+
+def topa():
+ answers=__import__('collections').defaultdict(int)
+ for a in (x[1] for x in state.db['questions']['general']):
+ answers[a]+=1;
+ a2=[]
+ for a, num in answers.items():
+ a2.append((a, num))
+ a2.sort(key=lambda v: v[1], reverse=True)
+ return a2