1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
|
#! /usr/bin/python3
import json
import sys
import termios
import tty
import signal
from .connection import Connection
from .gameclient import Client
from .newdisplay.display import Display
from .parseargs import parse_args
from ratuil.screen import Screen
def main(argv=None):
(name, socketType, address, keybindings, characters, colours, logfile) = parse_args(argv)
connection = Connection(socketType)
try:
connection.connect(address)
except ConnectionRefusedError:
print("ERROR: Could not connect to server.\nAre you sure that the server is running and that you're connecting to the right address?", file=sys.stderr)
return
error = None
closeMessage = None
#os.environ.setdefault("ESCDELAY", "25")
fd = sys.stdin.fileno()
oldterm = termios.tcgetattr(fd)
try:
# Initialize curses
#stdscr = curses.initscr()
# Turn off echoing of keys, and enter cbreak mode,
# where no buffering is performed on keyboard input
#curses.noecho()
#curses.cbreak()
## In keypad mode, escape sequences for special keys
## (like the cursor keys) will be interpreted and
## a special value like curses.KEY_LEFT will be returned
#stdscr.keypad(1)
# Start color, too. Harmless if the terminal doesn't have
# color; user can test with has_color() later on. The try/catch
# works around a minor bit of over-conscientiousness in the curses
# module -- the error return from C start_color() is ignorable.
#try:
#curses.start_color()
#except:
#pass
tty.setraw(sys.stdin)
Screen.default.hide_cursor()
display = Display(characters)
client = Client(display, name, connection, keybindings, logfile)
signal.signal(signal.SIGWINCH, client.onSigwinch)
try:
client.start()
except KeyboardInterrupt:
client.close("^C caught, goodbye")
except Exception as e:
# throw the execption outside ncurses
# so the cleanup can happen first
error = e
closeMessage = client.closeMessage
finally:
## Set everything back to normal
#if 'stdscr' in locals():
#stdscr.keypad(0)
#curses.echo()
#curses.nocbreak()
#curses.endwin()
termios.tcsetattr(fd, termios.TCSADRAIN, oldterm)
Screen.default.finalize()
if error is not None:
raise error
if closeMessage:
print(closeMessage, file=sys.stderr)
|