]> git.scottworley.com Git - paperdoorknob/blobdiff - paperdoorknob.py
Use LaTeX packages: longtable and booktabs
[paperdoorknob] / paperdoorknob.py
index 84ed70228d3d9b4040fc765c3ced2be68d1d58ea..b5b7a44a433f2410d64fb12c021348fac25171b8 100644 (file)
@@ -8,7 +8,7 @@
 from bs4 import BeautifulSoup
 
 from args import spec_from_commandline_args
 from bs4 import BeautifulSoup
 
 from args import spec_from_commandline_args
-from glowfic import chunkDOMs
+from glowfic import chunkDOMs, flatURL, makeChunk
 from spec import Spec
 
 
 from spec import Spec
 
 
@@ -17,16 +17,24 @@ def parse(content: bytes) -> BeautifulSoup:
 
 
 def process(spec: Spec) -> None:
 
 
 def process(spec: Spec) -> None:
-    spec.texout.write(b'\\documentclass{article}\n')
+    spec.texout.write(b'''\\documentclass{article}
+\\usepackage{booktabs}
+\\usepackage{graphicx}
+\\usepackage{longtable}
+\\usepackage{varwidth}
+\\usepackage{wrapstuff}
+''')
     if spec.geometry is not None:
         spec.texout.write(b'\\usepackage[' +
                           spec.geometry.encode('UTF-8') +
                           b']{geometry}\n')
     spec.texout.write(b'\\begin{document}\n')
     if spec.geometry is not None:
         spec.texout.write(b'\\usepackage[' +
                           spec.geometry.encode('UTF-8') +
                           b']{geometry}\n')
     spec.texout.write(b'\\begin{document}\n')
-    html = parse(spec.htmlfilter(spec.fetcher.fetch(spec.url)))
+    url = flatURL(spec.url)
+    html = parse(spec.htmlfilter(spec.fetcher.fetch(url)))
     for r in chunkDOMs(html):
         spec.domfilter(r)
     for r in chunkDOMs(html):
         spec.domfilter(r)
-        spec.texout.write(spec.texifier.texify(r))
+        chunk = makeChunk(r, spec.images)
+        spec.texout.write(spec.layout.renderChunk(chunk))
     spec.texout.write(b'\\end{document}\n')
 
 
     spec.texout.write(b'\\end{document}\n')