if len(dbjson) > 0:
os.rename(self.questionfile, self.questionfile+".auto.bak")
try:
+ # TODO replace both of these with tempfile.NamedTemporaryFile(delete=False, dir=os.path.dirname(self.questionfile), prefix='trivia') & f.name :
if sys.version_info.major < 3:
tmpfn = os.tempnam('.', 'trivia')
f = open(tmpfn, "w")
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
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))
+ bot.msg(user, _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)
+ 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("[@<category>] <qid>", "displays the q*a for a qid", "category defaults to current")