Mercurial > public > purple
changeset 23:196c3c4a15aa
Added the --group and --width options.
author | Brian Neal <bgneal@gmail.com> |
---|---|
date | Sun, 16 Feb 2014 16:54:40 -0600 (2014-02-16) |
parents | 9c90ca37c023 |
children | adddc0d7038a |
files | purple/main.py purple/tests/test_machine.py |
diffstat | 2 files changed, 34 insertions(+), 5 deletions(-) [+] |
line wrap: on
line diff
--- a/purple/main.py Sun Feb 16 14:31:24 2014 -0600 +++ b/purple/main.py Sun Feb 16 16:54:40 2014 -0600 @@ -1,4 +1,4 @@ -# Copyright (C) 2013 by Brian Neal. +# Copyright (C) 2013 - 2014 by Brian Neal. # This file is part of purple, the PURPLE (Cipher Machine 97) simulation. # purple is released under the MIT License (see LICENSE.txt). @@ -8,6 +8,7 @@ import os import string import sys +import textwrap from purple.machine import Purple97, Purple97Error from purple.switch import SteppingSwitchError @@ -77,24 +78,37 @@ yield c +def group_text(text, n=5): + """Groups the given text into n-letter groups separated by spaces.""" + + return ' '.join(text[i:i+n] for i in range(0, len(text), n)) + + def main(argv=None): """Entry point for the command-line purple97 simulation.""" parser = argparse.ArgumentParser(description=DESC, epilog=EPILOG) parser.add_argument('-e', '--encrypt', action='store_true', - help='encrypt text from files or the command-line') + help='perform an encrypt operation') parser.add_argument('-d', '--decrypt', action='store_true', - help='decrypt text from files or the command-line') + help='perform a decrypt operation') parser.add_argument('-f', '--filter', action='store_true', help='filter plaintext and provide useful substitutions') parser.add_argument('-s', '--switches', help='switch settings, e.g. 9-1,24,6-23') parser.add_argument('-a', '--alphabet', - help='plugboard wiring string, 26-letters') + help='plugboard wiring string, 26-letters; e.g. AEIOUYBCDFGHJKLMNPQRSTVWXZ') parser.add_argument('-t', '--text', help='input text to encrypt/decrypt') parser.add_argument('-i', '--input', metavar='FILE', help='file to read input text from, - for stdin') + parser.add_argument('-g', '--group', type=int, default=5, metavar='N', + help=('if non-zero, group output in %(metavar)s-letter groups ' + '[default: %(default)s]')) + parser.add_argument('-w', '--width', type=int, default=70, metavar='N', + help=("wrap output text to %(metavar)s letters; " + "a value of 0 means do not wrap " + "[default: %(default)s]")) args = parser.parse_args(args=argv) @@ -119,6 +133,11 @@ else: alphabet = os.environ.get('PURPLE97_ALPHABET', DEFAULT_ALPHABET) + if args.group < 0: + parser.error("The --group option must be 0 or greater") + if args.width < 0: + parser.error("The --width option must be 0 or greater") + # Create purple cipher machine object try: purple = Purple97.from_key_sheet(switches, alphabet) @@ -148,6 +167,16 @@ except (Purple97Error, SteppingSwitchError) as ex: parser.error(str(ex)) + if args.group != 0: + result = group_text(result, args.group) + + if args.width != 0: + # Never break groups when grouping + break_long_words = args.group == 0 + result = textwrap.fill(result, width=args.width, expand_tabs=False, + replace_whitespace=False, drop_whitespace=False, + break_long_words=break_long_words) + print(result)
--- a/purple/tests/test_machine.py Sun Feb 16 14:31:24 2014 -0600 +++ b/purple/tests/test_machine.py Sun Feb 16 16:54:40 2014 -0600 @@ -1,4 +1,4 @@ -# Copyright (C) 2013 by Brian Neal. +# Copyright (C) 2013 - 2014 by Brian Neal. # This file is part of purple, the PURPLE (Cipher Machine 97) simulation. # purple is released under the MIT License (see LICENSE.txt).