]> gitweb.pimeys.fr Git - bots/historien.git/blobdiff - historien.py
Des évènements foireux
[bots/historien.git] / historien.py
index ffa673dbd291b9f779f44f3ebadd7d33a01b7f8d..d48cd067a3233c35a82f4131413369b854faf433 100755 (executable)
@@ -80,6 +80,11 @@ config_score_annee=1
 config_score_mois=3
 config_score_jour=4
 
+config_noscore=["[20-100]","[20-100]_"] # parce que 20-100 est nul en histoire
+
+class GoodCentury(Exception):
+    pass
+
 def reussi(message,answer,auteur):
     if auteur in config_level3:
         return answer in message
@@ -99,6 +104,8 @@ def reussi(message,answer,auteur):
                 score+=config_score_mois
                 if date[2]==realdate[2]:
                     score+=config_score_jour
+        elif date[0]/100 == realdate[0]/100:
+            raise GoodCentury
         return score
 
 def is_something(chain,matches,avant=u".*(?:^| )",apres=u"(?:$|\.| |,|;).*",case_sensitive=False,debug=False):
@@ -169,7 +176,8 @@ class Historien(ircbot.SingleServerIRCBot):
                 log(self.serveur,channel,u"$Date$".encode("utf8"),("%s : %s"%(date, evenement)).encode("utf8"))
                 serv.privmsg(channel,evenement.encode("utf8"))
                 token=time.time()
-                self.play_status[channel]=[1,date,evenement,token]
+                # le 0 est le flag "bon siècle" n' pas encore été dit
+                self.play_status[channel]=[1,date,evenement,0,token]
                 serv.execute_delayed(random.randrange(ttrig*3,ttrig*5),self.give_indice,(serv,channel,token))
             elif ok=="refuse":
                 raise RefuseError
@@ -555,7 +563,14 @@ class Historien(ircbot.SingleServerIRCBot):
         if tryother:
             if self.play_status.get(canal,[-1])[0] in [1,2]:
                 answer=self.play_status[canal][1]
-                score_obtenu=reussi(message.decode("utf8"),answer,auteur)
+                flag_century=self.play_status[canal][3]
+                try:
+                    score_obtenu=reussi(message.decode("utf8"),answer,auteur)
+                except GoodCentury:
+                    if not flag_century:
+                        serv.privmsg(canal,"%s: C'est le bon siècle, mais pas la bonne année, cherche encore ;)"%(auteur))
+                        self.play_status[canal][3]=1
+                    return
                 if score_obtenu:
                     if self.play_status[canal][0]==1:
                         bonusmsg=u" [+bonus_mois"*(score_obtenu>config_score_annee)+u"+bonus_jour"*(score_obtenu>config_score_annee+config_score_mois)+u"]"
@@ -564,6 +579,8 @@ class Historien(ircbot.SingleServerIRCBot):
                         score_obtenu=1
                     serv.privmsg(canal,(u"%s: bravo ! (C'était le %s)%s"%(auteur,answer,bonusmsg)).encode("utf8"))
                     log(self.serveur,canal,auteur+"$win",message)
+                    if auteur in config_noscore:
+                        score_obtenu=0
                     self.add_score(auteur,score_obtenu)
                     token=time.time()
                     self.play_status[canal]=[0,token]
@@ -575,7 +592,7 @@ class Historien(ircbot.SingleServerIRCBot):
         victime = ev.arguments()[0]
         raison = ev.arguments()[1]
         if victime==self.nick:
-            log(self.serveur,"%s kické par %s (raison : %s)" %(victime,auteur,raison))
+            log(self.serveur,"%s kické de %s par %s (raison : %s)" %(victime,channel,auteur,raison))
             time.sleep(5)
             serv.join(channel)
             # on ne dit rien au rejoin