From 78115e2f0533963de6a6b317f2acadb6da7d60de Mon Sep 17 00:00:00 2001 From: Vincent Le Gallic Date: Sun, 20 May 2012 23:42:55 +0200 Subject: [PATCH 1/1] tag --- deconnaisseur.py | 30 ++++++++++++++++++++++++++++++ 1 file changed, 30 insertions(+) diff --git a/deconnaisseur.py b/deconnaisseur.py index 94e6009..0dc4639 100755 --- a/deconnaisseur.py +++ b/deconnaisseur.py @@ -32,6 +32,14 @@ config_time_incompressible_clue=60 #on peut pas forcer la demande d'indice en de config_score_file="scores.pickle" +config_tag_triggers=[u"t(|a)g",u"ta gueule",u"la ferme",u"ferme( |-)la",u"tais-toi",u"chut"] +config_tag_actions=[u"se tait",u"ferme sa gueule",u"se la ferme",u"la ferme"] +config_tag_answers=[u"J'me tais si j'veux !", +u"Je t'entends pas :°", +u"Héhé, try again", +u"Non, j'ai pas envie", +u"Peut-être quand toi tu la fermeras, et encore…"] + class UnicodeBotError(Exception): pass def bot_unicode(chain): @@ -64,6 +72,19 @@ def tolere(regexp): reg=reg.replace(u"œ",u"(œ|oe)").replace(u"æ",u"(æ|ae)") return reg +def is_something(chain,matches,avant=u".*(?:^| )",apres=u"(?:$|\.| |,|;).*",case_sensitive=False,debug=False): + if case_sensitive: + chain=unicode(chain,"utf8") + else: + chain=unicode(chain,"utf8").lower() + allmatches="("+"|".join(matches)+")" + reg=(avant+allmatches+apres).lower() + o=re.match(reg,chain) + return o + +def is_tag(chain): + return is_something(chain,config_tag_triggers) + class RefuseError(Exception): pass @@ -468,6 +489,15 @@ class Deconnaisseur(ircbot.SingleServerIRCBot): serv.privmsg(canal,"%s: pas ici…"%(auteur)) if cmd=="indice" and canal in self.play_channels: self.give_indice(serv,canal,None) + if is_tag(message) and not canal in self.quiet_channels: + if auteur in self.ops: + action=random.choice(config_tag_actions) + serv.action(canal,action.encode("utf8")) + self.quiet_channels.append(canal) + else: + answer=random.choice(config_tag_answers) + for ligne in answer.split("\n"): + serv.privmsg(canal,"%s: %s"%(auteur,ligne.encode("utf8"))) else: tryother=True else: -- 2.39.2