X-Git-Url: https://jfr.im/git/erebus.git/blobdiff_plain/c3ff1486929923f394c219e6999df301a5a5bf04..58cd01915145ccfc90db81073a2d5451630562ac:/modules/trivia.py diff --git a/modules/trivia.py b/modules/trivia.py index b5191d3..cf67a2a 100644 --- a/modules/trivia.py +++ b/modules/trivia.py @@ -331,6 +331,7 @@ class TriviaState(object): 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)) @@ -363,9 +364,10 @@ class TriviaState(object): 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 @@ -716,7 +718,7 @@ def questionpause(bot, user, chan, realtarget, *args): bot.msg(user, "Failed to set questionpause.") @lib.hook(glevel=1, needchan=False) -@lib.help("[@category] ", "finds a qid given a complete question") +@lib.help("[@category] ", "finds a question (qid) given a (partial) question") @lib.argsGE(1) def findq(bot, user, chan, realtarget, *args): args = list(args) @@ -726,21 +728,11 @@ def findq(bot, user, chan, realtarget, *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)) + bot.msg(user, _findq(questions, pattern)) @lib.hook(glevel=1, needchan=False) -@lib.help("[@] ", "finds a qid given a regex or partial question") +@lib.help("[@] ", "finds a question (qid) given a regex") @lib.argsGE(1) def findqre(bot, user, chan, realtarget, *args): args = list(args) @@ -749,21 +741,20 @@ def findqre(bot, user, chan, realtarget, *args): questions = state.db['questions'][cat] else: questions = state.questions + pattern = ' '.join(args) + bot.msg(user, _findq(questions, pattern)) - if len(args) == 0: - bot.msg(user, "You need to specify a search string.") - return - - searcher = re.compile(' '.join(args), re.IGNORECASE) +def _findq(questions, pattern): + searcher = re.compile(pattern, re.IGNORECASE) matches = [str(i) for i in range(len(questions)) if searcher.search(questions[i][0]) 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(matches)) elif len(matches) == 1: - bot.msg(user, "One match: %s" % (matches[0])) + return "One match: %s" % (matches[0]) else: - bot.msg(user, "No match.") + return "No match." @lib.hook(glevel=lib.STAFF, needchan=False) @lib.help("[@] ", "displays the q*a for a qid", "category defaults to current")