from lxml.etree import XMLSyntaxError, XSLTApplyError
functions.reg_substitute_entities()
+functions.reg_person_name()
STYLESHEETS = {
'legacy': 'xslt/book2html.xslt',
return etree.ETXPath('//p|//{%(ns)s}p|//h1|//{%(ns)s}h1' % {'ns': str(XHTMLNS)})(text)
def transform(input, output_filename=None, is_file=True, \
- parse_dublincore=True, stylesheet='legacy', options={}):
+ parse_dublincore=True, stylesheet='legacy', options={}, flags=None):
"""Transforms file input_filename in XML to output_filename in XHTML.
If output_filename is None, returns an XML,
document = WLDocument.from_string(input, True, \
parse_dublincore=parse_dublincore)
+ if flags:
+ for flag in flags:
+ document.edoc.getroot().set(flag, 'yes')
+
document.clean_ed_note()
result = document.transform(style, **options)
add_table_of_contents(result.getroot())
if output_filename is not None:
- result.write(output_filename, xml_declaration=False, pretty_print=True, encoding='utf-8')
+ result.write(output_filename, method='html', xml_declaration=False, pretty_print=True, encoding='utf-8')
else:
return result
return True
open_fragments = {}
closed_fragments = {}
- for event, element in etree.iterparse(input_filename, events=('start', 'end')):
+ # iterparse would die on a HTML document
+ parser = etree.HTMLParser(encoding='utf-8')
+ buf = cStringIO.StringIO()
+ buf.write(etree.tostring(etree.parse(input_filename, parser).getroot()[0][0], encoding='utf-8'))
+ buf.seek(0)
+
+ for event, element in etree.iterparse(buf, events=('start', 'end')):
# Process begin and end elements
if element.get('class', '') in ('theme-begin', 'theme-end'):
if not event == 'end': continue # Process elements only once, on end event
root.insert(0, toc)
+
+def extract_annotations(html_path):
+ """For each annotation, yields a tuple: anchor, text, html."""
+ parser = etree.HTMLParser(encoding='utf-8')
+ tree = etree.parse(html_path, parser)
+ footnotes = tree.find('//*[@id="footnotes"]')
+ if footnotes is not None:
+ for footnote in footnotes.findall('div'):
+ anchor = footnote.find('a[@name]').get('name')
+ del footnote[:2]
+ text_str = etree.tostring(footnote, method='text', encoding='utf-8').strip()
+ html_str = etree.tostring(footnote, method='html', encoding='utf-8')
+ yield anchor, text_str, html_str
+