X-Git-Url: http://gitweb.pimeys.fr/?a=blobdiff_plain;f=parrot.py;h=a844a53ebc5e313941d0ccddaf84210efdafd525;hb=0cbb98d746fa75d42efb8878c77c6c533d7e2f22;hp=236cf1b225f767e2d128052143a8c6f51ada2658;hpb=e4a8875d6a305772ae5fa07781e786e6026dd0d9;p=bots%2Fparrot.git diff --git a/parrot.py b/parrot.py index 236cf1b..a844a53 100755 --- a/parrot.py +++ b/parrot.py @@ -26,7 +26,7 @@ import errors #: Module de gestion des quotes import quotes -quote_pattern = re.compile(config.quote_regexp) +quote_pattern = re.compile(config.quote_regexp, flags=re.UNICODE) def get_config_logfile(serveur): """Renvoie le nom du fichier de log en fonction du ``serveur`` et de la config.""" @@ -85,7 +85,8 @@ class Parrot(ircbot.SingleServerIRCBot): self.last_perdu = 0 self.quotedb = quotes.QuoteDB() - self.quotedb.load() + self.reload_quotes() + ### Utilitaires def _getnick(self): @@ -122,10 +123,15 @@ class Parrot(ircbot.SingleServerIRCBot): quit_message = random.choice(config.quit_messages) self.die(msg=quit_message.encode("utf8")) + def reload_quotes(self): + """ Recharge la base de données des quotes et recompile la regexp de quote """ + self.quotedb.load() + self.quote_pattern = re.compile(config.quote_regexp, flags=re.UNICODE) + def execute_reload(self, auteur=None): """Recharge la config.""" reload(config) - isit.regexp_compile() + self.reload_quotes() if auteur in [None, "SIGHUP"]: towrite = "Config reloaded" + " (SIGHUP received)" * (auteur == "SIGHUP") for to in config.report_bugs_to: @@ -155,10 +161,6 @@ class Parrot(ircbot.SingleServerIRCBot): self.serv.privmsg(place, message) log(self.serveur, place, auteur, something + "%r" % params + ("[successful]" if success else "[failed]")) - ### Gestion des quotes - def enregistrer(self, author, content, timestamp): - - quotes.save(self.quotelist, config.quote_file) ### Surcharge des events du Bot @@ -439,7 +441,7 @@ class Parrot(ircbot.SingleServerIRCBot): victime = ev.arguments()[0] raison = ev.arguments()[1] if victime == self.nick: - log(self.serveur, u"%s kické de %s par %s (raison : %s)" % (victime, channel.decode("utf-8"), auteur, raison)) + log(self.serveur, "%s kické de %s par %s (raison : %s)" % (victime, channel, auteur, raison)) time.sleep(2) serv.join(channel)