]> gitweb.pimeys.fr Git - bots/parrot.git/blobdiff - parrot.py
!author : on affiche un message si pas de résultat
[bots/parrot.git] / parrot.py
index a507663bc0d9e6dcdbc76fd402e49e3a3910bd0d..6229e8d4a5c4189d82a0a6945fe5d8c3a52e4e50 100755 (executable)
--- a/parrot.py
+++ b/parrot.py
@@ -426,7 +426,7 @@ class Parrot(ircbot.SingleServerIRCBot):
                 self.serv.privmsg(canal, "%s: %s" % (auteur, config.quote_display_url.encode("utf-8")))
         else:
             # Vu que ce bot est prévu pour parser des quotes il va falloir bosser ici
-            match = quote_pattern.match(message)
+            match = self.quote_pattern.match(message)
             if match:
                 d = match.groupdict()
                 if self.quotedb.store(d["author"], d["content"]):
@@ -446,6 +446,18 @@ class Parrot(ircbot.SingleServerIRCBot):
                         serv.privmsg(canal, (u"Pas de quote de %s en mémoire." % author).encode("utf-8"))
                         return
                     serv.privmsg(canal, str(q))
+            elif message.startswith(u"!author"):
+                words = message.split()
+                cmd = words[0].lstrip("!")
+                regexp = cmd in ["author-r", "authorreg", "author-reg", "author-regex"]
+                search = u" ".join(words[1:])
+                authors = self.quotedb.search_authors(search, regexp)
+                if len(authors) > config.search_max_authors:
+                    authors = authors[:config.search_max_authors+1] + [unicode(len(authors) - config.search_max_authors)]
+                if authors:
+                    serv.privmsg(canal, "%s: %s" % (auteur, (u" ".join(authors)).encode("utf-8")))
+                else:
+                    serv.privmsg(canal, "%s: Pas d'auteur correspondant à la recherche.")
 
     def on_action(self, serv, ev):
         """À la réception d'une action."""