X-Git-Url: http://gitweb.pimeys.fr/?a=blobdiff_plain;f=hung.py;h=6be04dd5658bbd25f462bb708f35626bc28639b2;hb=67007d667863c145b09efb751d6237c3e5f8396e;hp=0ad4a372620cdeea003f2cb0ad2d0ddbca3c3155;hpb=4e3d1abd20d837a4693decb7ee70e792a9aeaf2a;p=bots%2Fhung.git diff --git a/hung.py b/hung.py index 0ad4a37..6be04dd 100755 --- a/hung.py +++ b/hung.py @@ -40,6 +40,27 @@ config_dico_defs="definitions.txt" config_scores_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…"] + +config_quit_messages=[u"_ _ _, _ _ _ _ _ _ _ _ _ _!", +u"_ _ E, _ _ _ E _ _ _ _ _ _!", +u"_ _ E, _ _ _ E _ _ O _ _ _!", +u"_ _ E, _ _ U E _ _ O _ _ _!", +u"_ _ E, _ R U E _ _ O R _ _!", +u"_ _ E, _ R U E L _ O R L _!", +u"B _ E, _ R U E L _ O R L _!", +u"B _ E, C R U E L _ O R L _!", +u"B _ E, C R U E L _ O R L D!", +u"B Y E, C R U E L _ O R L D!", +u"B Y E, C R U E L W O R L D!", +] +config_leave_messages=["On finira la partie plus tard :p"] def log(serveur,channel,auteur=None,message=None): f=open(get_config_logfile(serveur),"a") @@ -53,6 +74,7 @@ def log(serveur,channel,auteur=None,message=None): print chain f.close() + class UnicodeBotError(Exception): pass def bot_unicode(chain): @@ -68,6 +90,18 @@ def remplace_accents(chaine): chaine=chaine.replace(avant,apres) return chaine +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 Hung(ircbot.SingleServerIRCBot): def __init__(self,serveur,debug=False): @@ -142,7 +176,7 @@ class Hung(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: - serv.part(message[1]) + self.quitter(message[1]," ".join(message[2:])) self.chanlist.remove(message[1]) log(self.serveur,"priv",auteur," ".join(message)+"[successful]") else: @@ -217,7 +251,7 @@ class Hung(ircbot.SingleServerIRCBot): elif cmd=="die": if auteur in self.overops: log(self.serveur,"priv",auteur," ".join(message)+"[successful]") - self.die() + self.mourir() else: notunderstood=True elif cmd=="quiet": @@ -281,7 +315,7 @@ class Hung(ircbot.SingleServerIRCBot): indice = random.randrange(0,len(mots)) mot,definition=mots[indice],defs[indice] # ' et - sont considérés comme déjà devinés - mot = [(lettre,lettre in "'-") for lettre in list(mot)] + mot = [(lettre,lettre in "'-()") for lettre in list(mot)] self.play_status[canal]=[mot,definition,{}] self.affiche_mot(serv, canal, begin="Devinez") @@ -295,7 +329,7 @@ class Hung(ircbot.SingleServerIRCBot): if not canal in self.quiet_channels: serv.privmsg(canal, "%s: Euh, tu fais de la merde avec ton encodage là, j'ai failli crasher…"%(auteur)) - return + return pour_moi,message=self.pourmoi(serv,message) if pour_moi and message.split()!=[]: cmd=message.split()[0].lower() @@ -306,14 +340,14 @@ class Hung(ircbot.SingleServerIRCBot): if cmd in ["meurs","die","crève"]: if auteur in self.overops: log(self.serveur,canal,auteur,message+"[successful]") - self.die() + self.mourir() else: serv.privmsg(canal,"%s: crève !"%(auteur)) log(self.serveur,canal,auteur,message+"[failed]") elif cmd in ["part","leave","dégage"]: if auteur in self.ops and (not (canal in self.stay_channels) or auteur in self.overops): - serv.part(canal,message="Éjecté par %s"%(auteur)) + self.quitter(canal) log(self.serveur,canal,auteur,message+"[successful]") if canal in self.chanlist: self.chanlist.remove(canal) @@ -338,8 +372,8 @@ class Hung(ircbot.SingleServerIRCBot): liste=self.play_status[canal][0] listeapres=[(lettre[0],lettre[1] or lettre[0]==giv_let) for lettre in liste] if liste!=listeapres: - nbtrouvees=(sum([lettre[1] for lettre in listeapres if not lettre[0] in "'-"]) - - sum([lettre[1] for lettre in liste if not lettre[0] in "'-"])) + nbtrouvees=(sum([lettre[1] for lettre in listeapres if not lettre[0] in "'-()"]) + - sum([lettre[1] for lettre in liste if not lettre[0] in "'-()"])) if self.play_status[canal][2].has_key(auteur): self.play_status[canal][2][auteur]+= nbtrouvees else: @@ -353,6 +387,15 @@ class Hung(ircbot.SingleServerIRCBot): self.send_scores(serv,auteur) if cmd in ["meur", "meurt","meurre","meurres"] and not canal in self.quiet_channels: serv.privmsg(canal,'%s: Mourir, impératif, 2ème personne du singulier : "meurs" (de rien)'%(auteur)) + 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"))) # on essaye de voir si le mot fourni matche la partie en cours mot = cmd # bon, ce teste merde et j'arrive pas à trouver pourquoi, alors j'ai craqué, je l'ai mis dans un try @@ -385,7 +428,16 @@ class Hung(ircbot.SingleServerIRCBot): "%s : Euh, tu fais de la merde avec ton encodage là, j'ai failli crasher…"%(auteur)) return mypseudo=serv.get_nickname() - + + def quitter(self,chan,leave_message=None): + if leave_message==None: + leave_message=random.choice(config_leave_messages) + self.serv.part(chan,leave_message.encode("utf8")) + + def mourir(self): + quit_message=random.choice(config_quit_messages) + self.die(message=config_quit_message) + def get_scores(self): f=open(config_scores_file) scores=pickle.load(f)