noDRM_DeDRM_tools/Topaz_Tools/lib/genhtml.py

186 lines
5.3 KiB
Python
Raw Normal View History

2010-01-17 13:10:35 +01:00
#! /usr/bin/python
# vim:ts=4:sw=4:softtabstop=4:smarttab:expandtab
# For use with Topaz Scripts Version 2.2
2010-01-17 13:10:35 +01:00
class Unbuffered:
def __init__(self, stream):
self.stream = stream
def write(self, data):
self.stream.write(data)
self.stream.flush()
def __getattr__(self, attr):
return getattr(self.stream, attr)
import sys
sys.stdout=Unbuffered(sys.stdout)
import os, getopt
2010-01-17 13:10:35 +01:00
# local routines
import convert2xml
import flatxml2html
import decode_meta
import stylexml2css
2010-01-20 13:13:31 +01:00
import getpagedim
2010-01-17 13:10:35 +01:00
def usage():
print 'Usage: '
print ' '
2009-01-27 13:20:37 +01:00
print ' genhtml.py [--fixed-image] unencryptedBookDir'
print ' '
print ' Options: '
print ' --fixed-image : force translation of fixed regions into svg images '
2010-01-17 13:10:35 +01:00
print ' '
def main(argv):
bookDir = ''
2009-01-27 13:20:37 +01:00
fixedimage = False
2010-01-17 13:10:35 +01:00
if len(argv) == 0:
argv = sys.argv
try:
2009-01-27 13:20:37 +01:00
opts, args = getopt.getopt(argv[1:], "h:",["fixed-image"])
2010-01-17 13:10:35 +01:00
except getopt.GetoptError, err:
print str(err)
usage()
sys.exit(1)
2010-01-17 13:10:35 +01:00
if len(opts) == 0 and len(args) == 0 :
usage()
sys.exit(1)
2010-01-17 13:10:35 +01:00
for o, a in opts:
if o =="-h":
usage()
sys.exit(0)
2009-01-27 13:20:37 +01:00
if o =="--fixed-image":
fixedimage = True
2010-01-17 13:10:35 +01:00
bookDir = args[0]
if not os.path.exists(bookDir) :
print "Can not find directory with unencrypted book"
sys.exit(1)
2010-01-17 13:10:35 +01:00
dictFile = os.path.join(bookDir,'dict0000.dat')
if not os.path.exists(dictFile) :
print "Can not find dict0000.dat file"
sys.exit(1)
2010-01-17 13:10:35 +01:00
pageDir = os.path.join(bookDir,'page')
if not os.path.exists(pageDir) :
print "Can not find page directory in unencrypted book"
sys.exit(1)
2010-01-17 13:10:35 +01:00
imgDir = os.path.join(bookDir,'img')
if not os.path.exists(imgDir) :
print "Can not find image directory in unencrypted book"
sys.exit(1)
2010-01-17 13:10:35 +01:00
2010-01-24 13:19:20 +01:00
svgDir = os.path.join(bookDir,'svg')
if not os.path.exists(svgDir) :
print "Can not find svg directory in unencrypted book"
print "please run gensvg.py before running genhtml.py"
sys.exit(1)
2010-01-24 13:19:20 +01:00
2010-01-17 13:10:35 +01:00
otherFile = os.path.join(bookDir,'other0000.dat')
if not os.path.exists(otherFile) :
print "Can not find other0000.dat in unencrypted book"
sys.exit(1)
2010-01-17 13:10:35 +01:00
metaFile = os.path.join(bookDir,'metadata0000.dat')
if not os.path.exists(metaFile) :
print "Can not find metadata0000.dat in unencrypted book"
sys.exit(1)
2010-01-17 13:10:35 +01:00
htmlFileName = "book.html"
2009-01-22 13:15:33 +01:00
htmlstr = '<!DOCTYPE HTML PUBLIC "-//W3C//DTD XHTML 1.0 Strict//EN" "http://www.w3.org/TR/xhtml1/DTD/xhtml1-strict.dtd">\n'
htmlstr += '<html>\n'
2010-01-17 13:10:35 +01:00
filenames = os.listdir(pageDir)
filenames = sorted(filenames)
print 'Processing ... '
htmlstr += '<head>\n'
2009-01-22 13:15:33 +01:00
htmlstr += '<meta http-equiv="content-type" content="text/html; charset=utf-8"/>\n'
2010-01-17 13:10:35 +01:00
2010-01-20 13:13:31 +01:00
# process metadata and retrieve fontSize info
2010-01-17 13:10:35 +01:00
print ' ', 'metadata0000.dat'
fname = os.path.join(bookDir,'metadata0000.dat')
xname = os.path.join(bookDir, 'metadata.txt')
metastr = decode_meta.getMetaData(fname)
file(xname, 'wb').write(metastr)
meta_array = decode_meta.getMetaArray(fname)
2009-01-22 13:15:33 +01:00
htmlstr += '<title>' + meta_array['Title'] + ' by ' + meta_array['Authors'] + '</title>\n'
2010-01-17 13:10:35 +01:00
htmlstr += '<meta name="Author" content="' + meta_array['Authors'] + '" />\n'
htmlstr += '<meta name="Title" content="' + meta_array['Title'] + '" />\n'
2010-01-19 13:11:59 +01:00
# get some scaling info from metadata to use while processing styles
fontsize = '135'
if 'fontSize' in meta_array:
fontsize = meta_array['fontSize']
2010-01-20 13:13:31 +01:00
# also get the size of a normal text page
spage = '1'
if 'firstTextPage' in meta_array:
spage = meta_array['firstTextPage']
pnum = int(spage)
# get page height and width from first text page for use in stylesheet scaling
pname = 'page%04d.dat' % (pnum + 1)
2010-01-20 13:13:31 +01:00
fname = os.path.join(pageDir,pname)
pargv=[]
pargv.append('convert2xml.py')
pargv.append('--flat-xml')
pargv.append(dictFile)
pargv.append(fname)
flat_xml = convert2xml.main(pargv)
2010-01-20 13:13:31 +01:00
(ph, pw) = getpagedim.getPageDim(flat_xml)
if (ph == '-1') or (ph == '0') : ph = '11000'
if (pw == '-1') or (pw == '0') : pw = '8500'
2010-01-20 13:13:31 +01:00
# now build up the style sheet
2010-01-17 13:10:35 +01:00
print ' ', 'other0000.dat'
fname = os.path.join(bookDir,'other0000.dat')
xname = os.path.join(bookDir, 'style.css')
pargv=[]
pargv.append('convert2xml.py')
pargv.append('--flat-xml')
pargv.append(dictFile)
pargv.append(fname)
xmlstr = convert2xml.main(pargv)
2010-01-20 13:13:31 +01:00
cssstr , classlst = stylexml2css.convert2CSS(xmlstr, fontsize, ph, pw)
2010-01-17 13:10:35 +01:00
file(xname, 'wb').write(cssstr)
2009-01-22 13:15:33 +01:00
htmlstr += '<link href="style.css" rel="stylesheet" type="text/css" />\n'
2010-01-17 13:10:35 +01:00
htmlstr += '</head>\n<body>\n'
for filename in filenames:
print ' ', filename
fname = os.path.join(pageDir,filename)
pargv=[]
pargv.append('convert2xml.py')
pargv.append('--flat-xml')
pargv.append(dictFile)
pargv.append(fname)
flat_xml = convert2xml.main(pargv)
2009-01-27 13:20:37 +01:00
htmlstr += flatxml2html.convert2HTML(flat_xml, classlst, fname, bookDir, fixedimage)
2010-01-17 13:10:35 +01:00
htmlstr += '</body>\n</html>\n'
file(os.path.join(bookDir, htmlFileName), 'wb').write(htmlstr)
print 'Processing Complete'
return 0
if __name__ == '__main__':
sys.exit(main(''))