Well, now @most has one set of commands that it will run, but it required a

big dictionary.
This commit is contained in:
James Vega 2003-11-06 18:19:41 +00:00
parent a55193ea62
commit ac97573d92

View File

@ -470,6 +470,42 @@ class MoobotFactoids(callbacks.PrivmsgCommandAndRegexp):
""" """
self._lock(irc, msg, args, False) self._lock(irc, msg, args, False)
_mostCount = 10
# _mostDict is maps the requested statsitic to the set of commands that
# need to be done to generate the response. Each tuple consists of 5
# items. These are:
# 1) the SQL used to retrieve the information,
# 2) the format string for the list of 'most' items
# 3) a lambda expression which returns a tuple of the items from
# cursor.fetchall(). This tuple contains the items that will be used
# in the string supplied in 2).
# 4) the format string that will be at the head of the irc.reply message
# 5) the word which describes what we are generating statistics about.
# This will be used in the string from 4)
_mostDict = {'popular':
("""SELECT key,requested_count FROM factoids WHERE
requested_count > 0 ORDER by requested_count DESC
LIMIT %s""",
'%s (%s)',
lambda c: [(t[0], t[1]) for t in c],
'Top %s %s: %s',
'factoid'),
'authored':
("""SELECT count(key),created_by FROM factoids GROUP BY
created_by ORDER BY created_by DESC LIMIT %s""",
'%s (%s)',
lambda c: [(ircdb.users.getUser(t[1]).name, t[0]) for t
in c],
'Top %s %s: %s',
'author'),
'recent':
("""SELECT key FROM factoids ORDER by created_at DESC LIMIT
%s""",
'%s',
lambda c: [t[0] for t in c],
'%s latest %s: %s',
'factoid')
}
def most(self, irc, msg, args): def most(self, irc, msg, args):
"""<popular|authored|recent> """<popular|authored|recent>
@ -477,45 +513,19 @@ class MoobotFactoids(callbacks.PrivmsgCommandAndRegexp):
most frequently requested factoids. <authored> lists the author with most frequently requested factoids. <authored> lists the author with
the most factoids. <recent> lists the most recently created factoids. the most factoids. <recent> lists the most recently created factoids.
""" """
key = privmsgs.getArgs(args,needed=1) arg = privmsgs.getArgs(args,needed=1)
key = key.lower() arg = arg.lower()
if key == 'popular': if arg in self._mostDict:
key = 'requested_count' args = self._mostDict[arg]
cursor = self.db.cursor() cursor = self.db.cursor()
cursor.execute("""SELECT key,%s FROM factoids WHERE requested_count cursor.execute(args[0] % self._mostCount)
> 0 ORDER by %s DESC LIMIT 10""" % (key, key))
if cursor.rowcount == 0: if cursor.rowcount == 0:
irc.reply(msg, 'I can\'t find any factoids.') irc.reply(msg, 'I can\'t find any factoids.')
else: else:
popular = ['%s (%s)' % (t[0], t[1]) for t in cursor.fetchall()] resp = [args[1] % t for t in args[2](cursor.fetchall())]
l = len(popular) l = len(resp)
irc.reply(msg, 'Top %s %s: %s' % (l, utils.pluralize(l, irc.reply(msg, args[3] % (l, utils.pluralize(l, args[4]),
'factoid'), utils.commaAndify(popular))) utils.commaAndify(resp)))
elif key == 'authored':
key = 'created_by'
cursor = self.db.cursor()
cursor.execute("""SELECT count(key),%s FROM factoids GROUP BY %s
ORDER BY %s DESC LIMIT 10""" % (key, key, key))
if cursor.rowcount == 0:
irc.reply(msg, 'I can\'t find any factoids.')
else:
author = ['%s (%s)' % (ircdb.users.getUser(t[1]).name, t[0])
for t in cursor.fetchall()]
l = len(author)
irc.reply(msg, 'Top %s %s: %s' % (l, utils.pluralize(l,
'author'), utils.commaAndify(author)))
elif key == 'recent':
key = 'created_at'
cursor = self.db.cursor()
cursor.execute("""SELECT key FROM factoids ORDER by %s DESC LIMIT
10""" % key)
if cursor.rowcount == 0:
irc.reply(msg, 'I can\'t find any factoids.')
else:
recent = ['%s' % t[0] for t in cursor.fetchall()]
l = len(recent)
irc.reply(msg, '%s latest %s: %s' % (l, utils.pluralize(l,
'factoid'), utils.commaAndify(recent)))
else: else:
raise callbacks.ArgumentError raise callbacks.ArgumentError