fnp
/
librarian.git
/ blobdiff
commit
grep
author
committer
pickaxe
?
search:
re
summary
|
shortlog
|
log
|
commit
|
commitdiff
|
tree
raw
|
inline
| side by side
images in epub/mobi
[librarian.git]
/
librarian
/
epub.py
diff --git
a/librarian/epub.py
b/librarian/epub.py
index
6a1b2ce
..
3b405f8
100644
(file)
--- a/
librarian/epub.py
+++ b/
librarian/epub.py
@@
-51,19
+51,21
@@
def set_hyph_language(source_tree):
def hyphenate_and_fix_conjunctions(source_tree, hyph):
def hyphenate_and_fix_conjunctions(source_tree, hyph):
- if hyph is not None:
- texts = etree.XPath('/utwor/*[2]//text()')(source_tree)
- for t in texts:
- parent = t.getparent()
+ texts = etree.XPath('/utwor/*[2]//text()')(source_tree)
+ for t in texts:
+ parent = t.getparent()
+ if hyph is not None:
newt = ''
wlist = re.compile(r'\w+|[^\w]', re.UNICODE).findall(t)
for w in wlist:
newt += hyph.inserted(w, u'\u00AD')
newt = ''
wlist = re.compile(r'\w+|[^\w]', re.UNICODE).findall(t)
for w in wlist:
newt += hyph.inserted(w, u'\u00AD')
- newt = re.sub(r'(?<=\s\w)\s+', u'\u00A0', newt)
- if t.is_text:
- parent.text = newt
- elif t.is_tail:
- parent.tail = newt
+ else:
+ newt = t
+ newt = re.sub(r'(?<=\s\w)\s+', u'\u00A0', newt)
+ if t.is_text:
+ parent.text = newt
+ elif t.is_tail:
+ parent.tail = newt
def inner_xml(node):
def inner_xml(node):
@@
-404,9
+406,8
@@
def transform_chunk(chunk_xml, chunk_no, annotations, empty=False, _empty_html_s
return output_html, toc, chars
return output_html, toc, chars
-def transform(wldoc, verbose=False,
- style=None, html_toc=False,
- sample=None, cover=None, flags=None):
+def transform(wldoc, verbose=False, style=None, html_toc=False,
+ sample=None, cover=None, flags=None, hyphenate=False, ilustr_path=''):
""" produces a EPUB file
sample=n: generate sample e-book (with at least n paragraphs)
""" produces a EPUB file
sample=n: generate sample e-book (with at least n paragraphs)
@@
-419,7
+420,7
@@
def transform(wldoc, verbose=False,
replace_characters(wldoc.edoc.getroot())
replace_characters(wldoc.edoc.getroot())
- hyphenator = set_hyph_language(wldoc.edoc.getroot())
+ hyphenator = set_hyph_language(wldoc.edoc.getroot())
if hyphenate else None
hyphenate_and_fix_conjunctions(wldoc.edoc.getroot(), hyphenator)
# every input file will have a TOC entry,
hyphenate_and_fix_conjunctions(wldoc.edoc.getroot(), hyphenator)
# every input file will have a TOC entry,
@@
-525,6
+526,9
@@
def transform(wldoc, verbose=False,
functions.reg_mathml_epub(zip)
functions.reg_mathml_epub(zip)
+ for filename in os.listdir(ilustr_path):
+ zip.write(os.path.join(ilustr_path, filename), os.path.join('OPS', filename))
+
# write static elements
mime = zipfile.ZipInfo()
mime.filename = 'mimetype'
# write static elements
mime = zipfile.ZipInfo()
mime.filename = 'mimetype'
@@
-646,7
+650,7
@@
def transform(wldoc, verbose=False,
'"http://www.w3.org/TR/xhtml11/DTD/xhtml11.dtd">'
))
'"http://www.w3.org/TR/xhtml11/DTD/xhtml11.dtd">'
))
- if not flags or
not 'without-fonts'
in flags:
+ if not flags or
'without-fonts' not
in flags:
# strip fonts
tmpdir = mkdtemp('-librarian-epub')
try:
# strip fonts
tmpdir = mkdtemp('-librarian-epub')
try: