X-Git-Url: https://git.mdrn.pl/librarian.git/blobdiff_plain/0b32c81b837233ea59fdd1b5f19edc935f7b626d..f4cbb15b0bcd2b876872983238a1656fbd990700:/librarian/pdf.py diff --git a/librarian/pdf.py b/librarian/pdf.py index eb3f942..5df8dad 100644 --- a/librarian/pdf.py +++ b/librarian/pdf.py @@ -30,6 +30,7 @@ from librarian import ParseError, DCNS, get_resource, OutputFile from librarian import functions from librarian.cover import WLCover +import itertools, operator functions.reg_substitute_entities() functions.reg_strip() @@ -95,6 +96,29 @@ def fix_hanging(doc): exclude=[DCNS("identifier.url"), DCNS("rights.license")] ) +def fake_tables(doc): + for tabela in doc.findall("//tabela"): + # are we dealing with a table of proper structure? + # two levels of same tags, and all tags on second level + # must be of same count. + def tag_count(m, k): + m[k.tag] = m.get(k.tag, 0) + 1 + return m + + child_tags = reduce(tag_count, list(tabela), {}) + if len(child_tags) != 1: + return + grandchild_tags = reduce(tag_count, itertools.chain(*[list(c) for c in tabela]), {}) + if len(grandchild_tags) != 1: + return + if len(set(grandchild_tags.values())) != 1: + return + + for row in tabela: + row.tag = 'r' + for col in row: + col.tag = 'c' + return def move_motifs_inside(doc): """ moves motifs to be into block elements """ @@ -185,7 +209,7 @@ def package_available(package, args='', verbose=False): def transform(wldoc, verbose=False, save_tex=None, save_texml=None, morefloats=None, - cover=None, flags=None, customizations=None, documentclass='wl', resources=None): + cover=None, cover_file=None, flags=None, customizations=None, documentclass='wl', resources=None, tworuns=False): """ produces a PDF file with XeLaTeX wldoc: a WLDocument @@ -241,6 +265,7 @@ def transform(wldoc, verbose=False, save_tex=None, save_texml=None, morefloats=N # hack the tree move_motifs_inside(document.edoc) hack_motifs(document.edoc) + fake_tables(document.edoc) parse_creator(document.edoc) substitute_hyphens(document.edoc) fix_hanging(document.edoc) @@ -275,6 +300,7 @@ def transform(wldoc, verbose=False, save_tex=None, save_texml=None, morefloats=N # LaTeX -> PDF shutil.copy(get_resource('pdf/wl.cls'), temp) shutil.copy(get_resource('pdf/wlpub.cls'), temp) + shutil.copy(get_resource('pdf/fnprep.cls'), temp) shutil.copy(get_resource('res/wl-logo.png'), temp) shutil.copy(get_resource('res/cover.jpg'), temp) if resources: @@ -286,12 +312,16 @@ def transform(wldoc, verbose=False, save_tex=None, save_texml=None, morefloats=N cwd = None os.chdir(temp) - if verbose: - p = call(['xelatex', tex_path]) - else: - p = call(['xelatex', '-interaction=batchmode', tex_path], stdout=PIPE, stderr=PIPE) - if p: - raise ParseError("Error parsing .tex file") + if resources: + os.putenv("TEXINPUTS", "::.:%s" % resources) + + for run in range(1 + (tworuns and 1 or 0)): + if verbose: + p = call(['xelatex', tex_path]) + else: + p = call(['xelatex', '-interaction=batchmode', tex_path], stdout=PIPE, stderr=PIPE) + if p: + raise ParseError("Error parsing .tex file") if cwd is not None: os.chdir(cwd)