X-Git-Url: https://git.mdrn.pl/librarian.git/blobdiff_plain/3a70fb37a8784ea703eb23d8b19b90bfd00f13bc..1428a9d8f91b754fe7f9fb96cbdd0d6a2536ffc1:/scripts/book2html diff --git a/scripts/book2html b/scripts/book2html index 8adeb38..6c1e1c6 100755 --- a/scripts/book2html +++ b/scripts/book2html @@ -4,62 +4,19 @@ # 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.book2anything import Book2Anything, Option +from librarian.formats.html import HtmlFormat -from librarian import ParseError -from librarian.parser import WLDocument +class Book2Html(Book2Anything): + format_cls = HtmlFormat -if __name__ == '__main__': - # Parse commandline arguments - usage = """Usage: %prog [options] SOURCE [SOURCE...] - Convert SOURCE files to HTML format.""" - - parser = optparse.OptionParser(usage=usage) - - 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() + format_options = [ + Option('-r', '--raw', dest='standalone', + action='store_false', default=True, + help='output raw text for use in templates') + ] - if len(input_filenames) < 1: - parser.print_help() - exit(1) - - # Do some real work - for input_filename in input_filenames: - if options.verbose: - print input_filename - - output_filename = os.path.splitext(input_filename)[0] + '.html' - 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 +if __name__ == '__main__': + Book2Html.run()