X-Git-Url: https://git.mdrn.pl/librarian.git/blobdiff_plain/387bff61a13e750e1ef4e015025415a8b311b25b..57dc61cf3e34d3acd054383842be40b974e2e2cf:/librarian/pdf.py diff --git a/librarian/pdf.py b/librarian/pdf.py index 5f6f0a2..b3725b4 100644 --- a/librarian/pdf.py +++ b/librarian/pdf.py @@ -152,7 +152,7 @@ def package_available(package, args='', verbose=False): fpath = os.path.join(tempdir, 'test.tex') f = open(fpath, 'w') f.write(r""" - \documentclass{book} + \documentclass{wl} \usepackage[%s]{%s} \begin{document} \end{document} @@ -167,7 +167,8 @@ def package_available(package, args='', verbose=False): def transform(provider, slug=None, file_path=None, - output_file=None, output_dir=None, make_dir=False, verbose=False, save_tex=None, morefloats=None): + output_file=None, output_dir=None, make_dir=False, verbose=False, save_tex=None, morefloats=None, + cover=None, flags=None): """ produces a PDF file with XeLaTeX provider: a DocProvider @@ -179,6 +180,8 @@ def transform(provider, slug=None, file_path=None, verbose: prints all output from LaTeX save_tex: path to save the intermediary LaTeX file to morefloats (old/new/none): force specific morefloats + cover: a cover.Cover object + flags: less-advertising, """ # Parse XSLT @@ -192,6 +195,13 @@ def transform(provider, slug=None, file_path=None, raise ValueError('either slug or file_path should be specified') document = load_including_children(provider, slug=slug) + if cover: + document.edoc.getroot().set('data-cover-width', str(cover.width)) + document.edoc.getroot().set('data-cover-height', str(cover.height)) + if flags: + for flag in flags: + document.edoc.getroot().set('flag-' + flag, 'yes') + # check for LaTeX packages if morefloats: document.edoc.getroot().set('morefloats', morefloats.lower()) @@ -214,10 +224,17 @@ def transform(provider, slug=None, file_path=None, style_filename = get_stylesheet("wl2tex") style = etree.parse(style_filename) texml = document.transform(style) - del document # no longer needed large object :) # TeXML -> LaTeX temp = mkdtemp('-wl2pdf') + + if cover: + c = cover(document.book_info.author.readable(), document.book_info.title) + with open(os.path.join(temp, 'cover.png'), 'w') as f: + c.save(f) + + del document # no longer needed large object :) + tex_path = os.path.join(temp, 'doc.tex') fout = open(tex_path, 'w') process(StringIO(texml), fout, 'utf-8') @@ -228,7 +245,7 @@ def transform(provider, slug=None, file_path=None, shutil.copy(tex_path, save_tex) # LaTeX -> PDF - shutil.copy(get_resource('pdf/wl.sty'), temp) + shutil.copy(get_resource('pdf/wl.cls'), temp) shutil.copy(get_resource('res/wl-logo.png'), temp) cwd = os.getcwd()