X-Git-Url: http://gitweb.pimeys.fr/?a=blobdiff_plain;f=hung.py;h=20adde8f7b1409180114b9c7b0d35fa3329a5302;hb=07b3ec1f01ff8258aba94b8f68a22a9b777c1736;hp=7b848186bd67cfa2b9d3adc62b031b2f06ed906f;hpb=8847da02712c4e2f56c1ab75a3da4d450513a202;p=bots%2Fhung.git diff --git a/hung.py b/hung.py index 7b84818..20adde8 100755 --- a/hung.py +++ b/hung.py @@ -42,6 +42,17 @@ def log(serveur,channel,auteur=None,message=None): print chain f.close() +def ignore_event(serv, ev): + """Retourne ``True`` si il faut ignorer cet évènement.""" + for (blackmask, exceptmask) in config.blacklisted_masks: + usermask = ev.source() + 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 @@ -75,7 +86,7 @@ def is_mot(mot,liste): real_word = "".join([lettre[0] for lettre in liste]) real_word = real_word.decode("utf8").lower() mot=remplace_accents(mot.decode("utf8")) - return mot==real_word + return mot.startswith(real_word) class Hung(ircbot.SingleServerIRCBot): def __init__(self,serveur,debug=False): @@ -124,6 +135,8 @@ class Hung(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: @@ -339,6 +352,8 @@ class Hung(ircbot.SingleServerIRCBot): self.affiche_mot(serv, canal, begin="Devinez") def on_pubmsg(self, serv, ev): + if ignore_event(serv, ev): + return auteur = irclib.nm_to_n(ev.source()) canal = ev.target() message = ev.arguments()[0] @@ -447,6 +462,8 @@ class Hung(ircbot.SingleServerIRCBot): 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()