]> git.scottworley.com Git - paperdoorknob/blobdiff - paperdoorknob.py
Support strikethrough
[paperdoorknob] / paperdoorknob.py
index f8b336194974668477b5739b74c014a00d7e7549..0da6d97c8626938e29c407dd507467897994c9ea 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, makeChunk
+from glowfic import chunkDOMs, flatURL, makeChunk
 from spec import Spec
 
 
 from spec import Spec
 
 
@@ -18,19 +18,24 @@ def parse(content: bytes) -> BeautifulSoup:
 
 def process(spec: Spec) -> None:
     spec.texout.write(b'''\\documentclass{article}
 
 def process(spec: Spec) -> None:
     spec.texout.write(b'''\\documentclass{article}
+\\usepackage{booktabs}
 \\usepackage{graphicx}
 \\usepackage{graphicx}
-\\usepackage{wrapfig}
+\\usepackage{longtable}
+\\usepackage{soul}
+\\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)
         chunk = makeChunk(r, spec.images)
     for r in chunkDOMs(html):
         spec.domfilter(r)
         chunk = makeChunk(r, spec.images)
-        spec.texout.write(spec.layout.renderChunk(chunk))
+        spec.texout.write(spec.texfilter(spec.layout.renderChunk(chunk)))
     spec.texout.write(b'\\end{document}\n')
 
 
     spec.texout.write(b'\\end{document}\n')