From ac1dd1bd2e92ac2e5f76ad976a39e6ae831b2493 Mon Sep 17 00:00:00 2001 From: Simon Tatham Date: Sun, 21 Apr 2019 14:07:25 +0100 Subject: [PATCH] kh2reg.py: switch from getopt to argparse. This change gives us an automatic --help option, which is always useful for a script used very rarely. It also makes it that much easier to add extra options. --- contrib/kh2reg.py | 30 +++++++++++++++++++----------- 1 file changed, 19 insertions(+), 11 deletions(-) diff --git a/contrib/kh2reg.py b/contrib/kh2reg.py index 5f9b95f1..ea8ff23d 100755 --- a/contrib/kh2reg.py +++ b/contrib/kh2reg.py @@ -16,7 +16,7 @@ import struct import string import re import sys -import getopt +import argparse import itertools import collections from functools import reduce @@ -370,18 +370,26 @@ class UnixOutputFormatter(OutputFormatter): self.fh.write('%s %s\n' % (key, value)) def main(): - output_formatter_class = WindowsOutputFormatter - try: - optlist, args = getopt.getopt(sys.argv[1:], '', [ 'win', 'unix' ]) - if any(x[0] == '--unix' for x in optlist): - output_formatter_class = UnixOutputFormatter - except getopt.error as e: - sys.stderr.write(str(e) + "\n") - sys.exit(1) + parser = argparse.ArgumentParser( + description="Convert OpenSSH known hosts files to PuTTY's format.") + group = parser.add_mutually_exclusive_group() + group.add_argument( + "--windows", "--win", action='store_const', + dest="output_formatter_class", const=WindowsOutputFormatter, + help="Produce Windows .reg file output that regedit.exe can import" + " (default).") + group.add_argument( + "--unix", action='store_const', + dest="output_formatter_class", const=UnixOutputFormatter, + help="Produce a file suitable for use as ~/.putty/sshhostkeys.") + parser.add_argument("infile", nargs="*", + help="Input file(s) to read from (default stdin).") + parser.set_defaults(output_formatter_class=WindowsOutputFormatter) + args = parser.parse_args() - output_formatter = output_formatter_class(sys.stdout) + output_formatter = args.output_formatter_class(sys.stdout) output_formatter.header() - for line in fileinput.input(args): + for line in fileinput.input(args.infile): handle_line(line, output_formatter) output_formatter.trailer()