try: return str(self.db['users'][self.db['ranks'][num]]['points'])
except: return 0
+ status = False
try:
f = open(self.db['hofpath'], 'rb+')
for i in range(self.db['hoflines']): #skip this many lines
'thirdscore': pts(2),
})
f.write(fcontents)
- return True
+ status = True
except Exception as e:
- raise e #FIXME wtf???
- return False
+ status = False
finally:
f.close()
+ return status
def endPointVote(self):
self.getchan().msg("Voting has ended!")
state.nextquestion()
@lib.hook(needchan=False)
+@lib.help("[<user>]", "shows how many points you or someone has")
def points(bot, user, chan, realtarget, *args):
if chan is not None and realtarget == chan.name: replyto = chan
else: replyto = user
bot.msg(replyto, "%s has %d points." % (who, state.points(who)))
@lib.hook(glevel=lib.STAFF, needchan=False)
+@lib.help("<user> [<amount>]", "gives someone points", "defaults to 1 point")
@lib.argsGE(1)
def give(bot, user, chan, realtarget, *args):
whoto = args[0]
bot.msg(chan, "%s gave %s %d points. New balance: %d" % (user, whoto, numpoints, balance))
@lib.hook(glevel=1, needchan=False)
+@lib.help("<qid>", "sets next question to one in the database")
+@lib.argsEQ(1)
def setnextid(bot, user, chan, realtarget, *args):
try:
qid = int(args[0])
bot.msg(user, "Error: %s" % (e))
@lib.hook(glevel=lib.STAFF, needchan=False)
+@lib.help("<q>*<a>", "sets next question to one not in database")
@lib.argsGE(1)
def setnext(bot, user, chan, realtarget, *args):
line = ' '.join([str(arg) for arg in args])
bot.msg(user, "Done.")
@lib.hook(glevel=1, needchan=False)
+@lib.help(None, "skips to next question")
def skip(bot, user, chan, realtarget, *args):
state.nextquestion(qskipped=True, skipwait=True)
@lib.hook(needchan=False)
+@lib.help(None, "starts the trivia game")
def start(bot, user, chan, realtarget, *args):
if chan is not None and realtarget == chan.name: replyto = chan
else: replyto = user
bot.msg(user, "Game is already started!")
@lib.hook('stop', glevel=1, needchan=False)
+@lib.help(None, "stops the trivia game")
def cmd_stop(bot, user, chan, realtarget, *args):
if stop():
bot.msg(state.chan, "Game stopped by %s" % (user))
else:
bot.msg(user, "Game isn't running.")
-@lib.hook('exception', glevel=lib.OWNER)
-def cmd_exception(*args, **kwargs):
- raise Exception()
-
def stop():
state.curq = None
state.nextq = None
return True
@lib.hook(needchan=False)
+@lib.help("<reason>", "reports a bad question to the admins")
@lib.argsGE(1)
def badq(bot, user, chan, realtarget, *args):
lastqid = state.lastqid
reason = ' '.join(args)
state.db['badqs'].append([lastqid, curqid, reason])
+ state.savedb()
bot.msg(user, "Reported bad question.")
@lib.hook(glevel=lib.STAFF, needchan=False)
+@lib.help(None, "shows a list of BADQ reports")
def badqs(bot, user, chan, realtarget, *args):
if len(state.db['badqs']) == 0:
bot.msg(user, "No reports.")
bot.msg(user, "- Exception: %r" % (e))
@lib.hook(glevel=lib.STAFF, needchan=False)
+@lib.hook(None, "clears list of BADQ reports")
def clearbadqs(bot, user, chan, realtarget, *args):
state.db['badqs'] = []
+ state.savedb()
bot.msg(user, "Cleared reports.")
@lib.hook(glevel=lib.STAFF, needchan=False)
+@lib.hook("<badqid>", "removes a BADQ report")
@lib.argsEQ(1)
def delbadq(bot, user, chan, realtarget, *args):
- qid = int(args[0])
- del state.db['badqs'][qid]
- bot.msg(user, "Removed report #%d" % (qid))
+ try:
+ qid = int(args[0])
+ del state.db['badqs'][qid]
+ state.savedb()
+ bot.msg(user, "Removed report #%d" % (qid))
+ except:
+ bot.msg(user, "Failed!")
@lib.hook(needchan=False)
+@lib.help("[<user>]", "shows you or someone else's rank")
def rank(bot, user, chan, realtarget, *args):
if chan is not None and realtarget == chan.name: replyto = chan
else: replyto = user
bot.msg(replyto, "%s is in %d place (%s points). Target is: %s (%s points)." % (who, state.rank(who), state.points(who), state.targetuser(who), state.targetpoints(who)))
@lib.hook(needchan=False)
+@lib.help(None, "shows top10 list")
def top10(bot, user, chan, realtarget, *args):
if len(state.db['ranks']) == 0:
return bot.msg(state.db['chan'], "No one is ranked!")
bot.msg(state.db['chan'], "Top 10: %s" % (replylist))
@lib.hook(glevel=lib.ADMIN, needchan=False)
+@lib.help("<target score>", "changes the target score for this round")
def settarget(bot, user, chan, realtarget, *args):
try:
state.db['target'] = int(args[0])
bot.msg(user, "Failed to set target.")
@lib.hook(needchan=False)
+@lib.help("<option>", "votes for a trarget score for next round")
def vote(bot, user, chan, realtarget, *args):
if state.pointvote is not None:
if int(args[0]) in state.voteamounts:
bot.msg(user, "There's no vote in progress.")
@lib.hook(glevel=lib.ADMIN, needchan=False)
+@lib.help("<number>", "sets the max missed question before game stops")
def maxmissed(bot, user, chan, realtarget, *args):
try:
state.db['maxmissedquestions'] = int(args[0])
bot.msg(user, "Failed to set maxmissed.")
@lib.hook(glevel=lib.ADMIN, needchan=False)
+@lib.help("<seconds>", "sets the time between hints")
def hinttimer(bot, user, chan, realtarget, *args):
try:
state.db['hinttimer'] = float(args[0])
bot.msg(user, "Failed to set hint timer.")
@lib.hook(glevel=lib.ADMIN, needchan=False)
+@lib.help("<number>", "sets the number of hints given")
def hintnum(bot, user, chan, realtarget, *args):
try:
state.db['hintnum'] = int(args[0])
bot.msg(user, "Failed to set hintnum.")
@lib.hook(glevel=lib.ADMIN, needchan=False)
+@lib.help("<seconds>", "sets the pause between questions")
def questionpause(bot, user, chan, realtarget, *args):
try:
state.db['questionpause'] = float(args[0])
bot.msg(user, "Failed to set questionpause.")
@lib.hook(glevel=1, needchan=False)
+@lib.help("<full question>", "finds a qid given a complete question")
def findq(bot, user, chan, realtarget, *args):
+ 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(state.db['questions'])) if state.db['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.")
+
+@lib.hook(glevel=1, needchan=False)
+@lib.help("<regex>", "finds a qid given a regex or partial question")
+def findqre(bot, user, chan, realtarget, *args):
if len(args) == 0:
bot.msg(user, "You need to specify a search string.")
return
- searcher = re.compile(' '.join(args))
+ searcher = re.compile(' '.join(args), re.IGNORECASE)
matches = [str(i) for i in range(len(state.db['questions'])) if searcher.search(state.db['questions'][i][0]) is not None]
if len(matches) > 25:
bot.msg(user, "Too many matches! (>25)")
bot.msg(user, "No match.")
@lib.hook(glevel=lib.STAFF, needchan=False)
+@lib.help("<qid>", "displays the q*a for a qid")
def showq(bot, user, chan, realtarget, *args):
try:
qid = int(args[0])
bot.msg(user, "%s: %s*%s" % (qid, q[0], q[1]))
@lib.hook(('delq', 'deleteq'), glevel=lib.STAFF, needchan=False)
+@lib.help("<qid>", "removes a question from the database")
def delq(bot, user, chan, realtarget, *args):
try:
backup = state.db['questions'][int(args[0])]
bot.msg(user, "Couldn't delete that question. %r" % (e))
@lib.hook(glevel=lib.STAFF, needchan=False)
+@lib.help("<q>*<a>", "adds a question")
def addq(bot, user, chan, realtarget, *args):
line = ' '.join([str(arg) for arg in args])
linepieces = line.split('*')
if user.glevel >= 1:
bot.slowmsg(user, "SKIP (KNOWN)")
bot.slowmsg(user, "STOP (KNOWN)")
- bot.slowmsg(user, "FINDQ <question> (KNOWN)")
+ bot.slowmsg(user, "FINDQ <full question> (KNOWN)")
+ bot.slowmsg(user, "FINDQRE <regex> (KNOWN)")
bot.slowmsg(user, "SETNEXTID <qid> (KNOWN)")
if user.glevel >= lib.STAFF:
bot.slowmsg(user, "GIVE <user> [<points>] (STAFF)")