X-Git-Url: https://git.armaanb.net/?a=blobdiff_plain;f=lightcards%2Frunner.py;h=15a622983235a671fd6b330b7efe75a6bd42dc55;hb=79afb3261a260272d0c3975eac67872a1c0b25df;hp=35651f92b5fd1d20cb7454b9bc1e1f34c661d1e6;hpb=25e3ada874ea7f277129b8d2e39b675bde340afe;p=lightcards.git diff --git a/lightcards/runner.py b/lightcards/runner.py index 35651f9..15a6229 100644 --- a/lightcards/runner.py +++ b/lightcards/runner.py @@ -2,13 +2,13 @@ # Armaan Bhojwani 2021 import argparse -from curses import wrapper -import os +import curses +import pkg_resources from random import shuffle import sys -from . import parse, progress -from .display import Display +from . import parse, progress, config +from .display import Display, CursesError from .deck import Status @@ -17,6 +17,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 +39,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 +52,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, conf): """ 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 +82,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, args, conf) + try: + curses.wrapper(win.run) + except curses.error as e: + raise CursesError() from e def get_orig(): @@ -93,7 +100,12 @@ def main(args=sys.argv): args = parse_args() global headers, stack (headers, stack) = parse.parse_html(parse.md2html(args.inp[0])) - show(args, stack, headers) + conf = config.read_file(args.config) + + if not conf["debug"]: + sys.tracebacklimit = 0 + + show(args, stack, headers, conf) if __name__ == "__main__":