X-Git-Url: https://git.armaanb.net/?a=blobdiff_plain;f=lightcards%2Frunner.py;h=6cb87d40d3f36c4db647e955cd3a70455b208044;hb=dd109cb4a1b49f920e36e5732417c4a3d5582821;hp=83a71b009b25413e51f112f2e200251b4b705a76;hpb=65cb608a985f5168edfa6e2833f37bc812274a2f;p=lightcards.git diff --git a/lightcards/runner.py b/lightcards/runner.py index 83a71b0..6cb87d4 100644 --- a/lightcards/runner.py +++ b/lightcards/runner.py @@ -2,13 +2,14 @@ # Armaan Bhojwani 2021 import argparse -from curses import wrapper +import curses import os +import pkg_resources from random import shuffle import sys from . import parse, progress -from .display import Display +from .display import Display, CursesError from .deck import Status @@ -17,6 +18,21 @@ def parse_args(): parser = argparse.ArgumentParser( description="Terminal flashcards from Markdown" ) + parser.add_argument( + "-c", + "--config", + type=str, + help="specify custom config file", + ) + parser.add_argument( + "-V", + "--view", + metavar="view", + type=int, + choices=range(1, 4), + default=1, + help="specify which view to start in (default = 1)", + ) parser.add_argument("inp", metavar="input file", type=str, nargs=1) parser.add_argument( "-a", @@ -24,9 +40,6 @@ def parse_args(): action="store_true", help="alphabetize card order", ) - parser.add_argument( - "-f", "--flip", action="store_true", help="show second column first" - ) parser.add_argument( "-p", "--purge", @@ -40,23 +53,26 @@ def parse_args(): "-s", "--shuffle", action="store_true", help="shuffle card order" ) parser.add_argument( - "-v", "--version", action="version", version="lightcards 0.6.0" + "-v", + "--version", + action="version", + version=f"lightcards {pkg_resources.require('lightcards')[0].version}", ) return parser.parse_args() -def show(args, stack, headers): +def show(args, stack, headers, input_file): """ Get objects from cache, manipulate deck according to passed arguments, and send it to the display functions """ # Purge caches if asked if args.purge: - progress.purge(stack) + progress.purge(get_orig()[1]) # Check for caches idx = Status() - cache = progress.dive(get_orig()) + cache = progress.dive(get_orig()[1]) if cache: (stack) = cache @@ -64,24 +80,16 @@ def show(args, stack, headers): if args.shuffle: shuffle(stack) if args.alphabetize: - stack.sort() + stack.sort(key=lambda x: x.front) if args.reverse: stack.reverse() - if args.flip: - for x in stack: - x[0], x[1] = x[1], x[0] - headers[0], headers[1] = headers[1], headers[0] # Send to display - win = Display(stack, headers, idx) - wrapper(win.run) - - -def reparse(): - """Parse arguments and input file again""" - args = parse_args() - os.system(f"$EDITOR {args.inp[0]}"), - return parse.parse_html(parse.md2html(args.inp[0])) + win = Display(stack, headers, idx, args.view, input_file) + try: + curses.wrapper(win.run) + except curses.error as e: + raise CursesError() from e def get_orig(): @@ -90,10 +98,11 @@ def get_orig(): def main(args=sys.argv): + sys.tracebacklimit = 0 args = parse_args() global headers, stack (headers, stack) = parse.parse_html(parse.md2html(args.inp[0])) - show(args, stack, headers) + show(args, stack, headers, args) if __name__ == "__main__":