From 4253cf1292a40e6c5c7a6a7729c278da4bf69186 Mon Sep 17 00:00:00 2001 From: Aineopintojen-harjoitustyo-Algoritmit-j Date: Sat, 3 Feb 2024 10:02:58 +0200 Subject: Adding --file option to cmdline parser and moving to cmdline.py. --- __main__.py | 84 +------------------------------------------------- cmdline.py | 101 ++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++ 2 files changed, 102 insertions(+), 83 deletions(-) create mode 100644 cmdline.py diff --git a/__main__.py b/__main__.py index 8f60946..a6b3172 100644 --- a/__main__.py +++ b/__main__.py @@ -1,92 +1,10 @@ """ __main__.py - Tästä suoritus alkaa """ import sys -from argparse import ArgumentParser from app import App from tui import KEY_DESCRIPTIONS -parser = ArgumentParser( - prog='miinaharava', - description='Klassisen miinaharavapelin terminaali toteutus.', - add_help=False -) -level_group = parser.add_argument_group('Vaikeustaso') -level_group.add_argument( - '-i', '--intermediate', - help='keskivaikea (oletus on aloittelija)', - action='store_true' -) -level_group.add_argument( - '-e', '--expert', - help='edistynyt (vaatii 100 merkkiä leveän terminaalin)', - action='store_true' -) - - -custom_group = parser.add_argument_group('Mukautettu vaikeustaso') -def board_size(wxh_string): - """ parser for dimensions. throws error on bad input""" - w, h = wxh_string.split('x') - return (int(w), int(h)) -custom_group.add_argument( - '-s', '--size', - metavar='', - type= board_size, - dest='size', - help='Pelikentän koko, missä on {leveys}x{korkeus}.' -) -custom_group.add_argument( - '-m', '--mines', - metavar='', - type=int, - dest='mines', - help='Säätää pelilaulla olevien pommien määrän :ksi.', -) - - -hint_group = parser.add_argument_group('Tekoäly') -hint_group.add_argument( - '-a', '--auto', - dest='autoplay', - default=0, - action='count', - help='Pelaa tekoälyn vihjeet. [-aa] Pelaa myös epävarmat.' -) -hint_group.add_argument( - '-b', '--bot', metavar='', - choices=range(2), - type=int, - default=2, - help='Valitsee tekoälyn , missä: 0: Ei tekoälyä 1: Yksinkertainen, 2: DSSP (oletus)', -) - -batch_group = parser.add_argument_group('Automatisointi') -batch_group.add_argument( - '-q', '--quiet', - help='Tulostaa minimaalisesti (asettaa myös [-aa])', - action='store_true' -) -batch_group.add_argument( - '-c', '--count', - metavar='', - type=int, - dest='count', - help='Suorittaa ohelmaa kertaa ja tulostaa voitto-osuuden.', -) - -misc_group = parser.add_argument_group('Sekalaista') -misc_group.add_argument( - '-h', '--help', - help='Tulostaa tämän viestin', - action='store_true' -) -misc_group.add_argument( - '-k', '--keys', - help='Tulostaa pelin näppäinkartan.', - action='store_true' -) - -args = parser.parse_args() +from cmdline import args if args.help: parser.print_help() diff --git a/cmdline.py b/cmdline.py new file mode 100644 index 0000000..b75c49c --- /dev/null +++ b/cmdline.py @@ -0,0 +1,101 @@ +from argparse import ArgumentParser + +parser = ArgumentParser( + prog='miinaharava', + description='Klassisen miinaharavapelin terminaali toteutus.', + add_help=False +) +level_group = parser.add_argument_group('Vaikeustaso') +level_group.add_argument( + '-i', '--intermediate', + help='keskivaikea (oletus on aloittelija)', + action='store_true' +) +level_group.add_argument( + '-e', '--expert', + help='edistynyt (vaatii 100 merkkiä leveän terminaalin)', + action='store_true' +) + + +custom_group = parser.add_argument_group('Mukautettu vaikeustaso') +def board_size(wxh_string): + """ parser for dimensions. throws error on bad input""" + w, h = wxh_string.split('x') + return (int(w), int(h)) +custom_group.add_argument( + '-s', '--size', + metavar='', + type= board_size, + dest='size', + help='Pelikentän koko, missä on {leveys}x{korkeus}.' +) +custom_group.add_argument( + '-m', '--mines', + metavar='', + type=int, + dest='mines', + help='Säätää pelilaulla olevien pommien määrän :ksi.', +) + + +hint_group = parser.add_argument_group('Tekoäly') +hint_group.add_argument( + '-a', '--auto', + dest='autoplay', + default=0, + action='count', + help='Pelaa tekoälyn vihjeet. [-aa] Pelaa myös epävarmat.' +) +hint_group.add_argument( + '-b', '--bot', metavar='', + choices=range(2), + type=int, + default=2, + help='Valitsee tekoälyn , missä: 0: Ei tekoälyä 1: Yksinkertainen, 2: DSSP (oletus)', +) + +batch_group = parser.add_argument_group('Automatisointi') +batch_group.add_argument( + '-q', '--quiet', + help='Tulostaa minimaalisesti (asettaa myös [-aa])', + action='store_true' +) +batch_group.add_argument( + '-c', '--count', + metavar='', + type=int, + dest='count', + help='Suorittaa ohelmaa kertaa ja tulostaa voitto-osuuden.', +) + +def filename( fn_string ): + """ filename - parser tyyppi joka testaa saako tiedoston auki """ + try: + with open(fn_string, "r", encoding="utf-8"): + pass + except FileNotFoundError as e: + raise ValueError from e + return fn_string +batch_group.add_argument( + '-f', '--file', + metavar='', + type=filename, + dest='file', + help='Pelaa tiedostossa olevat miinaharavakentät.', +) + +misc_group = parser.add_argument_group('Sekalaista') +misc_group.add_argument( + '-h', '--help', + help='Tulostaa tämän viestin', + action='store_true' +) +misc_group.add_argument( + '-k', '--keys', + help='Tulostaa pelin näppäinkartan.', + action='store_true' +) + +args = parser.parse_args() + -- cgit v1.2.3