X-Git-Url: http://gitweb.pimeys.fr/?a=blobdiff_plain;ds=sidebyside;f=saturnin.py;h=2d9b4e970b9d80deabcd14da47020ef255719c45;hb=6b6d0c5d8cb493240208a6c474be14a1f29d8930;hp=4903ec32892e35832c00df7351d9205f36b349e2;hpb=015c05016255df0dc06e6ebb2e21c7b8dbe34de4;p=bots%2Fsaturnin.git diff --git a/saturnin.py b/saturnin.py index 4903ec3..2d9b4e9 100755 --- a/saturnin.py +++ b/saturnin.py @@ -56,11 +56,18 @@ def is_something(chain,matches,avant=u".*(?:^| )",apres=u"(?:$|\.| |,|;).*",case regexp_pan = re.compile(u".*(" + "|".join(config.killwords) + u").*") def is_pan(chain): return regexp_pan.match(unicode(chain,"utf8").lower()) -def ignore_pan(serv, ev): - """Retourne ``True`` si il faut ignorer ce pan.""" - for (blackmask, exceptmask) in config.ignored_pan_masks: + +def ignore_event(serv, ev): + """Retourne ``True`` si il faut ignorer cet évènement.""" + for (blackmask, exceptmask) in config.blacklisted_masks: usermask = ev.source() - return bool(irclib.mask_matches(usermask, blackmask) and not irclib.mask_matches(usermask, exceptmask)) + if exceptmask is None: + exceptit = False + else: + exceptit = bool(irclib.mask_matches(usermask, exceptmask)) + blackit = bool(irclib.mask_matches(usermask, blackmask)) + if blackit and not exceptit: + return True class UnicodeBotError(Exception): pass @@ -121,6 +128,8 @@ class Saturnin(ircbot.SingleServerIRCBot): return (False,message) def on_privmsg(self, serv, ev): + if ignore_event(serv, ev): + return message=ev.arguments()[0] auteur = irclib.nm_to_n(ev.source()) try: @@ -396,6 +405,13 @@ class Saturnin(ircbot.SingleServerIRCBot): self.add_score(de,-asked) self.add_score(to,asked) serv.privmsg(auteur,"Transfert de %s points de %s à %s"%(asked,de,to)) + elif len(message) == 2: + scores = self.get_scores() + asked = message[1] + if asked in scores: + serv.privmsg(auteur, "Score de %s : %s" % (asked, scores[asked])) + else: + serv.privmsg(auteur, "%s n'a encore jamais joué (avec succès)." % (asked,)) else: serv.privmsg(auteur,"Syntaxe : SCORE TRANSFERT []") else: @@ -454,9 +470,9 @@ class Saturnin(ircbot.SingleServerIRCBot): self.serv.privmsg(to, "Scores by pseudo : "+" ; ".join(["%s %s"%(i[0],i[1]) for i in scores])) def on_pubmsg(self, serv, ev): - auteur = irclib.nm_to_n(ev.source()) - if re.match(config.ignored_pseudos, auteur): + if ignore_event(serv, ev): return + auteur = irclib.nm_to_n(ev.source()) channel = ev.target() message = ev.arguments()[0] try: @@ -499,11 +515,11 @@ class Saturnin(ircbot.SingleServerIRCBot): self.sendscores(auteur) else: if is_pan(message): - if ignore_pan(serv, ev): - return self.shot(channel, auteur) def on_action(self, serv, ev): + if ignore_event(serv, ev): + return action = ev.arguments()[0] auteur = irclib.nm_to_n(ev.source()) channel = ev.target()