X-Git-Url: http://gitweb.pimeys.fr/?p=bots%2Fbasile.git;a=blobdiff_plain;f=basile.py;h=4ee806783efa2306f1f0afc738f7c3ad7e3bdc46;hp=ecbef4ec39389afed5def41297096a77c7531098;hb=4d6cedfb164059e9c5c607db4752533ae7333b44;hpb=667757031c816e434da2065b2d129402a7a72f5f diff --git a/basile.py b/basile.py index ecbef4e..4ee8067 100755 --- a/basile.py +++ b/basile.py @@ -54,6 +54,17 @@ def log(serveur, channel, auteur=None, message=None): if config.debug_stdout: print chain +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)) + return blackit and not exceptit + def regex_join(liste, avant=u".*(?:^| )", apres=u"(?:$|\.| |,|;).*"): """Fabrique une regexp à partir d'une liste d'éléments à matcher.""" return avant + u"(" + u"|".join(liste) + u")" + apres @@ -425,7 +436,7 @@ class Basile(ircbot.SingleServerIRCBot): if auteur in self.ops and len(message) > 1: if message[1] in self.chanlist: if not (message[1] in self.stay_channels) or auteur in self.overops: - self.quitter(message[1], " ".join(message[2:])) + self.quitter(message[1].encode("utf-8"), " ".join(message[2:])) self.chanlist.remove(message[1]) log(self.serveur, "priv", auteur, " ".join(message) + "[successful]") else: