X-Git-Url: https://git.mdrn.pl/librarian.git/blobdiff_plain/07fdba2c7fe8e11b6867712d47bdd608e88c29fb..bf5758493c7f22bf54ecb7d0f042d4a288d9e2fc:/scripts/book2html?ds=sidebyside diff --git a/scripts/book2html b/scripts/book2html index a0229bb..8adeb38 100755 --- a/scripts/book2html +++ b/scripts/book2html @@ -1,8 +1,14 @@ #!/usr/bin/env python +# -*- coding: utf-8 -*- +# +# This file is part of Librarian, licensed under GNU Affero GPLv3 or later. +# Copyright © Fundacja Nowoczesna Polska. See NOTICE for more information. +# import os import optparse -from librarian import html +from librarian import ParseError +from librarian.parser import WLDocument if __name__ == '__main__': @@ -14,6 +20,10 @@ if __name__ == '__main__': parser.add_option('-v', '--verbose', action='store_true', dest='verbose', default=False, help='print status messages to stdout') + parser.add_option('-i', '--ignore-dublin-core', action='store_false', dest='parse_dublincore', default=True, + help='don\'t try to parse dublin core metadata') + parser.add_option('-r', '--raw', action='store_false', dest='full_page', default=True, + help='outpu raw text for use in templates') options, input_filenames = parser.parse_args() @@ -25,7 +35,31 @@ if __name__ == '__main__': for input_filename in input_filenames: if options.verbose: print input_filename - + output_filename = os.path.splitext(input_filename)[0] + '.html' - html.transform(input_filename, output_filename) + try: + doc = WLDocument.from_file(input_filename, + parse_dublincore=options.parse_dublincore) + flags = ('full-page',) if options.full_page else None + html = doc.as_html(flags=flags) + doc.save_output_file(html, output_path=output_filename) + except ParseError, e: + print '%(file)s:%(name)s:%(message)s' % { + 'file': input_filename, + 'name': e.__class__.__name__, + 'message': e, + } + except IOError, e: + print '%(file)s:%(name)s:%(message)s' % { + 'file': input_filename, + 'name': e.__class__.__name__, + 'message': e.strerror, + } + except BaseException, e: + print '%(file)s:%(etype)s:%(message)s' % { + 'file': input_filename, + 'etype': e.__class__.__name__, + 'message': e, + } + raise