]> git.phdru.name Git - m_librarian.git/blobdiff - m_librarian/glst.py
Docs: Update TODO
[m_librarian.git] / m_librarian / glst.py
index 6b2e0904157870d2de8c52298e31a64b736c3a0a..206dcc40f858a306524ef07e1d2ec68b02269cc7 100755 (executable)
@@ -1,8 +1,10 @@
 #! /usr/bin/env python
 
 from __future__ import print_function
+from glob import glob
 import codecs
 import os
+
 from sqlobject import sqlhub, SQLObjectNotFound
 from .db import Genre
 
@@ -43,14 +45,15 @@ def import_glst_file(glst_filename):
 
 def _import_glst():
     ml_dir = os.path.dirname(__file__)
-    old_fb2, new_fb2 = import_glst_file(
-        os.path.join(ml_dir, 'glst', 'genres_fb2.glst'))
-    old_nonfb2, new_nonfb2 = import_glst_file(
-        os.path.join(ml_dir, 'glst', 'genres_nonfb2.glst'))
+    count_old = count_new = 0
+    for glst_file in glob(os.path.join(ml_dir, 'glst', '*.glst')):
+        _count_old, _count_new = import_glst_file(glst_file)
+        count_old += _count_old
+        count_new += _count_new
     connection = sqlhub.processConnection
     if connection.dbName == 'postgres':
         connection.query("VACUUM %s" % Genre.sqlmeta.table)
-    return old_fb2 + old_nonfb2, new_fb2 + new_nonfb2
+    return count_old, count_new
 
 
 def import_glst():
@@ -63,7 +66,13 @@ def import_glst():
 
 def test():
     ml_dir = os.path.dirname(__file__)
-    print(parse_glst_file(os.path.join(ml_dir, 'glst', 'genres_fb2.glst')))
+    for i, (name, title) in enumerate(parse_glst_file(
+        os.path.join(ml_dir, 'glst', 'genres_fb2_flibusta.glst')
+    )):
+        if i < 5:
+            print(name, title)
+        else:
+            break
 
 
 if __name__ == '__main__':