- # if output to dir, create the file
- if output_dir is not None:
- if make_dir:
- author = unicode(book_info.author)
- output_dir = os.path.join(output_dir, author)
- try:
- os.makedirs(output_dir)
- except OSError:
- pass
- if slug:
- output_file = os.path.join(output_dir, '%s.mobi' % slug)
- else:
- output_file = os.path.join(output_dir, os.path.splitext(os.path.basename(file_path))[0] + '.mobi')
-
- epub_file = NamedTemporaryFile(suffix='.epub', delete=False)
- if not flags:
- flags = []
- flags = list(flags) + ['without-fonts']
- epub.transform(provider, file_path=file_path, output_file=epub_file, verbose=verbose,
- sample=sample, cover=None, flags=flags, style=get_resource('mobi/style.css'))
- subprocess.check_call(['ebook-convert', epub_file.name, output_file])
- os.unlink(epub_file.name)
+ document = deepcopy(wldoc)
+ del wldoc
+
+ epub = document.as_epub(verbose=verbose, sample=sample,
+ html_toc=True, cover=cover or True, flags=flags,
+ hyphenate=hyphenate, ilustr_path=ilustr_path, output_type='mobi')
+ if verbose:
+ kwargs = {}
+ else:
+ devnull = open("/dev/null", 'w')
+ kwargs = {"stdout": devnull, "stderr": devnull}
+
+ output_file = NamedTemporaryFile(prefix='librarian', suffix='.mobi',
+ delete=False)
+ output_file.close()
+
+ if use_kindlegen:
+ output_file_basename = os.path.basename(output_file.name)
+ subprocess.check_call(['kindlegen', '-c2', epub.get_filename(),
+ '-o', output_file_basename], **kwargs)
+ else:
+ subprocess.check_call(['ebook-convert', epub.get_filename(),
+ output_file.name, '--no-inline-toc',
+ '--mobi-file-type=both',
+ '--mobi-ignore-margins'], **kwargs)
+ return OutputFile.from_filename(output_file.name)