blacklisted_masks = [("Flo!*@*", [])]
#: Regexp utilisée pour parser des quotes
-quote_regexp = ur"""\s*("|«|')\s*(?P<content>.+?)\s*("|»|') ?~ ?(?P<author>.+?)\s*$"""
+quote_regexp = ur"""\s*(?:"|«|')\s*(?P<content>.+?)\s*(?:"|»|') ?~ ?(?P<author>.+?)\s*(?:$|\n)"""
+
+#: Regexp utlisée pour parser une quote avec timestamp
+quote_regexp_with_timestamp = ur"(?P<timestamp>.{19}) " + quote_regexp
#: Template pour afficher une quote
quote_template = u"« %(content)s » ~ %(author)s"
#: Fichier pour stocker les quotes
quote_file = u"quotes.json"
+
+#: Fichier pour exporter les quotes
+quote_dump_file = u"quotes.txt"
def randomfrom(self, author):
""" Sort une quote aléatoire de ``author`` """
return random.choice([q for q in self.quotelist if q.author == author])
+
+def dump(quotedb, dump_file=None):
+ """Pour exporter les quotes dans un format readable vers un fichier."""
+ if dump_file is None:
+ dump_file = config.quote_dump_file
+ t = "\n".join(["%s %s" % (q.timestamp.strftime("%F_%T"), q) for q in quotedb.quotelist]) + "\n"
+ with open(dump_file, "w") as f:
+ f.write(t)
+
+def restore(dump_file=None):
+ """Crée un DB de quotes en parsant le contenu d'un fichier de dump."""
+ if dump_file is None:
+ dump_file = config.quote_dump_file
+ with open(dump_file) as f:
+ t = f.read()
+ t = t.decode("utf-8") # Oui, ça peut fail, mais on ne doit alors pas continuer
+ regex = re.compile(config.quote_regexp_with_timestamp)
+ l = [m.groupdict() for m in regex.finditer(t)]
+ # On instancie les quotes grâce aux dicos qui ont déjà la bonne tronche
+ l = [Quote(**q) for q in l]
+ newquotedb = QuoteDB()
+ newquotedb.quotelist = l
+ return newquotedb