X-Git-Url: https://git.phdru.name/?a=blobdiff_plain;f=m_librarian%2Fglst.py;h=5864d7f9687ab4a318b4d39ad20e1d72d7a1a7f3;hb=d288a27d443f38f8661acd59c8ed900e43141d00;hp=44ec6121cbeaf6038730f3a5f9c17abf0a99a0d4;hpb=d0a1abea3d89062e8f9b71dd6df45db5d8b84997;p=m_librarian.git diff --git a/m_librarian/glst.py b/m_librarian/glst.py index 44ec612..5864d7f 100755 --- a/m_librarian/glst.py +++ b/m_librarian/glst.py @@ -1,16 +1,16 @@ #! /usr/bin/env python -__all__ = ['import_glst'] - +from __future__ import print_function import codecs import os from sqlobject import sqlhub, SQLObjectNotFound from .db import Genre +__all__ = ['import_glst'] + def parse_glst_file(glst_filename): glst_file = codecs.open(glst_filename, 'r', 'utf-8') - genre_list = [] try: for line in glst_file: line = line.strip() @@ -23,10 +23,9 @@ def parse_glst_file(glst_filename): name, title = parts[1].split(';', 1) except (IndexError, ValueError): continue - genre_list.append((name, title)) + yield name, title finally: glst_file.close() - return genre_list def import_glst_file(glst_filename): @@ -48,17 +47,23 @@ def _import_glst(): 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')) - sqlhub.processConnection.query("VACUUM %s" % Genre.sqlmeta.table) + connection = sqlhub.processConnection + if connection.dbName == 'postgres': + connection.query("VACUUM %s" % Genre.sqlmeta.table) return old_fb2 + old_nonfb2, new_fb2 + new_nonfb2 def import_glst(): return sqlhub.doInTransaction(_import_glst) + connection = sqlhub.processConnection + if connection.dbName == 'sqlite': + connection.query("VACUUM") def test(): ml_dir = os.path.dirname(__file__) - print parse_glst_file(os.path.join(ml_dir, 'glst', 'genres_fb2.glst')) + print(parse_glst_file(os.path.join(ml_dir, 'glst', 'genres_fb2.glst'))) + if __name__ == '__main__': test()