]>
gitweb.pimeys.fr Git - today.git/blob - gather.py
2 # -*- encoding: utf-8 -*-
4 """ Module chargé de récupérer les nouvelles choses là où il faut et de fournir
5 le dico des derniers numéros.
7 * Une "nouvelle chose" doit fournir l'interface suivante :
8 une fonction qui s'appelle sans argument et renvoie un entier, le dernier id
9 * On peut avoir envie d'importer un module et de récupérer module.functions
10 un dictionnaire id → fonctions.
18 #: Gestion des chaînes youtube
22 def generate_errmsg(id):
23 errmsg
= "Erreur à la récupération de %s :\n" % id
24 errmsg
+= traceback
.format_exc()
25 # On dumpe le contenu local de la mémoire au moment de l'exception
26 fobj
= inspect
.trace()[-1][0]
27 # On fait un peu de ménage
28 d
= {k
:v
for (k
,v
) in fobj
.f_locals
.iteritems() if not k
.startswith("_")}
29 # On évite d'envoyer truckLoadsOfShit
30 d
= {k
: (v
if len(str(v
)) < 800
31 else str(v
)[:400] + "*" * 40 + "TRUNCATED OBJECT" + "*" * 40 + str(v
)[-400:])
32 for (k
,v
) in d
.iteritems()}
33 errmsg
+= "\nContexte : %s\n\n" % (pprint
.pformat(d
))
36 def get_storer(key_id
, parser
):
38 """ Encapsuleur. Renvoie une fonction qui, une fois appelée, stockera le résultat
39 de ``parser()`` dans ``results[key_id]``, ``results`` étant global. """
41 # On prend soin de ne pas crasher
43 results
[key_id
] = parser()
44 except Exception as e
:
45 # et d'afficher du debugging en cas de problème
46 print generate_errmsg(key_id
)
52 functions
.update(youtube
.functions
)
54 # On convertit les fonctions en storers
55 functions
= {id : get_storer(id, parser
) for (id, parser
) in functions
.items()}
59 for (id, f
) in functions
.items():
60 newthread
= threading
.Thread(name
="retrieving-%s" % id, target
= f
)
62 threads
.append(newthread
)
64 # On attend que tout le monde ait renvoyé son résultat
65 [t
.join() for t
in threads
]
69 if __name__
== "__main__":