+
+
+ def on_kick(self,serv,ev):
+ auteur = irclib.nm_to_n(ev.source())
+ channel = ev.target()
+ victime = ev.arguments()[0]
+ raison = ev.arguments()[1]
+ if victime==self.nick:
+ 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
+ #l1,l2=config.kick_answers,config.kick_actions
+ #n1,n2=len(l1),len(l2)
+ #i=random.randrange(n1+n2)
+ #if i>=n1:
+ # serv.action(channel,l2[i-n1].format(auteur).encode("utf8"))
+ #else:
+ # serv.privmsg(channel,l1[i].format(auteur).encode("utf8"))
+
+ def _getnick(self):
+ return self.serv.get_nickname()
+ nick = property(_getnick)
+
+ def quitter(self,chan,leave_message=None):
+ if leave_message==None:
+ leave_message=random.choice(config.leave_messages)
+ self.serv.part(chan,message=leave_message.encode("utf8"))
+
+ def mourir(self):
+ quit_message=random.choice(config.quit_messages)
+ self.die(msg=quit_message.encode("utf8"))
+
+ def get_scores(self):
+ f=open(config.scores_file)
+ scores=pickle.load(f)
+ f.close()
+ return scores
+ def save_scores(self,scores):
+ f=open(config.scores_file,'w')
+ pickle.dump(scores,f)
+ f.close()
+ def add_score(self,dico):
+ scores=self.get_scores()
+ for k,v in dico.items():
+ if scores.has_key(k):
+ scores[k]+=v
+ else:
+ scores[k]=v
+ self.save_scores(scores)
+ def send_scores(self, serv, destinataire):
+ scores=self.get_scores()
+ scores=scores.items()
+ scores.sort(lambda x,y:cmp(x[1],y[1]))
+ scores.reverse()
+ serv.privmsg(destinataire,"Scores by score : "+" ; ".join(["%s %s"%(k,v) for (k,v) in scores]) )
+ scores.sort(lambda x,y:cmp(x[0].lower(),y[0].lower()))
+ serv.privmsg(destinataire,"Scores by pseudo : "+" ; ".join(["%s %s"%(k,v) for (k,v) in scores]) )
+
+ def gagne(self, serv, canal, bonus=None, bonusvalue=2):
+ serv.privmsg(canal,"Bravo !")
+ realword = self.reveal_word(serv, canal)
+ nlettre=float(len(realword.replace("'","").replace("-","")))
+ contribs=["%s:%s%%%s"%(pseudo,str(int(100*contrib/nlettre)),("+bonus(%s)"%(bonusvalue))*(bonus==pseudo)) for pseudo,contrib in self.play_status[canal][2].items()]
+ contribs_score={pseudo:int(10*contrib/nlettre) for pseudo,contrib in self.play_status[canal][2].items()}
+ self.add_score(contribs_score)
+ serv.privmsg(canal,"Contributions : %s"%(" ".join(contribs)) )
+ self.play_status[canal]=[None,None,None]
+
+ def reveal_word(self, serv, canal):
+ realword="".join([lettre[0] for lettre in self.play_status[canal][0]])
+ serv.privmsg(canal, "C'était %s." % (realword))
+ definition = self.play_status[canal][1]
+ serv.privmsg(canal,definition)
+ return realword
+
+ def perd(self, serv, canal):
+ serv.privmsg(canal,"Pendu !")
+ self.reveal_word(serv, canal)
+ self.play_status[canal]=[None,None,None]
+
+ def reload(self, auteur=None):
+ reload(config)
+ if auteur in [None, "SIGHUP"]:
+ towrite = "Config reloaded" + " (SIGHUP received)"*(auteur == "SIGHUP")
+ for to in config.report_bugs_to:
+ self.serv.privmsg(to, towrite)
+ log(self.serveur, towrite)
+ else:
+ self.serv.privmsg(auteur,"Config reloaded")
+
+ def start_as_daemon(self, outfile):
+ sys.stderr = Logger(outfile)
+ self.start()
+
+
+class Logger(object):
+ """Pour écrire ailleurs que sur stdout"""
+ def __init__(self, filename="hung.full.log"):
+ self.filename = filename
+
+ def write(self, message):
+ f = open(self.filename, "a")
+ f.write(message)
+ f.close()
+
+