#!/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, ParseError 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') options, input_filenames = parser.parse_args() 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: html.transform(input_filename, output_filename, parse_dublincore=options.parse_dublincore, flags=('full-page',)) except ParseError, e: print '%(file)s:%(name)s:%(message)s' % { 'file': input_filename, 'name': e.__class__.__name__, 'message': e.message } 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.message, } raise