X-Git-Url: https://git.phdru.name/?a=blobdiff_plain;f=m_librarian%2Fglst.py;h=2de36c3a92180b7abaf1b7b76079e51938e93c06;hb=9686bc5fd9b73a6f43a7753afd172a5fe5b9501a;hp=cd2b8c90f33a7235c86d7dc9e12887253f07e95f;hpb=711b094b0eb5a6804fceffe72c4d8c700d789cf2;p=m_librarian.git diff --git a/m_librarian/glst.py b/m_librarian/glst.py index cd2b8c9..2de36c3 100755 --- a/m_librarian/glst.py +++ b/m_librarian/glst.py @@ -1,5 +1,7 @@ #! /usr/bin/env python +__all__ = ['import_glst'] + import codecs import os from sqlobject import sqlhub, SQLObjectNotFound @@ -8,7 +10,6 @@ from .db import Genre 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() @@ -21,10 +22,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): @@ -40,20 +40,25 @@ def import_glst_file(glst_filename): return old, new -def _import_data(): +def _import_glst(): ml_dir = os.path.dirname(__file__) old_fb2, new_fb2 = import_glst_file( - os.path.join(ml_dir, 'data', 'genres_fb2.glst')) + os.path.join(ml_dir, 'glst', 'genres_fb2.glst')) old_nonfb2, new_nonfb2 = import_glst_file( - os.path.join(ml_dir, 'data', 'genres_nonfb2.glst')) - sqlhub.processConnection.query("VACUUM %s" % Genre.sqlmeta.table) + os.path.join(ml_dir, 'glst', 'genres_nonfb2.glst')) + connection = sqlhub.processConnection + if connection.dbName in ('postgres', 'sqlite'): + connection.query("VACUUM %s" % Genre.sqlmeta.table) return old_fb2 + old_nonfb2, new_fb2 + new_nonfb2 -def import_data(): - return sqlhub.doInTransaction(_import_data) +def import_glst(): + return sqlhub.doInTransaction(_import_glst) -if __name__ == '__main__': +def test(): ml_dir = os.path.dirname(__file__) - print parse_glst_file(os.path.join(ml_dir, 'data', 'genres_fb2.glst')) + print parse_glst_file(os.path.join(ml_dir, 'glst', 'genres_fb2.glst')) + +if __name__ == '__main__': + test()