X-Git-Url: https://git.mdrn.pl/librarian.git/blobdiff_plain/07fdba2c7fe8e11b6867712d47bdd608e88c29fb..6d65ed2b0c5f9f6df14de211ea2bf1de0a5dac70:/scripts/book2txt diff --git a/scripts/book2txt b/scripts/book2txt index 1ca4623..d5e18c6 100755 --- a/scripts/book2txt +++ b/scripts/book2txt @@ -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 text +from librarian import dcparser, ParseError if __name__ == '__main__': @@ -14,9 +20,13 @@ if __name__ == '__main__': parser.add_option('-v', '--verbose', action='store_true', dest='verbose', default=False, help='print status messages to stdout') - + parser.add_option('-w', '--wrap', action='store', type='int', dest='wrapping', default=0, + help='set line wrap column') + 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) @@ -27,5 +37,26 @@ if __name__ == '__main__': print input_filename output_filename = os.path.splitext(input_filename)[0] + '.txt' - text.transform(input_filename, output_filename) - + try: + output_file = open(output_filename, 'w') + text.transform(open(input_filename), output_file, parse_dublincore=options.parse_dublincore, + wrapping=str(options.wrapping)) + 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