mirror of
https://github.com/Mikaela/Limnoria.git
synced 2025-01-11 20:52:42 +01:00
Added error reporting to regexp-based callCommands.
This commit is contained in:
parent
a5042e2a3d
commit
aa1b992643
@ -597,15 +597,14 @@ class Privmsg(irclib.IrcCallback):
|
|||||||
else:
|
else:
|
||||||
return False
|
return False
|
||||||
|
|
||||||
def callCommand(self, f, irc, msg, args, *L):
|
def callCommand(self, f, irc, msg, *L):
|
||||||
# Exceptions aren't caught here because IrcObjectProxy.finalEval
|
# Exceptions aren't caught here because IrcObjectProxy.finalEval
|
||||||
# catches them and does The Right Thing.
|
# catches them and does The Right Thing.
|
||||||
start = time.time()
|
start = time.time()
|
||||||
f(irc, msg, args, *L)
|
f(irc, msg, *L)
|
||||||
elapsed = time.time() - start
|
elapsed = time.time() - start
|
||||||
funcname = f.im_func.func_name
|
funcname = '%s.%s' % (f.im_class.__name__, f.im_func.func_name)
|
||||||
debug.msg('%s.%s took %s seconds' % \
|
debug.msg('%s took %s seconds' % (funcname, elapsed), 'verbose')
|
||||||
(f.im_class.__name__, funcname, elapsed), 'verbose')
|
|
||||||
|
|
||||||
_r = re.compile(r'^([^\s[]+)(?:\[|\s+|$)')
|
_r = re.compile(r'^([^\s[]+)(?:\[|\s+|$)')
|
||||||
def doPrivmsg(self, irc, msg, rateLimit=True):
|
def doPrivmsg(self, irc, msg, rateLimit=True):
|
||||||
@ -695,6 +694,13 @@ class PrivmsgRegexp(Privmsg):
|
|||||||
debug.msg(s)
|
debug.msg(s)
|
||||||
self.res.sort(lambda (r1, m1), (r2, m2): cmp(m1.__name__, m2.__name__))
|
self.res.sort(lambda (r1, m1), (r2, m2): cmp(m1.__name__, m2.__name__))
|
||||||
|
|
||||||
|
def callCommand(self, irc, msg, *L):
|
||||||
|
try:
|
||||||
|
Privmsg.callCommand(self, irc, msg, *L)
|
||||||
|
except Exception, e:
|
||||||
|
debug.recoverableException()
|
||||||
|
irc.error(msg, debug.exnToString(e))
|
||||||
|
|
||||||
def doPrivmsg(self, irc, msg):
|
def doPrivmsg(self, irc, msg):
|
||||||
if ircdb.checkIgnored(msg.prefix, msg.args[0]):
|
if ircdb.checkIgnored(msg.prefix, msg.args[0]):
|
||||||
debug.msg('PrivmsgRegexp.doPrivmsg: ignoring %s' % msg.prefix)
|
debug.msg('PrivmsgRegexp.doPrivmsg: ignoring %s' % msg.prefix)
|
||||||
@ -741,6 +747,13 @@ class PrivmsgCommandAndRegexp(Privmsg):
|
|||||||
self.res.sort(lambda (r1, m1), (r2, m2): cmp(m1.__name__, m2.__name__))
|
self.res.sort(lambda (r1, m1), (r2, m2): cmp(m1.__name__, m2.__name__))
|
||||||
self.addressedRes.sort(lambda (r1, m1), (r2, m2): cmp(m1.__name__,
|
self.addressedRes.sort(lambda (r1, m1), (r2, m2): cmp(m1.__name__,
|
||||||
m2.__name__))
|
m2.__name__))
|
||||||
|
def callCommand(self, f, irc, msg, *L):
|
||||||
|
try:
|
||||||
|
Privmsg.callCommand(self, f, irc, msg, *L)
|
||||||
|
except Exception, e:
|
||||||
|
print irc.__class__
|
||||||
|
irc.error(msg, debug.exnToString(e))
|
||||||
|
debug.recoverableException()
|
||||||
|
|
||||||
def doPrivmsg(self, irc, msg):
|
def doPrivmsg(self, irc, msg):
|
||||||
if ircdb.checkIgnored(msg.prefix, msg.args[0]):
|
if ircdb.checkIgnored(msg.prefix, msg.args[0]):
|
||||||
@ -753,7 +766,8 @@ class PrivmsgCommandAndRegexp(Privmsg):
|
|||||||
self.rateLimiter.put(msg)
|
self.rateLimiter.put(msg)
|
||||||
msg = self.rateLimiter.get()
|
msg = self.rateLimiter.get()
|
||||||
if msg:
|
if msg:
|
||||||
self.callCommand(method, IrcObjectProxyRegexp(irc), msg, m)
|
proxy = IrcObjectProxyRegexp(irc)
|
||||||
|
self.callCommand(method, proxy, msg, m)
|
||||||
s = addressed(irc.nick, msg)
|
s = addressed(irc.nick, msg)
|
||||||
if s:
|
if s:
|
||||||
for (r, method) in self.addressedRes:
|
for (r, method) in self.addressedRes:
|
||||||
|
Loading…
Reference in New Issue
Block a user