DeDRM_tools/Topaz_Tools/lib
2015-02-28 12:18:57 +00:00
..
changes.txt topazscripts 1.7 2015-02-28 12:16:04 +00:00
cmbtc_dump.py topaz tools 1.0 (I think) 2015-02-28 12:11:14 +00:00
cmbtc_dump_nonK4PC.py name change 2015-02-28 12:18:57 +00:00
cmbtc_v2.2.py Name change 2015-02-28 12:08:10 +00:00
convert2xml.py topazscripts 1.7 2015-02-28 12:16:04 +00:00
decode_meta.py topaz tools 1.0 (I think) 2015-02-28 12:11:14 +00:00
flatxml2html.py topazscripts 1.7 2015-02-28 12:16:04 +00:00
genhtml.py topazscripts 1.7 2015-02-28 12:16:04 +00:00
gensvg.py topazscripts 1.7 2015-02-28 12:16:04 +00:00
genxml.py topaz tools 1.0 (I think) 2015-02-28 12:11:14 +00:00
getpagedim.py topazscripts 1.5 2015-02-28 12:13:49 +00:00
readme.txt topazscripts 1.7 2015-02-28 12:16:04 +00:00
stylexml2css.py topazscripts 1.5 2015-02-28 12:13:49 +00:00

Contributors:
     cmbtc - removal of drm which made all of this possible
     clarknova - for all of the svg and glyph generation and many other bug fixes and improvements
     skindle - for figuing out the general case for the mode loops
     some updates -  for conversion to xml, basic html
     DiapDealer - for extensive testing and feedback, and standalone linux/macosx version of cmbtc_dump
     stewball - for extensive testing and feedback

and many others for posting, feedback and testing
  

This is experimental and it will probably not work for you but...

ALSO:  Please do not use any of this to steal.  Theft is wrong. 
       This is meant to allow conversion of Topaz books for other book readers you own

Here are the steps:

1. Unzip the topazscripts.zip file to get the full set of python scripts.
The files you should have after unzipping are:

cmbtc_dump.py - (author: cmbtc) unencrypts and dumps sections into separate files
decode_meta.py - converts metadata0000.dat to human readable text (for the most part)
convert2xml.py - converts page*.dat, other*.dat, and glyphs*.dat files to pseudo xml descriptions
flatxml2html.py - converts a "flattened" xml description to html using the ocrtext
stylexml2css.py - converts stylesheet "flattened" xml into css (as best it can)
getpagedim.py - reads page0000.dat to get the book height and width parameters
genxml.py - main program to convert everything to xml
genhtml.py - main program to generate "book.html"
gensvg.py - (author: clarknova) main program to create an svg grpahic of each page


In addition there is now a new file:

cmbtc_dump_mac_linux.py  

If you know the pid of your ipod and/or your standalone Kindle and your book
was meant for that device, you can use this program to dump the proper sections
on Mac OSX and Linux (and even Windows if you do not have Kindle4PC installed).
Thank DiapDealer for creating it!


Please note, gensvg.py, genhtml.py, and genxml.py import and use
decode_meta.py, convert2xml.py, flatxml2html.py, getpagedim.py and stylexml2css.py 
so please keep all of these python scripts together in the same place.



2. Remove the DRM from the Topaz book and build a directory 
of its contents as files

All Thanks go to CMBTC who broke the DRM for Topaz - without it nothing else 
would be possible

   cmbtc_dump.py -d -o TARGETDIR [-p pid] YOURTOPAZBOOKNAMEHERE

This should create a directory called "TARGETDIR" in your current directory.  
It should have the following files in it:

metadata0000.dat - metadata info
other0000.dat - information used to create a style sheet
dict0000.dat - dictionary of words used to build page descriptions
page - directory filled with page*.dat files
glyphs - directory filled with glyphs*.dat files



3. Convert the files in "TARGETDIR" to their xml descriptions
which can be found in TARGETDIR/xml/ upon completion.

   genxml.py TARGETDIR



4. Create book.html which can be found in "TARGETDIR" after 
completion.  This html conversion can not fully capture 
all of the layouts actually used in the book and needs to 
be edited to include special font handling such as bold 
or italics that can not be determined from the ocrText
information or the style information.  If you want to 
see things exactly as they were, see step 5 below.

   genhtml.py TARGETDIR



5. Create an svg description of each page which can
be found in TARGETDIR/svg/ upon completion.

All thanks go to CLARKNOVA for this program.  This program is 
needed to actually see the true image of each page so that hand
editing of the html created by step 4 can be done.  

Or use the resulting svg files to read each page of the book
exactly as it has been laid out originally.

   gensvg.py TARGETDIR