X-Git-Url: https://git.armaanb.net/?a=blobdiff_plain;f=lightcards%2Frunner.py;h=69d5cbe09c1dd029d40e60b5af8a6f1fc8c1027a;hb=b9185b09edd2677f3a63cef4fd4be3e79671dc5c;hp=35651f92b5fd1d20cb7454b9bc1e1f34c661d1e6;hpb=25e3ada874ea7f277129b8d2e39b675bde340afe;p=lightcards.git diff --git a/lightcards/runner.py b/lightcards/runner.py index 35651f9..69d5cbe 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,15 @@ def parse_args(): parser = argparse.ArgumentParser( description="Terminal flashcards from Markdown" ) + 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 +34,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,19 +47,22 @@ 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() @@ -67,21 +77,13 @@ def show(args, stack, headers): 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 +92,12 @@ 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) + input_file = args.inp[0] + (headers, stack) = parse.parse_html(parse.md2html(input_file)) + show(args, stack, headers, input_file) if __name__ == "__main__":