X-Git-Url: https://git.mdrn.pl/librarian.git/blobdiff_plain/e868b7e6511dfbb89e5a9dd69bbb7ef13c42620a..5175c4cb9704f442c20abffbd575fb588278b3b2:/librarian/packagers.py diff --git a/librarian/packagers.py b/librarian/packagers.py index 054f068..0dbb6e8 100644 --- a/librarian/packagers.py +++ b/librarian/packagers.py @@ -6,37 +6,40 @@ import os from copy import deepcopy from lxml import etree -from librarian import epub, pdf, DirDocProvider, ParseError, cover -from librarian.dcparser import BookInfo +from librarian import pdf, epub, DirDocProvider, ParseError, cover +from librarian.parser import WLDocument +from librarian.styles.wolnelektury.partners import cover class Packager(object): cover = None flags = None + converter = NotImplemented + ext = NotImplemented @classmethod - def prepare_file(cls, main_input, output_dir, verbose=False): + def prepare_file(cls, main_input, output_dir): path, fname = os.path.realpath(main_input).rsplit('/', 1) provider = DirDocProvider(path) slug, ext = os.path.splitext(fname) if output_dir != '': - try: + if not os.path.isdir(output_dir): os.makedirs(output_dir) - except: - pass outfile = os.path.join(output_dir, slug + '.' + cls.ext) - cls.converter.transform(provider, file_path=main_input, output_file=outfile, - cover=cls.cover, flags=cls.flags) + doc = WLDocument.from_file(main_input, provider=provider) + output_file = cls.converter.transform(doc, cover=cls.cover, flags=cls.flags) + doc.save_output_file(output_file, output_path=outfile) @classmethod def prepare(cls, input_filenames, output_dir='', verbose=False): + main_input = None try: for main_input in input_filenames: if verbose: print main_input - cls.prepare_file(main_input, output_dir, verbose) + cls.prepare_file(main_input, output_dir) except ParseError, e: print '%(file)s:%(name)s:%(message)s' % { 'file': main_input, @@ -49,6 +52,7 @@ class EpubPackager(Packager): converter = epub ext = 'epub' + class PdfPackager(Packager): converter = pdf ext = 'pdf' @@ -57,28 +61,31 @@ class PdfPackager(Packager): class GandalfEpubPackager(EpubPackager): cover = cover.GandalfCover + class GandalfPdfPackager(PdfPackager): cover = cover.GandalfCover + class BookotekaEpubPackager(EpubPackager): cover = cover.BookotekaCover + class PrestigioEpubPackager(EpubPackager): cover = cover.PrestigioCover flags = ('less-advertising',) + class PrestigioPdfPackager(PdfPackager): cover = cover.PrestigioCover flags = ('less-advertising',) -class VirtualoEpubPackager(Packager): +class VirtualoPackager(Packager): @staticmethod def utf_trunc(text, limit): """ truncates text to at most `limit' bytes in utf-8 """ if text is None: return text - orig_text = text if len(text.encode('utf-8')) > limit: newlimit = limit - 3 while len(text.encode('utf-8')) > newlimit: @@ -105,6 +112,7 @@ class VirtualoEpubPackager(Packager): PL """) + main_input = None try: for main_input in input_filenames: if verbose: @@ -116,7 +124,8 @@ class VirtualoEpubPackager(Packager): outfile_dir = os.path.join(output_dir, slug) os.makedirs(os.path.join(output_dir, slug)) - info = BookInfo.from_file(main_input) + doc = WLDocument.from_file(main_input, provider=provider) + info = doc.book_info product_elem = deepcopy(product) product_elem[0].text = cls.utf_trunc(slug, 100) @@ -127,14 +136,16 @@ class VirtualoEpubPackager(Packager): product_elem[4][0][1].text = cls.utf_trunc(info.author.last_name, 100) xml.append(product_elem) - cover.VirtualoCover( - u' '.join(info.author.first_names + (info.author.last_name,)), - info.title - ).save(os.path.join(outfile_dir, slug+'.jpg')) + cover.VirtualoCover(info).save(os.path.join(outfile_dir, slug+'.jpg')) outfile = os.path.join(outfile_dir, '1.epub') outfile_sample = os.path.join(outfile_dir, '1.sample.epub') - epub.transform(provider, file_path=main_input, output_file=outfile) - epub.transform(provider, file_path=main_input, output_file=outfile_sample, sample=25) + doc.save_output_file(doc.as_epub(), output_path=outfile) + doc.save_output_file(doc.as_epub(doc, sample=25), output_path=outfile_sample) + outfile = os.path.join(outfile_dir, '1.mobi') + outfile_sample = os.path.join(outfile_dir, '1.sample.mobi') + doc.save_output_file(doc.as_mobi(cover=cover.VirtualoCover), output_path=outfile) + doc.save_output_file( + doc.as_mobi(doc, cover=cover.VirtualoCover, sample=25), output_path=outfile_sample) except ParseError, e: print '%(file)s:%(name)s:%(message)s' % { 'file': main_input,