X-Git-Url: https://git.sommitrealweird.co.uk/curses-crossword.git/blobdiff_plain/63cdf0aacdd38a6a5d14f8e142288e75a6fad0d1..95013783a7b2dcf4f9f2c9a13c2e7d1b0e319b59:/curses-crossword.py diff --git a/curses-crossword.py b/curses-crossword.py index d11568a..19ee754 100644 --- a/curses-crossword.py +++ b/curses-crossword.py @@ -4,6 +4,9 @@ import curses import curses.ascii import locale import codecs +import getopt +import os +import sys locale.setlocale(locale.LC_ALL, '') code = locale.getpreferredencoding() @@ -27,7 +30,30 @@ except: for number in range(0,10): superscript_numbers[str(number)] = str(number) -crossworddata = codecs.open("g2-20090701.txt", "r", "utf-8").read() +filename = None + +try: + (options, args) = getopt.getopt(sys.argv[1:], "f:", "file=") +except getopt.GetoptError, err: + print str(err) + sys.exit(2) + +for option in options: + if option[0] == "-f" or option[0] == "--file": + filename = option[1] + +if not filename and len(args) > 0: + filename = args[0] + +if not filename: + sys.stderr.write("No crossword file specified, exiting.\n") + sys.exit(0) + +if os.path.exists(filename) and os.path.isfile(filename): + crossworddata = codecs.open(filename, "r", "utf-8").read() +else: + sys.stderr.write("Couldn't open file %s\n" %(filename)) + sys.exit(0) def parsecrossword(crossworddata): ingrid = False @@ -58,13 +84,13 @@ def parsecrossword(crossworddata): parts = line.split() question_number = int(parts[0]) clue = " ".join(parts[1:]) - crossword["across"][int(question_number)] = clue + crossword["across"][int(question_number)] = clue.encode('utf-8') if indown: if line != "": parts = line.split() question_number = int(parts[0]) clue = " ".join(parts[1:]) - crossword["down"][int(question_number)] = clue + crossword["down"][int(question_number)] = clue.encode('utf-8') num_cols = len(crossword["grid"][0]) num_rows = len(crossword["grid"]) @@ -178,7 +204,12 @@ def crossword(stdscr, crossworddata): gridx = 0 gridy = 0 - stdscr.move(1,3) + while crossword["grid"][gridy][gridx] == "x": + curx += 4 + gridx += 1 + + stdscr.move(cury,curx) + while 1: c = stdscr.getch() if c == curses.ascii.ESC: