fnp
/
librarian.git
/ blobdiff
commit
grep
author
committer
pickaxe
?
search:
re
summary
|
shortlog
|
log
|
commit
|
commitdiff
|
tree
raw
|
inline
| side by side
Merge branch 'master' into commerce
[librarian.git]
/
librarian
/
packagers.py
diff --git
a/librarian/packagers.py
b/librarian/packagers.py
index
285a15f
..
9a93e56
100644
(file)
--- a/
librarian/packagers.py
+++ b/
librarian/packagers.py
@@
-6,8
+6,8
@@
import os
from copy import deepcopy
from lxml import etree
import os
from copy import deepcopy
from lxml import etree
-from librarian import
epub, pdf
, DirDocProvider, ParseError, cover
-from librarian.
dcparser import BookInfo
+from librarian import
pdf, epub
, DirDocProvider, ParseError, cover
+from librarian.
parser import WLDocument
class Packager(object):
class Packager(object):
@@
-26,8
+26,11
@@
class Packager(object):
except:
pass
outfile = os.path.join(output_dir, slug + '.' + cls.ext)
except:
pass
outfile = os.path.join(output_dir, slug + '.' + cls.ext)
- cls.converter.transform(provider, file_path=main_input, output_file=outfile,
+
+ doc = WLDocument.from_file(main_input, provider=provider)
+ output_file = cls.converter.transform(doc,
cover=cls.cover, flags=cls.flags)
cover=cls.cover, flags=cls.flags)
+ doc.save_output_file(output_file, output_path=outfile)
@classmethod
@classmethod
@@
-57,6
+60,15
@@
class PdfPackager(Packager):
class GandalfEpubPackager(EpubPackager):
cover = cover.GandalfCover
class GandalfEpubPackager(EpubPackager):
cover = cover.GandalfCover
+class GandalfPdfPackager(PdfPackager):
+ cover = cover.GandalfCover
+
+class ArtaTechEpubPackager(EpubPackager):
+ cover = cover.ArtaTechCover
+
+class ArtaTechPdfPackager(PdfPackager):
+ cover = cover.ArtaTechCover
+
class BookotekaEpubPackager(EpubPackager):
cover = cover.BookotekaCover
class BookotekaEpubPackager(EpubPackager):
cover = cover.BookotekaCover
@@
-75,7
+87,6
@@
class VirtualoEpubPackager(Packager):
""" truncates text to at most `limit' bytes in utf-8 """
if text is None:
return text
""" truncates text to at most `limit' bytes in utf-8 """
if text is None:
return text
- orig_text = text
if len(text.encode('utf-8')) > limit:
newlimit = limit - 3
while len(text.encode('utf-8')) > newlimit:
if len(text.encode('utf-8')) > limit:
newlimit = limit - 3
while len(text.encode('utf-8')) > newlimit:
@@
-113,7
+124,8
@@
class VirtualoEpubPackager(Packager):
outfile_dir = os.path.join(output_dir, slug)
os.makedirs(os.path.join(output_dir, slug))
outfile_dir = os.path.join(output_dir, slug)
os.makedirs(os.path.join(output_dir, slug))
- info = BookInfo.from_file(main_input)
+ doc = WLDocument.from_file(main_input, provider=provider)
+ info = doc.book_info
product_elem = deepcopy(product)
product_elem[0].text = cls.utf_trunc(slug, 100)
product_elem = deepcopy(product)
product_elem[0].text = cls.utf_trunc(slug, 100)
@@
-124,14
+136,13
@@
class VirtualoEpubPackager(Packager):
product_elem[4][0][1].text = cls.utf_trunc(info.author.last_name, 100)
xml.append(product_elem)
product_elem[4][0][1].text = cls.utf_trunc(info.author.last_name, 100)
xml.append(product_elem)
- cover.VirtualoCover(
- u' '.join(info.author.first_names + (info.author.last_name,)),
- info.title
- ).save(os.path.join(outfile_dir, slug+'.jpg'))
+ cover.VirtualoCover(info).save(os.path.join(outfile_dir, slug+'.jpg'))
outfile = os.path.join(outfile_dir, '1.epub')
outfile_sample = os.path.join(outfile_dir, '1.sample.epub')
outfile = os.path.join(outfile_dir, '1.epub')
outfile_sample = os.path.join(outfile_dir, '1.sample.epub')
- epub.transform(provider, file_path=main_input, output_file=outfile)
- epub.transform(provider, file_path=main_input, output_file=outfile_sample, sample=25)
+ doc.save_output_file(epub.transform(doc),
+ output_path=outfile)
+ doc.save_output_file(epub.transform(doc, sample=25),
+ output_path=outfile_sample)
except ParseError, e:
print '%(file)s:%(name)s:%(message)s' % {
'file': main_input,
except ParseError, e:
print '%(file)s:%(name)s:%(message)s' % {
'file': main_input,