slotUI/slotCli.py

Sat, 22 Jun 2013 18:21:13 +0200

author
Malte Bayer <mbayer@neo-soft.org>
date
Sat, 22 Jun 2013 18:21:13 +0200
changeset 137
94d71156517b
parent 124
0b12a8bf23b2
child 139
7127e7082ee0
permissions
-rwxr-xr-x

added textfile event logger

25
646ee4dc3a6b started communication class and CLI
Malte Bayer <mbayer@neo-soft.org>
parents:
diff changeset
1 #!/usr/bin/env python
646ee4dc3a6b started communication class and CLI
Malte Bayer <mbayer@neo-soft.org>
parents:
diff changeset
2 """
646ee4dc3a6b started communication class and CLI
Malte Bayer <mbayer@neo-soft.org>
parents:
diff changeset
3 Freeslot project
646ee4dc3a6b started communication class and CLI
Malte Bayer <mbayer@neo-soft.org>
parents:
diff changeset
4 Command line interface
646ee4dc3a6b started communication class and CLI
Malte Bayer <mbayer@neo-soft.org>
parents:
diff changeset
5 """
27
3e617fcf999a added exception, started SlotCli class
Malte Bayer <mbayer@neo-soft.org>
parents: 25
diff changeset
6
77
cede78304992 finished live CLI, BB firmware improvements and fixes
Malte Bayer <mbayer@neo-soft.org>
parents: 74
diff changeset
7 from freeslot import Blackbox, LOGLEVEL
35
00166228a419 cli: implemented setting of fuel, brake, speed, blinkstate for any car
Malte Bayer <mbayer@neo-soft.org>
parents: 27
diff changeset
8 from optparse import OptionParser
77
cede78304992 finished live CLI, BB firmware improvements and fixes
Malte Bayer <mbayer@neo-soft.org>
parents: 74
diff changeset
9 from operator import itemgetter
78
d9126a55295c added sound triggers to live mode
Malte Bayer <mbayer@neo-soft.org>
parents: 77
diff changeset
10 from subprocess import Popen, PIPE
137
94d71156517b added textfile event logger
Malte Bayer <mbayer@neo-soft.org>
parents: 124
diff changeset
11 from logger import eventLogger
78
d9126a55295c added sound triggers to live mode
Malte Bayer <mbayer@neo-soft.org>
parents: 77
diff changeset
12 import sys, os
54
68eca8057d68 added livemode display to slotcli, without communication yet
Malte Bayer <mbayer@neo-soft.org>
parents: 50
diff changeset
13 from copy import copy
68eca8057d68 added livemode display to slotcli, without communication yet
Malte Bayer <mbayer@neo-soft.org>
parents: 50
diff changeset
14 import curses
137
94d71156517b added textfile event logger
Malte Bayer <mbayer@neo-soft.org>
parents: 124
diff changeset
15 from time import sleep, time
115
bb150048d329 added player profiles
Malte Bayer <mbayer@neo-soft.org>
parents: 113
diff changeset
16 import ConfigParser
35
00166228a419 cli: implemented setting of fuel, brake, speed, blinkstate for any car
Malte Bayer <mbayer@neo-soft.org>
parents: 27
diff changeset
17
110
b0e4f4249351 added xmlrpc server to live viewer, cli functions communicate with server
Malte Bayer <mbayer@neo-soft.org>
parents: 109
diff changeset
18 import SimpleXMLRPCServer
b0e4f4249351 added xmlrpc server to live viewer, cli functions communicate with server
Malte Bayer <mbayer@neo-soft.org>
parents: 109
diff changeset
19 import xmlrpclib
b0e4f4249351 added xmlrpc server to live viewer, cli functions communicate with server
Malte Bayer <mbayer@neo-soft.org>
parents: 109
diff changeset
20 import threading
b0e4f4249351 added xmlrpc server to live viewer, cli functions communicate with server
Malte Bayer <mbayer@neo-soft.org>
parents: 109
diff changeset
21
b0e4f4249351 added xmlrpc server to live viewer, cli functions communicate with server
Malte Bayer <mbayer@neo-soft.org>
parents: 109
diff changeset
22
137
94d71156517b added textfile event logger
Malte Bayer <mbayer@neo-soft.org>
parents: 124
diff changeset
23 VERSION = "1.8.1"
54
68eca8057d68 added livemode display to slotcli, without communication yet
Malte Bayer <mbayer@neo-soft.org>
parents: 50
diff changeset
24 MAXSLOTS = 6
68eca8057d68 added livemode display to slotcli, without communication yet
Malte Bayer <mbayer@neo-soft.org>
parents: 50
diff changeset
25 TERM = {
68eca8057d68 added livemode display to slotcli, without communication yet
Malte Bayer <mbayer@neo-soft.org>
parents: 50
diff changeset
26 "caption": "\033[1;37m\033[1;44m",
68eca8057d68 added livemode display to slotcli, without communication yet
Malte Bayer <mbayer@neo-soft.org>
parents: 50
diff changeset
27 "text": "\033[1;30m",
68eca8057d68 added livemode display to slotcli, without communication yet
Malte Bayer <mbayer@neo-soft.org>
parents: 50
diff changeset
28 }
27
3e617fcf999a added exception, started SlotCli class
Malte Bayer <mbayer@neo-soft.org>
parents: 25
diff changeset
29
77
cede78304992 finished live CLI, BB firmware improvements and fixes
Malte Bayer <mbayer@neo-soft.org>
parents: 74
diff changeset
30 # disable debug log output
cede78304992 finished live CLI, BB firmware improvements and fixes
Malte Bayer <mbayer@neo-soft.org>
parents: 74
diff changeset
31 LOGLEVEL = 10
cede78304992 finished live CLI, BB firmware improvements and fixes
Malte Bayer <mbayer@neo-soft.org>
parents: 74
diff changeset
32
81
4f2f94a043fd betatest corrections
Malte Bayer <mbayer@neo-soft.org>
parents: 78
diff changeset
33 SOUNDPREFIX = "quake-"
107
efdf471642f5 added custom event scripts
Malte Bayer <mbayer@neo-soft.org>
parents: 106
diff changeset
34 EVENTPREFIX = "event/"
78
d9126a55295c added sound triggers to live mode
Malte Bayer <mbayer@neo-soft.org>
parents: 77
diff changeset
35 SOUNDS = {
81
4f2f94a043fd betatest corrections
Malte Bayer <mbayer@neo-soft.org>
parents: 78
diff changeset
36 "countdown_start": os.path.abspath(SOUNDPREFIX + "sound/countdown.mp3"),
4f2f94a043fd betatest corrections
Malte Bayer <mbayer@neo-soft.org>
parents: 78
diff changeset
37 "race_start": os.path.abspath(SOUNDPREFIX + "sound/racestart.mp3"),
96
bcba10c35f09 added test option without communication
Malte Bayer <mbayer@neo-soft.org>
parents: 95
diff changeset
38 "race_prepare": os.path.abspath(SOUNDPREFIX + "sound/prepare.mp3"),
81
4f2f94a043fd betatest corrections
Malte Bayer <mbayer@neo-soft.org>
parents: 78
diff changeset
39 "lap_record": os.path.abspath(SOUNDPREFIX + "sound/laprecord.mp3"),
117
534e5c4b82c3 added trigger for new first position
Malte Bayer <mbayer@neo-soft.org>
parents: 116
diff changeset
40 # "first_position": os.path.abspath(SOUNDPREFIX + "sound/laprecord.mp3"),
81
4f2f94a043fd betatest corrections
Malte Bayer <mbayer@neo-soft.org>
parents: 78
diff changeset
41 "fuel_warning1": os.path.abspath(SOUNDPREFIX + "sound/fuel1.mp3"),
4f2f94a043fd betatest corrections
Malte Bayer <mbayer@neo-soft.org>
parents: 78
diff changeset
42 "fuel_warning2": os.path.abspath(SOUNDPREFIX + "sound/fuel2.mp3"),
4f2f94a043fd betatest corrections
Malte Bayer <mbayer@neo-soft.org>
parents: 78
diff changeset
43 "fuel_full": os.path.abspath(SOUNDPREFIX + "sound/fuel_full.mp3"),
4f2f94a043fd betatest corrections
Malte Bayer <mbayer@neo-soft.org>
parents: 78
diff changeset
44 "pitlane_enter": os.path.abspath(SOUNDPREFIX + "sound/pitlane_enter.mp3"),
4f2f94a043fd betatest corrections
Malte Bayer <mbayer@neo-soft.org>
parents: 78
diff changeset
45 "pitlane_exit": os.path.abspath(SOUNDPREFIX + "sound/pitlane_exit.mp3"),
87
761863c71884 added empty lines between live data display entries
Malte Bayer <mbayer@neo-soft.org>
parents: 86
diff changeset
46 "data_error": os.path.abspath(SOUNDPREFIX + "sound/data_error.mp3"),
93
ee4f9b8a36e9 improved live display with colors
Malte Bayer <mbayer@neo-soft.org>
parents: 90
diff changeset
47 "panic": os.path.abspath(SOUNDPREFIX + "sound/panic.mp3"),
ee4f9b8a36e9 improved live display with colors
Malte Bayer <mbayer@neo-soft.org>
parents: 90
diff changeset
48 "panic_shortcut": os.path.abspath(SOUNDPREFIX + "sound/panic_shortcut.mp3"),
ee4f9b8a36e9 improved live display with colors
Malte Bayer <mbayer@neo-soft.org>
parents: 90
diff changeset
49 "resume": os.path.abspath(SOUNDPREFIX + "sound/resume.mp3"),
95
85c4a4da2ffd added winning ability ;)
Malte Bayer <mbayer@neo-soft.org>
parents: 94
diff changeset
50 "win": os.path.abspath(SOUNDPREFIX + "sound/win.mp3"),
93
ee4f9b8a36e9 improved live display with colors
Malte Bayer <mbayer@neo-soft.org>
parents: 90
diff changeset
51
78
d9126a55295c added sound triggers to live mode
Malte Bayer <mbayer@neo-soft.org>
parents: 77
diff changeset
52 }
d9126a55295c added sound triggers to live mode
Malte Bayer <mbayer@neo-soft.org>
parents: 77
diff changeset
53
d9126a55295c added sound triggers to live mode
Malte Bayer <mbayer@neo-soft.org>
parents: 77
diff changeset
54 def trigger_sound(what):
d9126a55295c added sound triggers to live mode
Malte Bayer <mbayer@neo-soft.org>
parents: 77
diff changeset
55 if what in SOUNDS:
d9126a55295c added sound triggers to live mode
Malte Bayer <mbayer@neo-soft.org>
parents: 77
diff changeset
56 Popen(["/usr/bin/mpg123", "-q", SOUNDS[what]])
d9126a55295c added sound triggers to live mode
Malte Bayer <mbayer@neo-soft.org>
parents: 77
diff changeset
57 #os.spawnlp(os.P_NOWAIT, "/usr/bin/mpg123", "mpg123", SOUNDS[what])
d9126a55295c added sound triggers to live mode
Malte Bayer <mbayer@neo-soft.org>
parents: 77
diff changeset
58 #Popen(["/usr/bin/mpg123", SOUNDS[what]]).pid
d9126a55295c added sound triggers to live mode
Malte Bayer <mbayer@neo-soft.org>
parents: 77
diff changeset
59
112
fee43a74bed6 added controller number to event scripts parameter 1
Malte Bayer <mbayer@neo-soft.org>
parents: 111
diff changeset
60 def trigger_event(what, slot = 0):
107
efdf471642f5 added custom event scripts
Malte Bayer <mbayer@neo-soft.org>
parents: 106
diff changeset
61 trigger_sound(what)
112
fee43a74bed6 added controller number to event scripts parameter 1
Malte Bayer <mbayer@neo-soft.org>
parents: 111
diff changeset
62 Popen(["/bin/sh", os.path.abspath(EVENTPREFIX + what), str(slot)])
107
efdf471642f5 added custom event scripts
Malte Bayer <mbayer@neo-soft.org>
parents: 106
diff changeset
63
110
b0e4f4249351 added xmlrpc server to live viewer, cli functions communicate with server
Malte Bayer <mbayer@neo-soft.org>
parents: 109
diff changeset
64 class SlotServer(threading.Thread):
b0e4f4249351 added xmlrpc server to live viewer, cli functions communicate with server
Malte Bayer <mbayer@neo-soft.org>
parents: 109
diff changeset
65 def __init__(self, blackbox):
b0e4f4249351 added xmlrpc server to live viewer, cli functions communicate with server
Malte Bayer <mbayer@neo-soft.org>
parents: 109
diff changeset
66 threading.Thread.__init__(self)
b0e4f4249351 added xmlrpc server to live viewer, cli functions communicate with server
Malte Bayer <mbayer@neo-soft.org>
parents: 109
diff changeset
67 self.server = SimpleXMLRPCServer.SimpleXMLRPCServer(("localhost", 8000))
b0e4f4249351 added xmlrpc server to live viewer, cli functions communicate with server
Malte Bayer <mbayer@neo-soft.org>
parents: 109
diff changeset
68 self.server.register_instance(blackbox)
b0e4f4249351 added xmlrpc server to live viewer, cli functions communicate with server
Malte Bayer <mbayer@neo-soft.org>
parents: 109
diff changeset
69 #self.server.register_function(lambda astr: '_' + astr, '_string')
111
7e9a451870ed forgot thread damonize
Malte Bayer <mbayer@neo-soft.org>
parents: 110
diff changeset
70 self.daemon = True
110
b0e4f4249351 added xmlrpc server to live viewer, cli functions communicate with server
Malte Bayer <mbayer@neo-soft.org>
parents: 109
diff changeset
71
b0e4f4249351 added xmlrpc server to live viewer, cli functions communicate with server
Malte Bayer <mbayer@neo-soft.org>
parents: 109
diff changeset
72 def run(self):
b0e4f4249351 added xmlrpc server to live viewer, cli functions communicate with server
Malte Bayer <mbayer@neo-soft.org>
parents: 109
diff changeset
73 self.server.serve_forever()
b0e4f4249351 added xmlrpc server to live viewer, cli functions communicate with server
Malte Bayer <mbayer@neo-soft.org>
parents: 109
diff changeset
74
b0e4f4249351 added xmlrpc server to live viewer, cli functions communicate with server
Malte Bayer <mbayer@neo-soft.org>
parents: 109
diff changeset
75 class SlotClient():
b0e4f4249351 added xmlrpc server to live viewer, cli functions communicate with server
Malte Bayer <mbayer@neo-soft.org>
parents: 109
diff changeset
76 def __init__(self, url):
b0e4f4249351 added xmlrpc server to live viewer, cli functions communicate with server
Malte Bayer <mbayer@neo-soft.org>
parents: 109
diff changeset
77 self.box = xmlrpclib.Server(url)
b0e4f4249351 added xmlrpc server to live viewer, cli functions communicate with server
Malte Bayer <mbayer@neo-soft.org>
parents: 109
diff changeset
78
27
3e617fcf999a added exception, started SlotCli class
Malte Bayer <mbayer@neo-soft.org>
parents: 25
diff changeset
79 class SlotCli():
106
11fabe1f7c40 added dev parameter
Malte Bayer <mbayer@neo-soft.org>
parents: 104
diff changeset
80 def __init__(self, test = None, dev=""):
27
3e617fcf999a added exception, started SlotCli class
Malte Bayer <mbayer@neo-soft.org>
parents: 25
diff changeset
81 self.box = Blackbox()
116
c2fc650cc48f added option to disable freeslot fuel logic
Malte Bayer <mbayer@neo-soft.org>
parents: 115
diff changeset
82 self.nofuel = False
124
0b12a8bf23b2 new option to set pitlane entry as finish line too to increase laps
Malte Bayer <mbayer@neo-soft.org>
parents: 123
diff changeset
83 self.pitfinish = False
110
b0e4f4249351 added xmlrpc server to live viewer, cli functions communicate with server
Malte Bayer <mbayer@neo-soft.org>
parents: 109
diff changeset
84 if (not test):
106
11fabe1f7c40 added dev parameter
Malte Bayer <mbayer@neo-soft.org>
parents: 104
diff changeset
85 self.box.connect(dev)
110
b0e4f4249351 added xmlrpc server to live viewer, cli functions communicate with server
Malte Bayer <mbayer@neo-soft.org>
parents: 109
diff changeset
86 self.rpcserver = SlotServer(self.box)
b0e4f4249351 added xmlrpc server to live viewer, cli functions communicate with server
Malte Bayer <mbayer@neo-soft.org>
parents: 109
diff changeset
87 self.rpcserver.start()
54
68eca8057d68 added livemode display to slotcli, without communication yet
Malte Bayer <mbayer@neo-soft.org>
parents: 50
diff changeset
88 self.slot_dummy = {
115
bb150048d329 added player profiles
Malte Bayer <mbayer@neo-soft.org>
parents: 113
diff changeset
89 "name": "uninitialized",
54
68eca8057d68 added livemode display to slotcli, without communication yet
Malte Bayer <mbayer@neo-soft.org>
parents: 50
diff changeset
90 "laps": 0,
95
85c4a4da2ffd added winning ability ;)
Malte Bayer <mbayer@neo-soft.org>
parents: 94
diff changeset
91 "laps_last": 0,
55
9293f3efcc06 added live display to CLI (lap counter, last and best time)
Malte Bayer <mbayer@neo-soft.org>
parents: 54
diff changeset
92 "last": 0.00,
9293f3efcc06 added live display to CLI (lap counter, last and best time)
Malte Bayer <mbayer@neo-soft.org>
parents: 54
diff changeset
93 "best": 0.00,
54
68eca8057d68 added livemode display to slotcli, without communication yet
Malte Bayer <mbayer@neo-soft.org>
parents: 50
diff changeset
94 "fuel": 0,
81
4f2f94a043fd betatest corrections
Malte Bayer <mbayer@neo-soft.org>
parents: 78
diff changeset
95 "fuel_last": 0,
54
68eca8057d68 added livemode display to slotcli, without communication yet
Malte Bayer <mbayer@neo-soft.org>
parents: 50
diff changeset
96 "position": 0,
55
9293f3efcc06 added live display to CLI (lap counter, last and best time)
Malte Bayer <mbayer@neo-soft.org>
parents: 54
diff changeset
97 "drive": 0,
77
cede78304992 finished live CLI, BB firmware improvements and fixes
Malte Bayer <mbayer@neo-soft.org>
parents: 74
diff changeset
98 "status": "Idle",
cede78304992 finished live CLI, BB firmware improvements and fixes
Malte Bayer <mbayer@neo-soft.org>
parents: 74
diff changeset
99 "clk": 0,
cede78304992 finished live CLI, BB firmware improvements and fixes
Malte Bayer <mbayer@neo-soft.org>
parents: 74
diff changeset
100 "car": 0,
95
85c4a4da2ffd added winning ability ;)
Malte Bayer <mbayer@neo-soft.org>
parents: 94
diff changeset
101 "limit": 15,
115
bb150048d329 added player profiles
Malte Bayer <mbayer@neo-soft.org>
parents: 113
diff changeset
102 "profilename": "default",
bb150048d329 added player profiles
Malte Bayer <mbayer@neo-soft.org>
parents: 113
diff changeset
103 "profile": ConfigParser.RawConfigParser(),
54
68eca8057d68 added livemode display to slotcli, without communication yet
Malte Bayer <mbayer@neo-soft.org>
parents: 50
diff changeset
104 }
115
bb150048d329 added player profiles
Malte Bayer <mbayer@neo-soft.org>
parents: 113
diff changeset
105 self.slot_dummy["profile"].read("profiles/" + self.slot_dummy["profilename"])
bb150048d329 added player profiles
Malte Bayer <mbayer@neo-soft.org>
parents: 113
diff changeset
106 self.slot_dummy["name"] = self.slot_dummy["profile"].get("Settings", "Name")
bb150048d329 added player profiles
Malte Bayer <mbayer@neo-soft.org>
parents: 113
diff changeset
107 self.slot_dummy["limit"] = self.slot_dummy["profile"].getint("Settings", "Limit")
27
3e617fcf999a added exception, started SlotCli class
Malte Bayer <mbayer@neo-soft.org>
parents: 25
diff changeset
108
54
68eca8057d68 added livemode display to slotcli, without communication yet
Malte Bayer <mbayer@neo-soft.org>
parents: 50
diff changeset
109 self.slot = [
68eca8057d68 added livemode display to slotcli, without communication yet
Malte Bayer <mbayer@neo-soft.org>
parents: 50
diff changeset
110 copy(self.slot_dummy), copy(self.slot_dummy),
68eca8057d68 added livemode display to slotcli, without communication yet
Malte Bayer <mbayer@neo-soft.org>
parents: 50
diff changeset
111 copy(self.slot_dummy), copy(self.slot_dummy),
68eca8057d68 added livemode display to slotcli, without communication yet
Malte Bayer <mbayer@neo-soft.org>
parents: 50
diff changeset
112 copy(self.slot_dummy), copy(self.slot_dummy),
68eca8057d68 added livemode display to slotcli, without communication yet
Malte Bayer <mbayer@neo-soft.org>
parents: 50
diff changeset
113 ]
77
cede78304992 finished live CLI, BB firmware improvements and fixes
Malte Bayer <mbayer@neo-soft.org>
parents: 74
diff changeset
114 self.reset_slots()
cede78304992 finished live CLI, BB firmware improvements and fixes
Malte Bayer <mbayer@neo-soft.org>
parents: 74
diff changeset
115 self.sysclk = 0.00
96
bcba10c35f09 added test option without communication
Malte Bayer <mbayer@neo-soft.org>
parents: 95
diff changeset
116 self.sysclk_last = 0.00
117
534e5c4b82c3 added trigger for new first position
Malte Bayer <mbayer@neo-soft.org>
parents: 116
diff changeset
117 self.bestlap = 9999999.00 # best lap time
87
761863c71884 added empty lines between live data display entries
Malte Bayer <mbayer@neo-soft.org>
parents: 86
diff changeset
118 self.test = test
117
534e5c4b82c3 added trigger for new first position
Malte Bayer <mbayer@neo-soft.org>
parents: 116
diff changeset
119 self.laplimit = 999 # race laplimit
534e5c4b82c3 added trigger for new first position
Malte Bayer <mbayer@neo-soft.org>
parents: 116
diff changeset
120 self.timelimit = 0 # race timelimit
534e5c4b82c3 added trigger for new first position
Malte Bayer <mbayer@neo-soft.org>
parents: 116
diff changeset
121 self.firstpos = -1 # first position slot
534e5c4b82c3 added trigger for new first position
Malte Bayer <mbayer@neo-soft.org>
parents: 116
diff changeset
122 self.freerun = True # freerun mode = sort order by best lap
137
94d71156517b added textfile event logger
Malte Bayer <mbayer@neo-soft.org>
parents: 124
diff changeset
123 self.raceName = "Freestyle"
94d71156517b added textfile event logger
Malte Bayer <mbayer@neo-soft.org>
parents: 124
diff changeset
124 self.log = eventLogger("events.log")
77
cede78304992 finished live CLI, BB firmware improvements and fixes
Malte Bayer <mbayer@neo-soft.org>
parents: 74
diff changeset
125
cede78304992 finished live CLI, BB firmware improvements and fixes
Malte Bayer <mbayer@neo-soft.org>
parents: 74
diff changeset
126 def reset_slots(self):
cede78304992 finished live CLI, BB firmware improvements and fixes
Malte Bayer <mbayer@neo-soft.org>
parents: 74
diff changeset
127 idx = 0
cede78304992 finished live CLI, BB firmware improvements and fixes
Malte Bayer <mbayer@neo-soft.org>
parents: 74
diff changeset
128 for slt in self.slot:
cede78304992 finished live CLI, BB firmware improvements and fixes
Malte Bayer <mbayer@neo-soft.org>
parents: 74
diff changeset
129 slt["laps"] = 0
95
85c4a4da2ffd added winning ability ;)
Malte Bayer <mbayer@neo-soft.org>
parents: 94
diff changeset
130 slt["laps_last"] = 0
122
8344d8d38c4f fix again
Malte Bayer <mbayer@neo-soft.org>
parents: 121
diff changeset
131 slt["last"] = 999.00
121
6ea0dff10e78 fix sort order
Malte Bayer <mbayer@neo-soft.org>
parents: 120
diff changeset
132 slt["best"] = 999.00
93
ee4f9b8a36e9 improved live display with colors
Malte Bayer <mbayer@neo-soft.org>
parents: 90
diff changeset
133 slt["fuel"] = 100
81
4f2f94a043fd betatest corrections
Malte Bayer <mbayer@neo-soft.org>
parents: 78
diff changeset
134 slt["fuel_last"] = 0
77
cede78304992 finished live CLI, BB firmware improvements and fixes
Malte Bayer <mbayer@neo-soft.org>
parents: 74
diff changeset
135 slt["position"] = idx
cede78304992 finished live CLI, BB firmware improvements and fixes
Malte Bayer <mbayer@neo-soft.org>
parents: 74
diff changeset
136 slt["car"] = idx # used for sort order calculation
cede78304992 finished live CLI, BB firmware improvements and fixes
Malte Bayer <mbayer@neo-soft.org>
parents: 74
diff changeset
137 slt["status"] = self.slot_dummy["status"]
cede78304992 finished live CLI, BB firmware improvements and fixes
Malte Bayer <mbayer@neo-soft.org>
parents: 74
diff changeset
138 slt["clk"] = 0
115
bb150048d329 added player profiles
Malte Bayer <mbayer@neo-soft.org>
parents: 113
diff changeset
139 slt["limit"] = slt["profile"].getint("Settings", "Limit")
77
cede78304992 finished live CLI, BB firmware improvements and fixes
Malte Bayer <mbayer@neo-soft.org>
parents: 74
diff changeset
140 idx += 1
82
c89221096db7 bugfixes
Malte Bayer <mbayer@neo-soft.org>
parents: 81
diff changeset
141 self.bestlap = 99999.00
97
9a01c57147db final corrections
Malte Bayer <mbayer@neo-soft.org>
parents: 96
diff changeset
142 self.raceactive = False
54
68eca8057d68 added livemode display to slotcli, without communication yet
Malte Bayer <mbayer@neo-soft.org>
parents: 50
diff changeset
143
68eca8057d68 added livemode display to slotcli, without communication yet
Malte Bayer <mbayer@neo-soft.org>
parents: 50
diff changeset
144 def update_positions(self):
77
cede78304992 finished live CLI, BB firmware improvements and fixes
Malte Bayer <mbayer@neo-soft.org>
parents: 74
diff changeset
145 order1 = sorted(self.slot, key=itemgetter(
cede78304992 finished live CLI, BB firmware improvements and fixes
Malte Bayer <mbayer@neo-soft.org>
parents: 74
diff changeset
146 "clk"))
117
534e5c4b82c3 added trigger for new first position
Malte Bayer <mbayer@neo-soft.org>
parents: 116
diff changeset
147 if self.freerun:
534e5c4b82c3 added trigger for new first position
Malte Bayer <mbayer@neo-soft.org>
parents: 116
diff changeset
148 order2 = sorted(self.slot, key=itemgetter(
534e5c4b82c3 added trigger for new first position
Malte Bayer <mbayer@neo-soft.org>
parents: 116
diff changeset
149 "best"))
534e5c4b82c3 added trigger for new first position
Malte Bayer <mbayer@neo-soft.org>
parents: 116
diff changeset
150 else:
534e5c4b82c3 added trigger for new first position
Malte Bayer <mbayer@neo-soft.org>
parents: 116
diff changeset
151 order2 = sorted(self.slot, key=itemgetter(
534e5c4b82c3 added trigger for new first position
Malte Bayer <mbayer@neo-soft.org>
parents: 116
diff changeset
152 "laps"), reverse=True)
77
cede78304992 finished live CLI, BB firmware improvements and fixes
Malte Bayer <mbayer@neo-soft.org>
parents: 74
diff changeset
153 idx = 1
cede78304992 finished live CLI, BB firmware improvements and fixes
Malte Bayer <mbayer@neo-soft.org>
parents: 74
diff changeset
154 for tst in order2:
cede78304992 finished live CLI, BB firmware improvements and fixes
Malte Bayer <mbayer@neo-soft.org>
parents: 74
diff changeset
155 self.slot[tst["car"]]["position"] = idx
117
534e5c4b82c3 added trigger for new first position
Malte Bayer <mbayer@neo-soft.org>
parents: 116
diff changeset
156 # check if first position changed
120
049478896193 hotfixes
Malte Bayer <mbayer@neo-soft.org>
parents: 118
diff changeset
157 if (self.firstpos != tst["car"]) and (idx == 1):
117
534e5c4b82c3 added trigger for new first position
Malte Bayer <mbayer@neo-soft.org>
parents: 116
diff changeset
158 self.firstpos = tst["car"]
534e5c4b82c3 added trigger for new first position
Malte Bayer <mbayer@neo-soft.org>
parents: 116
diff changeset
159 trigger_event("first_position", tst["car"] + 1)
77
cede78304992 finished live CLI, BB firmware improvements and fixes
Malte Bayer <mbayer@neo-soft.org>
parents: 74
diff changeset
160 idx += 1
54
68eca8057d68 added livemode display to slotcli, without communication yet
Malte Bayer <mbayer@neo-soft.org>
parents: 50
diff changeset
161
68eca8057d68 added livemode display to slotcli, without communication yet
Malte Bayer <mbayer@neo-soft.org>
parents: 50
diff changeset
162 def render_slots(self):
68eca8057d68 added livemode display to slotcli, without communication yet
Malte Bayer <mbayer@neo-soft.org>
parents: 50
diff changeset
163 self.update_positions()
68eca8057d68 added livemode display to slotcli, without communication yet
Malte Bayer <mbayer@neo-soft.org>
parents: 50
diff changeset
164 self.scr.addstr(3,0,
93
ee4f9b8a36e9 improved live display with colors
Malte Bayer <mbayer@neo-soft.org>
parents: 90
diff changeset
165 #"Pos | #/Name | Laps | Best | Last | Fuel | Status ",
ee4f9b8a36e9 improved live display with colors
Malte Bayer <mbayer@neo-soft.org>
parents: 90
diff changeset
166 "Pos | #/Name ",
ee4f9b8a36e9 improved live display with colors
Malte Bayer <mbayer@neo-soft.org>
parents: 90
diff changeset
167 curses.color_pair(2))
ee4f9b8a36e9 improved live display with colors
Malte Bayer <mbayer@neo-soft.org>
parents: 90
diff changeset
168 self.scr.addstr(4,4,
ee4f9b8a36e9 improved live display with colors
Malte Bayer <mbayer@neo-soft.org>
parents: 90
diff changeset
169 " Laps | Best | Last | Fuel | Status ",
54
68eca8057d68 added livemode display to slotcli, without communication yet
Malte Bayer <mbayer@neo-soft.org>
parents: 50
diff changeset
170 curses.color_pair(2))
68eca8057d68 added livemode display to slotcli, without communication yet
Malte Bayer <mbayer@neo-soft.org>
parents: 50
diff changeset
171 for idx in range(MAXSLOTS):
93
ee4f9b8a36e9 improved live display with colors
Malte Bayer <mbayer@neo-soft.org>
parents: 90
diff changeset
172 """
87
761863c71884 added empty lines between live data display entries
Malte Bayer <mbayer@neo-soft.org>
parents: 86
diff changeset
173 self.scr.addstr((3 + (self.slot[idx]["position"] * 2)), 0,
77
cede78304992 finished live CLI, BB firmware improvements and fixes
Malte Bayer <mbayer@neo-soft.org>
parents: 74
diff changeset
174 "%3i | %i %15s | %4i | %7.2fs | %7.2fs | %3i%% | %10s" % (
54
68eca8057d68 added livemode display to slotcli, without communication yet
Malte Bayer <mbayer@neo-soft.org>
parents: 50
diff changeset
175 self.slot[idx]["position"],
77
cede78304992 finished live CLI, BB firmware improvements and fixes
Malte Bayer <mbayer@neo-soft.org>
parents: 74
diff changeset
176 self.slot[idx]["car"] + 1, self.slot[idx]["name"],
54
68eca8057d68 added livemode display to slotcli, without communication yet
Malte Bayer <mbayer@neo-soft.org>
parents: 50
diff changeset
177 self.slot[idx]["laps"],
68eca8057d68 added livemode display to slotcli, without communication yet
Malte Bayer <mbayer@neo-soft.org>
parents: 50
diff changeset
178 self.slot[idx]["best"],
68eca8057d68 added livemode display to slotcli, without communication yet
Malte Bayer <mbayer@neo-soft.org>
parents: 50
diff changeset
179 self.slot[idx]["last"],
68eca8057d68 added livemode display to slotcli, without communication yet
Malte Bayer <mbayer@neo-soft.org>
parents: 50
diff changeset
180 self.slot[idx]["fuel"],
77
cede78304992 finished live CLI, BB firmware improvements and fixes
Malte Bayer <mbayer@neo-soft.org>
parents: 74
diff changeset
181 self.slot[idx]["status"],
93
ee4f9b8a36e9 improved live display with colors
Malte Bayer <mbayer@neo-soft.org>
parents: 90
diff changeset
182 ),
ee4f9b8a36e9 improved live display with colors
Malte Bayer <mbayer@neo-soft.org>
parents: 90
diff changeset
183 curses.color_pair(11 + idx) )
ee4f9b8a36e9 improved live display with colors
Malte Bayer <mbayer@neo-soft.org>
parents: 90
diff changeset
184 """
102
72f5eb420096 added drive speed display for virtual slots to live screen
Malte Bayer <mbayer@neo-soft.org>
parents: 101
diff changeset
185 if idx > 3:
72f5eb420096 added drive speed display for virtual slots to live screen
Malte Bayer <mbayer@neo-soft.org>
parents: 101
diff changeset
186 namesuffix = " (%i)" % self.slot[idx]["drive"]
72f5eb420096 added drive speed display for virtual slots to live screen
Malte Bayer <mbayer@neo-soft.org>
parents: 101
diff changeset
187 else:
72f5eb420096 added drive speed display for virtual slots to live screen
Malte Bayer <mbayer@neo-soft.org>
parents: 101
diff changeset
188 namesuffix = ""
72f5eb420096 added drive speed display for virtual slots to live screen
Malte Bayer <mbayer@neo-soft.org>
parents: 101
diff changeset
189
93
ee4f9b8a36e9 improved live display with colors
Malte Bayer <mbayer@neo-soft.org>
parents: 90
diff changeset
190 self.scr.addstr((3 + (self.slot[idx]["position"] * 2)), 0,
ee4f9b8a36e9 improved live display with colors
Malte Bayer <mbayer@neo-soft.org>
parents: 90
diff changeset
191 "%3i | %i %15s %48s" % (
ee4f9b8a36e9 improved live display with colors
Malte Bayer <mbayer@neo-soft.org>
parents: 90
diff changeset
192 self.slot[idx]["position"],
102
72f5eb420096 added drive speed display for virtual slots to live screen
Malte Bayer <mbayer@neo-soft.org>
parents: 101
diff changeset
193 self.slot[idx]["car"] + 1, (self.slot[idx]["name"] + namesuffix),
93
ee4f9b8a36e9 improved live display with colors
Malte Bayer <mbayer@neo-soft.org>
parents: 90
diff changeset
194 "",
ee4f9b8a36e9 improved live display with colors
Malte Bayer <mbayer@neo-soft.org>
parents: 90
diff changeset
195 ),
ee4f9b8a36e9 improved live display with colors
Malte Bayer <mbayer@neo-soft.org>
parents: 90
diff changeset
196 curses.color_pair(11 + idx) )
ee4f9b8a36e9 improved live display with colors
Malte Bayer <mbayer@neo-soft.org>
parents: 90
diff changeset
197 self.scr.addstr((4 + (self.slot[idx]["position"] * 2)), 4,
95
85c4a4da2ffd added winning ability ;)
Malte Bayer <mbayer@neo-soft.org>
parents: 94
diff changeset
198 " %4i | %7.2fs | %7.2fs | %3i%% | %10s | %2i% 15s" % (
93
ee4f9b8a36e9 improved live display with colors
Malte Bayer <mbayer@neo-soft.org>
parents: 90
diff changeset
199 self.slot[idx]["laps"],
ee4f9b8a36e9 improved live display with colors
Malte Bayer <mbayer@neo-soft.org>
parents: 90
diff changeset
200 self.slot[idx]["best"],
ee4f9b8a36e9 improved live display with colors
Malte Bayer <mbayer@neo-soft.org>
parents: 90
diff changeset
201 self.slot[idx]["last"],
ee4f9b8a36e9 improved live display with colors
Malte Bayer <mbayer@neo-soft.org>
parents: 90
diff changeset
202 self.slot[idx]["fuel"],
ee4f9b8a36e9 improved live display with colors
Malte Bayer <mbayer@neo-soft.org>
parents: 90
diff changeset
203 self.slot[idx]["status"],
95
85c4a4da2ffd added winning ability ;)
Malte Bayer <mbayer@neo-soft.org>
parents: 94
diff changeset
204 self.slot[idx]["limit"],
93
ee4f9b8a36e9 improved live display with colors
Malte Bayer <mbayer@neo-soft.org>
parents: 90
diff changeset
205 ""
ee4f9b8a36e9 improved live display with colors
Malte Bayer <mbayer@neo-soft.org>
parents: 90
diff changeset
206 ),
ee4f9b8a36e9 improved live display with colors
Malte Bayer <mbayer@neo-soft.org>
parents: 90
diff changeset
207 curses.color_pair(11 + idx) )
54
68eca8057d68 added livemode display to slotcli, without communication yet
Malte Bayer <mbayer@neo-soft.org>
parents: 50
diff changeset
208
68eca8057d68 added livemode display to slotcli, without communication yet
Malte Bayer <mbayer@neo-soft.org>
parents: 50
diff changeset
209 def cleartop(self):
95
85c4a4da2ffd added winning ability ;)
Malte Bayer <mbayer@neo-soft.org>
parents: 94
diff changeset
210 self.scr.addstr(0,0, "%60s" % "Race Limits: %i Laps / %i Minutes" % (self.laplimit, self.timelimit))
54
68eca8057d68 added livemode display to slotcli, without communication yet
Malte Bayer <mbayer@neo-soft.org>
parents: 50
diff changeset
211 self.scr.addstr(1,0, "%80s" % " ")
68eca8057d68 added livemode display to slotcli, without communication yet
Malte Bayer <mbayer@neo-soft.org>
parents: 50
diff changeset
212
115
bb150048d329 added player profiles
Malte Bayer <mbayer@neo-soft.org>
parents: 113
diff changeset
213 def flash_car_settings(self, slot):
bb150048d329 added player profiles
Malte Bayer <mbayer@neo-soft.org>
parents: 113
diff changeset
214 # write current settings to car firmware
bb150048d329 added player profiles
Malte Bayer <mbayer@neo-soft.org>
parents: 113
diff changeset
215 self.box.setmode(0)
116
c2fc650cc48f added option to disable freeslot fuel logic
Malte Bayer <mbayer@neo-soft.org>
parents: 115
diff changeset
216 self.scr.addstr(1,0, "%70s" % "Writing settings for %s to car %i, PLEASE WAIT... " % (
115
bb150048d329 added player profiles
Malte Bayer <mbayer@neo-soft.org>
parents: 113
diff changeset
217 self.slot[slot]["name"],
bb150048d329 added player profiles
Malte Bayer <mbayer@neo-soft.org>
parents: 113
diff changeset
218 slot + 1),
116
c2fc650cc48f added option to disable freeslot fuel logic
Malte Bayer <mbayer@neo-soft.org>
parents: 115
diff changeset
219 curses.color_pair(9))
115
bb150048d329 added player profiles
Malte Bayer <mbayer@neo-soft.org>
parents: 113
diff changeset
220 self.scr.refresh()
116
c2fc650cc48f added option to disable freeslot fuel logic
Malte Bayer <mbayer@neo-soft.org>
parents: 115
diff changeset
221 if not self.nofuel:
c2fc650cc48f added option to disable freeslot fuel logic
Malte Bayer <mbayer@neo-soft.org>
parents: 115
diff changeset
222 self.box.progcar(slot, "fuel", 0)
c2fc650cc48f added option to disable freeslot fuel logic
Malte Bayer <mbayer@neo-soft.org>
parents: 115
diff changeset
223 sleep(0.5)
115
bb150048d329 added player profiles
Malte Bayer <mbayer@neo-soft.org>
parents: 113
diff changeset
224 self.box.progcar(slot, "accel", self.slot[slot]["profile"].getint("Settings", "Accel"))
bb150048d329 added player profiles
Malte Bayer <mbayer@neo-soft.org>
parents: 113
diff changeset
225 sleep(0.5)
bb150048d329 added player profiles
Malte Bayer <mbayer@neo-soft.org>
parents: 113
diff changeset
226 self.box.progcar(slot, "brake", self.slot[slot]["profile"].getint("Settings", "Brake"))
bb150048d329 added player profiles
Malte Bayer <mbayer@neo-soft.org>
parents: 113
diff changeset
227 sleep(0.5)
bb150048d329 added player profiles
Malte Bayer <mbayer@neo-soft.org>
parents: 113
diff changeset
228 self.box.speedlimit(slot, self.slot[slot]["limit"])
bb150048d329 added player profiles
Malte Bayer <mbayer@neo-soft.org>
parents: 113
diff changeset
229 sleep(0.5)
bb150048d329 added player profiles
Malte Bayer <mbayer@neo-soft.org>
parents: 113
diff changeset
230 self.cleartop()
bb150048d329 added player profiles
Malte Bayer <mbayer@neo-soft.org>
parents: 113
diff changeset
231 self.box.setmode(1)
bb150048d329 added player profiles
Malte Bayer <mbayer@neo-soft.org>
parents: 113
diff changeset
232
54
68eca8057d68 added livemode display to slotcli, without communication yet
Malte Bayer <mbayer@neo-soft.org>
parents: 50
diff changeset
233 def readName(self, slot):
56
a20f59a3016c ui fix, added car5+6 detector to blackbox
Malte Bayer <mbayer@neo-soft.org>
parents: 55
diff changeset
234 self.scr.nodelay(0) # enable delay on readkey
54
68eca8057d68 added livemode display to slotcli, without communication yet
Malte Bayer <mbayer@neo-soft.org>
parents: 50
diff changeset
235 curses.echo()
68eca8057d68 added livemode display to slotcli, without communication yet
Malte Bayer <mbayer@neo-soft.org>
parents: 50
diff changeset
236 self.scr.addstr(0,0, "Enter Name for Controller %i [%s]:" % (
68eca8057d68 added livemode display to slotcli, without communication yet
Malte Bayer <mbayer@neo-soft.org>
parents: 50
diff changeset
237 slot + 1,
68eca8057d68 added livemode display to slotcli, without communication yet
Malte Bayer <mbayer@neo-soft.org>
parents: 50
diff changeset
238 self.slot[slot]["name"]),
68eca8057d68 added livemode display to slotcli, without communication yet
Malte Bayer <mbayer@neo-soft.org>
parents: 50
diff changeset
239 curses.color_pair(1))
68eca8057d68 added livemode display to slotcli, without communication yet
Malte Bayer <mbayer@neo-soft.org>
parents: 50
diff changeset
240 self.scr.refresh()
68eca8057d68 added livemode display to slotcli, without communication yet
Malte Bayer <mbayer@neo-soft.org>
parents: 50
diff changeset
241 name = self.scr.getstr(1,0, 15)
68eca8057d68 added livemode display to slotcli, without communication yet
Malte Bayer <mbayer@neo-soft.org>
parents: 50
diff changeset
242 if name != "":
115
bb150048d329 added player profiles
Malte Bayer <mbayer@neo-soft.org>
parents: 113
diff changeset
243 # look if profile with that name found
bb150048d329 added player profiles
Malte Bayer <mbayer@neo-soft.org>
parents: 113
diff changeset
244 try:
bb150048d329 added player profiles
Malte Bayer <mbayer@neo-soft.org>
parents: 113
diff changeset
245 with open("profiles/" + name) as f: pass
bb150048d329 added player profiles
Malte Bayer <mbayer@neo-soft.org>
parents: 113
diff changeset
246 self.slot[slot]["profilename"] = name
bb150048d329 added player profiles
Malte Bayer <mbayer@neo-soft.org>
parents: 113
diff changeset
247 self.slot[slot]["profile"].read("profiles/" + name)
bb150048d329 added player profiles
Malte Bayer <mbayer@neo-soft.org>
parents: 113
diff changeset
248 self.slot[slot]["name"] = self.slot[slot]["profile"].get("Settings", "Name")
bb150048d329 added player profiles
Malte Bayer <mbayer@neo-soft.org>
parents: 113
diff changeset
249 self.slot[slot]["limit"] = self.slot[slot]["profile"].getint("Settings", "Limit")
bb150048d329 added player profiles
Malte Bayer <mbayer@neo-soft.org>
parents: 113
diff changeset
250 self.flash_car_settings(slot)
bb150048d329 added player profiles
Malte Bayer <mbayer@neo-soft.org>
parents: 113
diff changeset
251 except IOError, err:
bb150048d329 added player profiles
Malte Bayer <mbayer@neo-soft.org>
parents: 113
diff changeset
252 self.slot[slot]["profilename"] = "default"
bb150048d329 added player profiles
Malte Bayer <mbayer@neo-soft.org>
parents: 113
diff changeset
253 self.slot[slot]["profile"].read("profiles/default")
bb150048d329 added player profiles
Malte Bayer <mbayer@neo-soft.org>
parents: 113
diff changeset
254 self.slot[slot]["limit"] = self.slot[slot]["profile"].getint("Settings", "Limit")
bb150048d329 added player profiles
Malte Bayer <mbayer@neo-soft.org>
parents: 113
diff changeset
255 self.slot[slot]["name"] = name
bb150048d329 added player profiles
Malte Bayer <mbayer@neo-soft.org>
parents: 113
diff changeset
256 self.flash_car_settings(slot)
54
68eca8057d68 added livemode display to slotcli, without communication yet
Malte Bayer <mbayer@neo-soft.org>
parents: 50
diff changeset
257 self.cleartop()
55
9293f3efcc06 added live display to CLI (lap counter, last and best time)
Malte Bayer <mbayer@neo-soft.org>
parents: 54
diff changeset
258 self.scr.refresh()
54
68eca8057d68 added livemode display to slotcli, without communication yet
Malte Bayer <mbayer@neo-soft.org>
parents: 50
diff changeset
259 curses.noecho()
56
a20f59a3016c ui fix, added car5+6 detector to blackbox
Malte Bayer <mbayer@neo-soft.org>
parents: 55
diff changeset
260 self.scr.nodelay(1) # disable delay on readkey
54
68eca8057d68 added livemode display to slotcli, without communication yet
Malte Bayer <mbayer@neo-soft.org>
parents: 50
diff changeset
261
137
94d71156517b added textfile event logger
Malte Bayer <mbayer@neo-soft.org>
parents: 124
diff changeset
262 def readRaceName(self):
94d71156517b added textfile event logger
Malte Bayer <mbayer@neo-soft.org>
parents: 124
diff changeset
263 self.scr.nodelay(0) # enable delay on readkey
94d71156517b added textfile event logger
Malte Bayer <mbayer@neo-soft.org>
parents: 124
diff changeset
264 curses.echo()
94d71156517b added textfile event logger
Malte Bayer <mbayer@neo-soft.org>
parents: 124
diff changeset
265 self.scr.addstr(0,0, "Enter Race Name [%s]:" % (
94d71156517b added textfile event logger
Malte Bayer <mbayer@neo-soft.org>
parents: 124
diff changeset
266 self.raceName),
94d71156517b added textfile event logger
Malte Bayer <mbayer@neo-soft.org>
parents: 124
diff changeset
267 curses.color_pair(1))
94d71156517b added textfile event logger
Malte Bayer <mbayer@neo-soft.org>
parents: 124
diff changeset
268 self.scr.refresh()
94d71156517b added textfile event logger
Malte Bayer <mbayer@neo-soft.org>
parents: 124
diff changeset
269 name = self.scr.getstr(1,0, 15)
94d71156517b added textfile event logger
Malte Bayer <mbayer@neo-soft.org>
parents: 124
diff changeset
270 if name != "":
94d71156517b added textfile event logger
Malte Bayer <mbayer@neo-soft.org>
parents: 124
diff changeset
271 self.raceName = name
94d71156517b added textfile event logger
Malte Bayer <mbayer@neo-soft.org>
parents: 124
diff changeset
272 self.cleartop()
94d71156517b added textfile event logger
Malte Bayer <mbayer@neo-soft.org>
parents: 124
diff changeset
273 self.scr.refresh()
94d71156517b added textfile event logger
Malte Bayer <mbayer@neo-soft.org>
parents: 124
diff changeset
274 curses.noecho()
94d71156517b added textfile event logger
Malte Bayer <mbayer@neo-soft.org>
parents: 124
diff changeset
275 self.scr.nodelay(1) # disable delay on readkey
94d71156517b added textfile event logger
Malte Bayer <mbayer@neo-soft.org>
parents: 124
diff changeset
276
95
85c4a4da2ffd added winning ability ;)
Malte Bayer <mbayer@neo-soft.org>
parents: 94
diff changeset
277 def readLimit(self, slot):
85c4a4da2ffd added winning ability ;)
Malte Bayer <mbayer@neo-soft.org>
parents: 94
diff changeset
278 limit = self.readInt("SPEEDLIMIT for %s (%i)" % (
85c4a4da2ffd added winning ability ;)
Malte Bayer <mbayer@neo-soft.org>
parents: 94
diff changeset
279 self.slot[slot]["name"],
85c4a4da2ffd added winning ability ;)
Malte Bayer <mbayer@neo-soft.org>
parents: 94
diff changeset
280 slot + 1),
85c4a4da2ffd added winning ability ;)
Malte Bayer <mbayer@neo-soft.org>
parents: 94
diff changeset
281 self.slot[slot]["limit"], 15)
85c4a4da2ffd added winning ability ;)
Malte Bayer <mbayer@neo-soft.org>
parents: 94
diff changeset
282 if limit:
85c4a4da2ffd added winning ability ;)
Malte Bayer <mbayer@neo-soft.org>
parents: 94
diff changeset
283 self.slot[slot]["limit"] = limit
85c4a4da2ffd added winning ability ;)
Malte Bayer <mbayer@neo-soft.org>
parents: 94
diff changeset
284 self.cleartop()
85c4a4da2ffd added winning ability ;)
Malte Bayer <mbayer@neo-soft.org>
parents: 94
diff changeset
285 self.box.speedlimit(slot, limit)
85c4a4da2ffd added winning ability ;)
Malte Bayer <mbayer@neo-soft.org>
parents: 94
diff changeset
286
85c4a4da2ffd added winning ability ;)
Malte Bayer <mbayer@neo-soft.org>
parents: 94
diff changeset
287
85c4a4da2ffd added winning ability ;)
Malte Bayer <mbayer@neo-soft.org>
parents: 94
diff changeset
288 def readInt(self, msg, default, maximum = 999999):
94
c7ff8cde6b1e improved live display with colors
Malte Bayer <mbayer@neo-soft.org>
parents: 93
diff changeset
289 self.scr.nodelay(0) # enable delay on readkey
c7ff8cde6b1e improved live display with colors
Malte Bayer <mbayer@neo-soft.org>
parents: 93
diff changeset
290 curses.echo()
c7ff8cde6b1e improved live display with colors
Malte Bayer <mbayer@neo-soft.org>
parents: 93
diff changeset
291 self.scr.addstr(0,0, "%s [%i]:" % (
c7ff8cde6b1e improved live display with colors
Malte Bayer <mbayer@neo-soft.org>
parents: 93
diff changeset
292 msg,
95
85c4a4da2ffd added winning ability ;)
Malte Bayer <mbayer@neo-soft.org>
parents: 94
diff changeset
293 default),
94
c7ff8cde6b1e improved live display with colors
Malte Bayer <mbayer@neo-soft.org>
parents: 93
diff changeset
294 curses.color_pair(1))
c7ff8cde6b1e improved live display with colors
Malte Bayer <mbayer@neo-soft.org>
parents: 93
diff changeset
295 self.scr.refresh()
c7ff8cde6b1e improved live display with colors
Malte Bayer <mbayer@neo-soft.org>
parents: 93
diff changeset
296 inp = self.scr.getstr(1,0, 4)
c7ff8cde6b1e improved live display with colors
Malte Bayer <mbayer@neo-soft.org>
parents: 93
diff changeset
297 if inp != "":
c7ff8cde6b1e improved live display with colors
Malte Bayer <mbayer@neo-soft.org>
parents: 93
diff changeset
298 try:
c7ff8cde6b1e improved live display with colors
Malte Bayer <mbayer@neo-soft.org>
parents: 93
diff changeset
299 inp = int(inp)
95
85c4a4da2ffd added winning ability ;)
Malte Bayer <mbayer@neo-soft.org>
parents: 94
diff changeset
300 if inp > maximum: inp = maximum
94
c7ff8cde6b1e improved live display with colors
Malte Bayer <mbayer@neo-soft.org>
parents: 93
diff changeset
301 except Exception:
c7ff8cde6b1e improved live display with colors
Malte Bayer <mbayer@neo-soft.org>
parents: 93
diff changeset
302 inp = None
c7ff8cde6b1e improved live display with colors
Malte Bayer <mbayer@neo-soft.org>
parents: 93
diff changeset
303 else:
c7ff8cde6b1e improved live display with colors
Malte Bayer <mbayer@neo-soft.org>
parents: 93
diff changeset
304 inp = None
c7ff8cde6b1e improved live display with colors
Malte Bayer <mbayer@neo-soft.org>
parents: 93
diff changeset
305 self.cleartop()
c7ff8cde6b1e improved live display with colors
Malte Bayer <mbayer@neo-soft.org>
parents: 93
diff changeset
306 self.scr.refresh()
c7ff8cde6b1e improved live display with colors
Malte Bayer <mbayer@neo-soft.org>
parents: 93
diff changeset
307 curses.noecho()
c7ff8cde6b1e improved live display with colors
Malte Bayer <mbayer@neo-soft.org>
parents: 93
diff changeset
308 self.scr.nodelay(1) # disable delay on readkey
c7ff8cde6b1e improved live display with colors
Malte Bayer <mbayer@neo-soft.org>
parents: 93
diff changeset
309 return inp
c7ff8cde6b1e improved live display with colors
Malte Bayer <mbayer@neo-soft.org>
parents: 93
diff changeset
310
c7ff8cde6b1e improved live display with colors
Malte Bayer <mbayer@neo-soft.org>
parents: 93
diff changeset
311
103
52fd4283cd2c added learn and teach modes for intelligent ghostcars
Malte Bayer <mbayer@neo-soft.org>
parents: 102
diff changeset
312 def monitor_init(self, live = 1):
74
173d0863a804 added live init to slotcli
Malte Bayer <mbayer@neo-soft.org>
parents: 61
diff changeset
313 """
173d0863a804 added live init to slotcli
Malte Bayer <mbayer@neo-soft.org>
parents: 61
diff changeset
314 Send initializing commands for live monitoring
173d0863a804 added live init to slotcli
Malte Bayer <mbayer@neo-soft.org>
parents: 61
diff changeset
315 """
116
c2fc650cc48f added option to disable freeslot fuel logic
Malte Bayer <mbayer@neo-soft.org>
parents: 115
diff changeset
316 if self.nofuel:
c2fc650cc48f added option to disable freeslot fuel logic
Malte Bayer <mbayer@neo-soft.org>
parents: 115
diff changeset
317 #print cli.box.fueldivisor(0)
c2fc650cc48f added option to disable freeslot fuel logic
Malte Bayer <mbayer@neo-soft.org>
parents: 115
diff changeset
318 self.box.query("F0\n") # set fuel logic disabled
c2fc650cc48f added option to disable freeslot fuel logic
Malte Bayer <mbayer@neo-soft.org>
parents: 115
diff changeset
319 else:
c2fc650cc48f added option to disable freeslot fuel logic
Malte Bayer <mbayer@neo-soft.org>
parents: 115
diff changeset
320 #print cli.box.fueldivisor(25)
c2fc650cc48f added option to disable freeslot fuel logic
Malte Bayer <mbayer@neo-soft.org>
parents: 115
diff changeset
321 self.box.query("F1\n") # set fuel logic enabled
124
0b12a8bf23b2 new option to set pitlane entry as finish line too to increase laps
Malte Bayer <mbayer@neo-soft.org>
parents: 123
diff changeset
322
0b12a8bf23b2 new option to set pitlane entry as finish line too to increase laps
Malte Bayer <mbayer@neo-soft.org>
parents: 123
diff changeset
323 if self.pitfinish:
0b12a8bf23b2 new option to set pitlane entry as finish line too to increase laps
Malte Bayer <mbayer@neo-soft.org>
parents: 123
diff changeset
324 self.box.query("X1\n") # set pitlane finish function
0b12a8bf23b2 new option to set pitlane entry as finish line too to increase laps
Malte Bayer <mbayer@neo-soft.org>
parents: 123
diff changeset
325 else:
0b12a8bf23b2 new option to set pitlane entry as finish line too to increase laps
Malte Bayer <mbayer@neo-soft.org>
parents: 123
diff changeset
326 #print cli.box.fueldivisor(25)
0b12a8bf23b2 new option to set pitlane entry as finish line too to increase laps
Malte Bayer <mbayer@neo-soft.org>
parents: 123
diff changeset
327 self.box.query("X0\n")
0b12a8bf23b2 new option to set pitlane entry as finish line too to increase laps
Malte Bayer <mbayer@neo-soft.org>
parents: 123
diff changeset
328
103
52fd4283cd2c added learn and teach modes for intelligent ghostcars
Malte Bayer <mbayer@neo-soft.org>
parents: 102
diff changeset
329 self.box.query("*%i\n" % live) # set live fuel info
52fd4283cd2c added learn and teach modes for intelligent ghostcars
Malte Bayer <mbayer@neo-soft.org>
parents: 102
diff changeset
330
52fd4283cd2c added learn and teach modes for intelligent ghostcars
Malte Bayer <mbayer@neo-soft.org>
parents: 102
diff changeset
331 def monitor_learn(self, slot):
52fd4283cd2c added learn and teach modes for intelligent ghostcars
Malte Bayer <mbayer@neo-soft.org>
parents: 102
diff changeset
332 # clear garbage in UART rx buffer
52fd4283cd2c added learn and teach modes for intelligent ghostcars
Malte Bayer <mbayer@neo-soft.org>
parents: 102
diff changeset
333 self.box.query("*0\n") # set live fuel info
52fd4283cd2c added learn and teach modes for intelligent ghostcars
Malte Bayer <mbayer@neo-soft.org>
parents: 102
diff changeset
334 self.box.query("*0\n") # set live fuel info
52fd4283cd2c added learn and teach modes for intelligent ghostcars
Malte Bayer <mbayer@neo-soft.org>
parents: 102
diff changeset
335 while self.box.readline() != "": pass
52fd4283cd2c added learn and teach modes for intelligent ghostcars
Malte Bayer <mbayer@neo-soft.org>
parents: 102
diff changeset
336
52fd4283cd2c added learn and teach modes for intelligent ghostcars
Malte Bayer <mbayer@neo-soft.org>
parents: 102
diff changeset
337 trk = False
52fd4283cd2c added learn and teach modes for intelligent ghostcars
Malte Bayer <mbayer@neo-soft.org>
parents: 102
diff changeset
338 spd = 0
52fd4283cd2c added learn and teach modes for intelligent ghostcars
Malte Bayer <mbayer@neo-soft.org>
parents: 102
diff changeset
339 trk_old = False
52fd4283cd2c added learn and teach modes for intelligent ghostcars
Malte Bayer <mbayer@neo-soft.org>
parents: 102
diff changeset
340 spd_old = 0
52fd4283cd2c added learn and teach modes for intelligent ghostcars
Malte Bayer <mbayer@neo-soft.org>
parents: 102
diff changeset
341 clock = -1
52fd4283cd2c added learn and teach modes for intelligent ghostcars
Malte Bayer <mbayer@neo-soft.org>
parents: 102
diff changeset
342
52fd4283cd2c added learn and teach modes for intelligent ghostcars
Malte Bayer <mbayer@neo-soft.org>
parents: 102
diff changeset
343 self.monitor_init(slot + 2)
52fd4283cd2c added learn and teach modes for intelligent ghostcars
Malte Bayer <mbayer@neo-soft.org>
parents: 102
diff changeset
344 while 1:
52fd4283cd2c added learn and teach modes for intelligent ghostcars
Malte Bayer <mbayer@neo-soft.org>
parents: 102
diff changeset
345 #key = self.scr.getch()
52fd4283cd2c added learn and teach modes for intelligent ghostcars
Malte Bayer <mbayer@neo-soft.org>
parents: 102
diff changeset
346 #if key == ord('c'): break
52fd4283cd2c added learn and teach modes for intelligent ghostcars
Malte Bayer <mbayer@neo-soft.org>
parents: 102
diff changeset
347
52fd4283cd2c added learn and teach modes for intelligent ghostcars
Malte Bayer <mbayer@neo-soft.org>
parents: 102
diff changeset
348 # is there something in the rx buffer?
52fd4283cd2c added learn and teach modes for intelligent ghostcars
Malte Bayer <mbayer@neo-soft.org>
parents: 102
diff changeset
349 rx = self.box.readline()
52fd4283cd2c added learn and teach modes for intelligent ghostcars
Malte Bayer <mbayer@neo-soft.org>
parents: 102
diff changeset
350 if (rx != ""):
52fd4283cd2c added learn and teach modes for intelligent ghostcars
Malte Bayer <mbayer@neo-soft.org>
parents: 102
diff changeset
351 try:
52fd4283cd2c added learn and teach modes for intelligent ghostcars
Malte Bayer <mbayer@neo-soft.org>
parents: 102
diff changeset
352 data = rx.split(":")
52fd4283cd2c added learn and teach modes for intelligent ghostcars
Malte Bayer <mbayer@neo-soft.org>
parents: 102
diff changeset
353 if rx[:3] == "LN:":
52fd4283cd2c added learn and teach modes for intelligent ghostcars
Malte Bayer <mbayer@neo-soft.org>
parents: 102
diff changeset
354 if clock >= 0:
52fd4283cd2c added learn and teach modes for intelligent ghostcars
Malte Bayer <mbayer@neo-soft.org>
parents: 102
diff changeset
355 clock += 1
52fd4283cd2c added learn and teach modes for intelligent ghostcars
Malte Bayer <mbayer@neo-soft.org>
parents: 102
diff changeset
356 spd = int(data[1], 16)
52fd4283cd2c added learn and teach modes for intelligent ghostcars
Malte Bayer <mbayer@neo-soft.org>
parents: 102
diff changeset
357 trk = (data[2] != 'X')
52fd4283cd2c added learn and teach modes for intelligent ghostcars
Malte Bayer <mbayer@neo-soft.org>
parents: 102
diff changeset
358 if (spd != spd_old) or (trk != trk_old):
52fd4283cd2c added learn and teach modes for intelligent ghostcars
Malte Bayer <mbayer@neo-soft.org>
parents: 102
diff changeset
359 if clock < 0:
52fd4283cd2c added learn and teach modes for intelligent ghostcars
Malte Bayer <mbayer@neo-soft.org>
parents: 102
diff changeset
360 clock = 0
52fd4283cd2c added learn and teach modes for intelligent ghostcars
Malte Bayer <mbayer@neo-soft.org>
parents: 102
diff changeset
361 print "%i,%i,%s" % (clock, spd, trk)
52fd4283cd2c added learn and teach modes for intelligent ghostcars
Malte Bayer <mbayer@neo-soft.org>
parents: 102
diff changeset
362 trk_old = trk
52fd4283cd2c added learn and teach modes for intelligent ghostcars
Malte Bayer <mbayer@neo-soft.org>
parents: 102
diff changeset
363 spd_old = spd * 1
52fd4283cd2c added learn and teach modes for intelligent ghostcars
Malte Bayer <mbayer@neo-soft.org>
parents: 102
diff changeset
364 if rx[:2] == "L:":
52fd4283cd2c added learn and teach modes for intelligent ghostcars
Malte Bayer <mbayer@neo-soft.org>
parents: 102
diff changeset
365 # update lap time info
52fd4283cd2c added learn and teach modes for intelligent ghostcars
Malte Bayer <mbayer@neo-soft.org>
parents: 102
diff changeset
366 l = int(data[2], 16)
52fd4283cd2c added learn and teach modes for intelligent ghostcars
Malte Bayer <mbayer@neo-soft.org>
parents: 102
diff changeset
367 s = int(data[3]) - 1
52fd4283cd2c added learn and teach modes for intelligent ghostcars
Malte Bayer <mbayer@neo-soft.org>
parents: 102
diff changeset
368 t = int(data[4], 16) / 2000.00
52fd4283cd2c added learn and teach modes for intelligent ghostcars
Malte Bayer <mbayer@neo-soft.org>
parents: 102
diff changeset
369 if (slot == s):
52fd4283cd2c added learn and teach modes for intelligent ghostcars
Malte Bayer <mbayer@neo-soft.org>
parents: 102
diff changeset
370 print "# lap %i complete: %3.2f seconds" % (l, t)
52fd4283cd2c added learn and teach modes for intelligent ghostcars
Malte Bayer <mbayer@neo-soft.org>
parents: 102
diff changeset
371 clock = 0
52fd4283cd2c added learn and teach modes for intelligent ghostcars
Malte Bayer <mbayer@neo-soft.org>
parents: 102
diff changeset
372 print "%i,%i,%s" % (clock, spd, trk)
52fd4283cd2c added learn and teach modes for intelligent ghostcars
Malte Bayer <mbayer@neo-soft.org>
parents: 102
diff changeset
373 except:
52fd4283cd2c added learn and teach modes for intelligent ghostcars
Malte Bayer <mbayer@neo-soft.org>
parents: 102
diff changeset
374 print "RX ERROR: " % rx
52fd4283cd2c added learn and teach modes for intelligent ghostcars
Malte Bayer <mbayer@neo-soft.org>
parents: 102
diff changeset
375
52fd4283cd2c added learn and teach modes for intelligent ghostcars
Malte Bayer <mbayer@neo-soft.org>
parents: 102
diff changeset
376 def monitor_playback(self, slot, filename):
52fd4283cd2c added learn and teach modes for intelligent ghostcars
Malte Bayer <mbayer@neo-soft.org>
parents: 102
diff changeset
377 # clear garbage in UART rx buffer
52fd4283cd2c added learn and teach modes for intelligent ghostcars
Malte Bayer <mbayer@neo-soft.org>
parents: 102
diff changeset
378 self.box.query("*0\n") # set live fuel info
52fd4283cd2c added learn and teach modes for intelligent ghostcars
Malte Bayer <mbayer@neo-soft.org>
parents: 102
diff changeset
379 self.box.query("*0\n") # set live fuel info
52fd4283cd2c added learn and teach modes for intelligent ghostcars
Malte Bayer <mbayer@neo-soft.org>
parents: 102
diff changeset
380 sleep(1)
52fd4283cd2c added learn and teach modes for intelligent ghostcars
Malte Bayer <mbayer@neo-soft.org>
parents: 102
diff changeset
381 cli.box.speedminimum(slot, 0 )
52fd4283cd2c added learn and teach modes for intelligent ghostcars
Malte Bayer <mbayer@neo-soft.org>
parents: 102
diff changeset
382 while self.box.readline() != "": pass
52fd4283cd2c added learn and teach modes for intelligent ghostcars
Malte Bayer <mbayer@neo-soft.org>
parents: 102
diff changeset
383
52fd4283cd2c added learn and teach modes for intelligent ghostcars
Malte Bayer <mbayer@neo-soft.org>
parents: 102
diff changeset
384 clock = -5
52fd4283cd2c added learn and teach modes for intelligent ghostcars
Malte Bayer <mbayer@neo-soft.org>
parents: 102
diff changeset
385 trkfile = open(filename, "r").readlines()
52fd4283cd2c added learn and teach modes for intelligent ghostcars
Malte Bayer <mbayer@neo-soft.org>
parents: 102
diff changeset
386 print "Loading %s..." % filename
52fd4283cd2c added learn and teach modes for intelligent ghostcars
Malte Bayer <mbayer@neo-soft.org>
parents: 102
diff changeset
387
52fd4283cd2c added learn and teach modes for intelligent ghostcars
Malte Bayer <mbayer@neo-soft.org>
parents: 102
diff changeset
388 while 1:
52fd4283cd2c added learn and teach modes for intelligent ghostcars
Malte Bayer <mbayer@neo-soft.org>
parents: 102
diff changeset
389 try:
52fd4283cd2c added learn and teach modes for intelligent ghostcars
Malte Bayer <mbayer@neo-soft.org>
parents: 102
diff changeset
390 for l in trkfile:
52fd4283cd2c added learn and teach modes for intelligent ghostcars
Malte Bayer <mbayer@neo-soft.org>
parents: 102
diff changeset
391 l = l.strip()
52fd4283cd2c added learn and teach modes for intelligent ghostcars
Malte Bayer <mbayer@neo-soft.org>
parents: 102
diff changeset
392 if (l != "") and (l[:1] != "#"):
52fd4283cd2c added learn and teach modes for intelligent ghostcars
Malte Bayer <mbayer@neo-soft.org>
parents: 102
diff changeset
393 print "Line: %s" % repr(l)
52fd4283cd2c added learn and teach modes for intelligent ghostcars
Malte Bayer <mbayer@neo-soft.org>
parents: 102
diff changeset
394 data = l.split(",")
52fd4283cd2c added learn and teach modes for intelligent ghostcars
Malte Bayer <mbayer@neo-soft.org>
parents: 102
diff changeset
395 speed = int(data[1])
52fd4283cd2c added learn and teach modes for intelligent ghostcars
Malte Bayer <mbayer@neo-soft.org>
parents: 102
diff changeset
396 while (clock < int(data[0]) and (int(data[0]) > 0)):
52fd4283cd2c added learn and teach modes for intelligent ghostcars
Malte Bayer <mbayer@neo-soft.org>
parents: 102
diff changeset
397 clock += 1
52fd4283cd2c added learn and teach modes for intelligent ghostcars
Malte Bayer <mbayer@neo-soft.org>
parents: 102
diff changeset
398 sleep(0.07)
52fd4283cd2c added learn and teach modes for intelligent ghostcars
Malte Bayer <mbayer@neo-soft.org>
parents: 102
diff changeset
399 print "CLK %i/%i -> set: %i" % (clock, int(data[0]), speed)
52fd4283cd2c added learn and teach modes for intelligent ghostcars
Malte Bayer <mbayer@neo-soft.org>
parents: 102
diff changeset
400 cli.box.speedminimum(slot, speed )
52fd4283cd2c added learn and teach modes for intelligent ghostcars
Malte Bayer <mbayer@neo-soft.org>
parents: 102
diff changeset
401 # now wait for lap sync :)
52fd4283cd2c added learn and teach modes for intelligent ghostcars
Malte Bayer <mbayer@neo-soft.org>
parents: 102
diff changeset
402 while self.box.readline() != "": pass
52fd4283cd2c added learn and teach modes for intelligent ghostcars
Malte Bayer <mbayer@neo-soft.org>
parents: 102
diff changeset
403 rx = ""
52fd4283cd2c added learn and teach modes for intelligent ghostcars
Malte Bayer <mbayer@neo-soft.org>
parents: 102
diff changeset
404 while rx[:2] != "L:":
52fd4283cd2c added learn and teach modes for intelligent ghostcars
Malte Bayer <mbayer@neo-soft.org>
parents: 102
diff changeset
405 rx = self.box.readline()
52fd4283cd2c added learn and teach modes for intelligent ghostcars
Malte Bayer <mbayer@neo-soft.org>
parents: 102
diff changeset
406 data = rx.split(":")
52fd4283cd2c added learn and teach modes for intelligent ghostcars
Malte Bayer <mbayer@neo-soft.org>
parents: 102
diff changeset
407 l = int(data[2], 16)
52fd4283cd2c added learn and teach modes for intelligent ghostcars
Malte Bayer <mbayer@neo-soft.org>
parents: 102
diff changeset
408 s = int(data[3]) - 1
52fd4283cd2c added learn and teach modes for intelligent ghostcars
Malte Bayer <mbayer@neo-soft.org>
parents: 102
diff changeset
409 t = int(data[4], 16) / 2000.00
52fd4283cd2c added learn and teach modes for intelligent ghostcars
Malte Bayer <mbayer@neo-soft.org>
parents: 102
diff changeset
410 print "# lap %i complete: %3.2f seconds" % (l, t)
52fd4283cd2c added learn and teach modes for intelligent ghostcars
Malte Bayer <mbayer@neo-soft.org>
parents: 102
diff changeset
411 clock = -3
52fd4283cd2c added learn and teach modes for intelligent ghostcars
Malte Bayer <mbayer@neo-soft.org>
parents: 102
diff changeset
412 except Exception, e:
52fd4283cd2c added learn and teach modes for intelligent ghostcars
Malte Bayer <mbayer@neo-soft.org>
parents: 102
diff changeset
413 print repr(e)
52fd4283cd2c added learn and teach modes for intelligent ghostcars
Malte Bayer <mbayer@neo-soft.org>
parents: 102
diff changeset
414 sys.exit(1)
52fd4283cd2c added learn and teach modes for intelligent ghostcars
Malte Bayer <mbayer@neo-soft.org>
parents: 102
diff changeset
415 except KeyboardInterrupt:
52fd4283cd2c added learn and teach modes for intelligent ghostcars
Malte Bayer <mbayer@neo-soft.org>
parents: 102
diff changeset
416 print "resetting"
52fd4283cd2c added learn and teach modes for intelligent ghostcars
Malte Bayer <mbayer@neo-soft.org>
parents: 102
diff changeset
417 cli.box.speedminimum(slot, 0 )
52fd4283cd2c added learn and teach modes for intelligent ghostcars
Malte Bayer <mbayer@neo-soft.org>
parents: 102
diff changeset
418 cli.box.speedminimum(slot, 0 )
52fd4283cd2c added learn and teach modes for intelligent ghostcars
Malte Bayer <mbayer@neo-soft.org>
parents: 102
diff changeset
419 sys.exit(0)
52fd4283cd2c added learn and teach modes for intelligent ghostcars
Malte Bayer <mbayer@neo-soft.org>
parents: 102
diff changeset
420
52fd4283cd2c added learn and teach modes for intelligent ghostcars
Malte Bayer <mbayer@neo-soft.org>
parents: 102
diff changeset
421
74
173d0863a804 added live init to slotcli
Malte Bayer <mbayer@neo-soft.org>
parents: 61
diff changeset
422
54
68eca8057d68 added livemode display to slotcli, without communication yet
Malte Bayer <mbayer@neo-soft.org>
parents: 50
diff changeset
423 def monitor(self):
27
3e617fcf999a added exception, started SlotCli class
Malte Bayer <mbayer@neo-soft.org>
parents: 25
diff changeset
424 """
54
68eca8057d68 added livemode display to slotcli, without communication yet
Malte Bayer <mbayer@neo-soft.org>
parents: 50
diff changeset
425 Live Monitor on the console
27
3e617fcf999a added exception, started SlotCli class
Malte Bayer <mbayer@neo-soft.org>
parents: 25
diff changeset
426 Keyboard loop to control it???
3e617fcf999a added exception, started SlotCli class
Malte Bayer <mbayer@neo-soft.org>
parents: 25
diff changeset
427 """
77
cede78304992 finished live CLI, BB firmware improvements and fixes
Malte Bayer <mbayer@neo-soft.org>
parents: 74
diff changeset
428 # clear garbage in UART rx buffer
86
79fb119cf3c3 added test option without communication
Malte Bayer <mbayer@neo-soft.org>
parents: 85
diff changeset
429 while self.box.readline() != "": pass
77
cede78304992 finished live CLI, BB firmware improvements and fixes
Malte Bayer <mbayer@neo-soft.org>
parents: 74
diff changeset
430
74
173d0863a804 added live init to slotcli
Malte Bayer <mbayer@neo-soft.org>
parents: 61
diff changeset
431 self.monitor_init()
54
68eca8057d68 added livemode display to slotcli, without communication yet
Malte Bayer <mbayer@neo-soft.org>
parents: 50
diff changeset
432 self.scr = curses.initscr()
68eca8057d68 added livemode display to slotcli, without communication yet
Malte Bayer <mbayer@neo-soft.org>
parents: 50
diff changeset
433 curses.start_color()
68eca8057d68 added livemode display to slotcli, without communication yet
Malte Bayer <mbayer@neo-soft.org>
parents: 50
diff changeset
434 curses.init_pair(1, curses.COLOR_WHITE, curses.COLOR_BLACK) # standard text
68eca8057d68 added livemode display to slotcli, without communication yet
Malte Bayer <mbayer@neo-soft.org>
parents: 50
diff changeset
435 curses.init_pair(2, curses.COLOR_WHITE, curses.COLOR_BLUE) # label
116
c2fc650cc48f added option to disable freeslot fuel logic
Malte Bayer <mbayer@neo-soft.org>
parents: 115
diff changeset
436 curses.init_pair(9, curses.COLOR_WHITE, curses.COLOR_RED) # ATTENTION
93
ee4f9b8a36e9 improved live display with colors
Malte Bayer <mbayer@neo-soft.org>
parents: 90
diff changeset
437 curses.init_pair(11, curses.COLOR_BLACK, curses.COLOR_YELLOW) # player 1 slot
ee4f9b8a36e9 improved live display with colors
Malte Bayer <mbayer@neo-soft.org>
parents: 90
diff changeset
438 curses.init_pair(12, curses.COLOR_BLACK, curses.COLOR_GREEN) # player 2 slot
ee4f9b8a36e9 improved live display with colors
Malte Bayer <mbayer@neo-soft.org>
parents: 90
diff changeset
439 curses.init_pair(13, curses.COLOR_BLACK, curses.COLOR_RED) # player 3 slot
ee4f9b8a36e9 improved live display with colors
Malte Bayer <mbayer@neo-soft.org>
parents: 90
diff changeset
440 curses.init_pair(14, curses.COLOR_BLACK, curses.COLOR_MAGENTA) # player 4 slot
ee4f9b8a36e9 improved live display with colors
Malte Bayer <mbayer@neo-soft.org>
parents: 90
diff changeset
441 curses.init_pair(15, curses.COLOR_WHITE, curses.COLOR_BLACK) # player 5 slot
ee4f9b8a36e9 improved live display with colors
Malte Bayer <mbayer@neo-soft.org>
parents: 90
diff changeset
442 curses.init_pair(16, curses.COLOR_WHITE, curses.COLOR_BLACK) # player 6 slot
54
68eca8057d68 added livemode display to slotcli, without communication yet
Malte Bayer <mbayer@neo-soft.org>
parents: 50
diff changeset
443 curses.noecho() # disable key echo
68eca8057d68 added livemode display to slotcli, without communication yet
Malte Bayer <mbayer@neo-soft.org>
parents: 50
diff changeset
444 curses.cbreak() # do not buffer keypresses
68eca8057d68 added livemode display to slotcli, without communication yet
Malte Bayer <mbayer@neo-soft.org>
parents: 50
diff changeset
445 self.scr.keypad(1) # enable special keys
68eca8057d68 added livemode display to slotcli, without communication yet
Malte Bayer <mbayer@neo-soft.org>
parents: 50
diff changeset
446 self.scr.nodelay(1) # disable delay on readkey
68eca8057d68 added livemode display to slotcli, without communication yet
Malte Bayer <mbayer@neo-soft.org>
parents: 50
diff changeset
447
59
361bc4602cf7 added fuel management to blackbox, cars dont get stuck at the moment
Malte Bayer <mbayer@neo-soft.org>
parents: 56
diff changeset
448 self.cleartop()
55
9293f3efcc06 added live display to CLI (lap counter, last and best time)
Malte Bayer <mbayer@neo-soft.org>
parents: 54
diff changeset
449 self.render_slots()
9293f3efcc06 added live display to CLI (lap counter, last and best time)
Malte Bayer <mbayer@neo-soft.org>
parents: 54
diff changeset
450 self.scr.refresh()
9293f3efcc06 added live display to CLI (lap counter, last and best time)
Malte Bayer <mbayer@neo-soft.org>
parents: 54
diff changeset
451
9293f3efcc06 added live display to CLI (lap counter, last and best time)
Malte Bayer <mbayer@neo-soft.org>
parents: 54
diff changeset
452
54
68eca8057d68 added livemode display to slotcli, without communication yet
Malte Bayer <mbayer@neo-soft.org>
parents: 50
diff changeset
453 while 1:
68eca8057d68 added livemode display to slotcli, without communication yet
Malte Bayer <mbayer@neo-soft.org>
parents: 50
diff changeset
454 key = self.scr.getch()
116
c2fc650cc48f added option to disable freeslot fuel logic
Malte Bayer <mbayer@neo-soft.org>
parents: 115
diff changeset
455 if key == ord('q'): break
89
4b5b4c7ba03d added panic mode, shortcircuit can be resumed now
Malte Bayer <mbayer@neo-soft.org>
parents: 87
diff changeset
456 elif key == ord(' '): self.box.query("+") # panic / resume
118
9d5456cf6dad new hotkey 'f' to toggle freerun mode
Malte Bayer <mbayer@neo-soft.org>
parents: 117
diff changeset
457 elif key == 10:
9d5456cf6dad new hotkey 'f' to toggle freerun mode
Malte Bayer <mbayer@neo-soft.org>
parents: 117
diff changeset
458 self.freerun = False
9d5456cf6dad new hotkey 'f' to toggle freerun mode
Malte Bayer <mbayer@neo-soft.org>
parents: 117
diff changeset
459 self.box.query("#") # remote start button press
116
c2fc650cc48f added option to disable freeslot fuel logic
Malte Bayer <mbayer@neo-soft.org>
parents: 115
diff changeset
460
54
68eca8057d68 added livemode display to slotcli, without communication yet
Malte Bayer <mbayer@neo-soft.org>
parents: 50
diff changeset
461 elif key == ord('1'): self.readName(0)
68eca8057d68 added livemode display to slotcli, without communication yet
Malte Bayer <mbayer@neo-soft.org>
parents: 50
diff changeset
462 elif key == ord('2'): self.readName(1)
68eca8057d68 added livemode display to slotcli, without communication yet
Malte Bayer <mbayer@neo-soft.org>
parents: 50
diff changeset
463 elif key == ord('3'): self.readName(2)
68eca8057d68 added livemode display to slotcli, without communication yet
Malte Bayer <mbayer@neo-soft.org>
parents: 50
diff changeset
464 elif key == ord('4'): self.readName(3)
68eca8057d68 added livemode display to slotcli, without communication yet
Malte Bayer <mbayer@neo-soft.org>
parents: 50
diff changeset
465 elif key == ord('5'): self.readName(4)
68eca8057d68 added livemode display to slotcli, without communication yet
Malte Bayer <mbayer@neo-soft.org>
parents: 50
diff changeset
466 elif key == ord('6'): self.readName(5)
115
bb150048d329 added player profiles
Malte Bayer <mbayer@neo-soft.org>
parents: 113
diff changeset
467 #elif key == ord('q'): self.readLimit(0)
bb150048d329 added player profiles
Malte Bayer <mbayer@neo-soft.org>
parents: 113
diff changeset
468 #elif key == ord('w'): self.readLimit(1)
bb150048d329 added player profiles
Malte Bayer <mbayer@neo-soft.org>
parents: 113
diff changeset
469 #elif key == ord('e'): self.readLimit(2)
bb150048d329 added player profiles
Malte Bayer <mbayer@neo-soft.org>
parents: 113
diff changeset
470 #elif key == ord('r'): self.readLimit(3)
bb150048d329 added player profiles
Malte Bayer <mbayer@neo-soft.org>
parents: 113
diff changeset
471 #elif key == ord('t'): self.readLimit(4)
bb150048d329 added player profiles
Malte Bayer <mbayer@neo-soft.org>
parents: 113
diff changeset
472 #elif key == ord('z'): self.readLimit(5)
137
94d71156517b added textfile event logger
Malte Bayer <mbayer@neo-soft.org>
parents: 124
diff changeset
473 elif key == ord('n'): self.readRaceName()
55
9293f3efcc06 added live display to CLI (lap counter, last and best time)
Malte Bayer <mbayer@neo-soft.org>
parents: 54
diff changeset
474 elif key == ord('a'):
9293f3efcc06 added live display to CLI (lap counter, last and best time)
Malte Bayer <mbayer@neo-soft.org>
parents: 54
diff changeset
475 if self.slot[4]["drive"] > 0: self.slot[4]["drive"] -= 1
9293f3efcc06 added live display to CLI (lap counter, last and best time)
Malte Bayer <mbayer@neo-soft.org>
parents: 54
diff changeset
476 cli.box.speedminimum(4, self.slot[4]["drive"])
9293f3efcc06 added live display to CLI (lap counter, last and best time)
Malte Bayer <mbayer@neo-soft.org>
parents: 54
diff changeset
477 elif key == ord('s'):
9293f3efcc06 added live display to CLI (lap counter, last and best time)
Malte Bayer <mbayer@neo-soft.org>
parents: 54
diff changeset
478 if self.slot[4]["drive"] < 16: self.slot[4]["drive"] += 1
9293f3efcc06 added live display to CLI (lap counter, last and best time)
Malte Bayer <mbayer@neo-soft.org>
parents: 54
diff changeset
479 cli.box.speedminimum(4, self.slot[4]["drive"])
9293f3efcc06 added live display to CLI (lap counter, last and best time)
Malte Bayer <mbayer@neo-soft.org>
parents: 54
diff changeset
480 elif key == ord('y'):
9293f3efcc06 added live display to CLI (lap counter, last and best time)
Malte Bayer <mbayer@neo-soft.org>
parents: 54
diff changeset
481 if self.slot[5]["drive"] > 0: self.slot[5]["drive"] -= 1
9293f3efcc06 added live display to CLI (lap counter, last and best time)
Malte Bayer <mbayer@neo-soft.org>
parents: 54
diff changeset
482 cli.box.speedminimum(5, self.slot[5]["drive"])
9293f3efcc06 added live display to CLI (lap counter, last and best time)
Malte Bayer <mbayer@neo-soft.org>
parents: 54
diff changeset
483 elif key == ord('x'):
9293f3efcc06 added live display to CLI (lap counter, last and best time)
Malte Bayer <mbayer@neo-soft.org>
parents: 54
diff changeset
484 if self.slot[5]["drive"] < 16: self.slot[5]["drive"] += 1
113
b2d91fd5d926 #721: fix typo
Malte Bayer <mbayer@neo-soft.org>
parents: 112
diff changeset
485 cli.box.speedminimum(5, self.slot[5]["drive"])
94
c7ff8cde6b1e improved live display with colors
Malte Bayer <mbayer@neo-soft.org>
parents: 93
diff changeset
486 elif key == ord('t'):
c7ff8cde6b1e improved live display with colors
Malte Bayer <mbayer@neo-soft.org>
parents: 93
diff changeset
487 tmp = self.readInt("Set new Race TIME limit", self.timelimit)
c7ff8cde6b1e improved live display with colors
Malte Bayer <mbayer@neo-soft.org>
parents: 93
diff changeset
488 if tmp: self.timelimit = tmp
115
bb150048d329 added player profiles
Malte Bayer <mbayer@neo-soft.org>
parents: 113
diff changeset
489 self.cleartop()
94
c7ff8cde6b1e improved live display with colors
Malte Bayer <mbayer@neo-soft.org>
parents: 93
diff changeset
490 elif key == ord('l'):
c7ff8cde6b1e improved live display with colors
Malte Bayer <mbayer@neo-soft.org>
parents: 93
diff changeset
491 tmp = self.readInt("Set new Race LAP limit", self.laplimit)
c7ff8cde6b1e improved live display with colors
Malte Bayer <mbayer@neo-soft.org>
parents: 93
diff changeset
492 if tmp: self.laplimit = tmp
115
bb150048d329 added player profiles
Malte Bayer <mbayer@neo-soft.org>
parents: 113
diff changeset
493 self.cleartop()
bb150048d329 added player profiles
Malte Bayer <mbayer@neo-soft.org>
parents: 113
diff changeset
494 elif key == ord('/'):
bb150048d329 added player profiles
Malte Bayer <mbayer@neo-soft.org>
parents: 113
diff changeset
495 for slot in range(5):
bb150048d329 added player profiles
Malte Bayer <mbayer@neo-soft.org>
parents: 113
diff changeset
496 self.flash_car_settings(slot)
118
9d5456cf6dad new hotkey 'f' to toggle freerun mode
Malte Bayer <mbayer@neo-soft.org>
parents: 117
diff changeset
497 elif key == ord('f'):
9d5456cf6dad new hotkey 'f' to toggle freerun mode
Malte Bayer <mbayer@neo-soft.org>
parents: 117
diff changeset
498 # set freerun mode manually (abort race)
9d5456cf6dad new hotkey 'f' to toggle freerun mode
Malte Bayer <mbayer@neo-soft.org>
parents: 117
diff changeset
499 self.freerun = not self.freerun
54
68eca8057d68 added livemode display to slotcli, without communication yet
Malte Bayer <mbayer@neo-soft.org>
parents: 50
diff changeset
500
55
9293f3efcc06 added live display to CLI (lap counter, last and best time)
Malte Bayer <mbayer@neo-soft.org>
parents: 54
diff changeset
501
9293f3efcc06 added live display to CLI (lap counter, last and best time)
Malte Bayer <mbayer@neo-soft.org>
parents: 54
diff changeset
502 # is there something in the rx buffer?
86
79fb119cf3c3 added test option without communication
Malte Bayer <mbayer@neo-soft.org>
parents: 85
diff changeset
503 rx = self.box.readline()
87
761863c71884 added empty lines between live data display entries
Malte Bayer <mbayer@neo-soft.org>
parents: 86
diff changeset
504 if (rx != "") or self.test:
123
ec623e5fcbca firmware fix: only fuel to 100% once in pitlane
Malte Bayer <mbayer@neo-soft.org>
parents: 122
diff changeset
505 self.scr.addstr(17,3,
ec623e5fcbca firmware fix: only fuel to 100% once in pitlane
Malte Bayer <mbayer@neo-soft.org>
parents: 122
diff changeset
506 "RX: %19s" % rx, curses.color_pair(2))
99
434d60dc9b12 fix winning position display
paepke
parents: 97
diff changeset
507 self.scr.redrawwin()
77
cede78304992 finished live CLI, BB firmware improvements and fixes
Malte Bayer <mbayer@neo-soft.org>
parents: 74
diff changeset
508 self.scr.refresh()
55
9293f3efcc06 added live display to CLI (lap counter, last and best time)
Malte Bayer <mbayer@neo-soft.org>
parents: 54
diff changeset
509 # we have received something
85
a637228562a7 added exception drop in uart rx tree
Malte Bayer <mbayer@neo-soft.org>
parents: 82
diff changeset
510 try:
a637228562a7 added exception drop in uart rx tree
Malte Bayer <mbayer@neo-soft.org>
parents: 82
diff changeset
511 data = rx.split(":")
a637228562a7 added exception drop in uart rx tree
Malte Bayer <mbayer@neo-soft.org>
parents: 82
diff changeset
512 if rx[:2] == "L:":
a637228562a7 added exception drop in uart rx tree
Malte Bayer <mbayer@neo-soft.org>
parents: 82
diff changeset
513 # update lap time info
a637228562a7 added exception drop in uart rx tree
Malte Bayer <mbayer@neo-soft.org>
parents: 82
diff changeset
514 l = int(data[2], 16)
a637228562a7 added exception drop in uart rx tree
Malte Bayer <mbayer@neo-soft.org>
parents: 82
diff changeset
515 slot = int(data[3]) - 1
a637228562a7 added exception drop in uart rx tree
Malte Bayer <mbayer@neo-soft.org>
parents: 82
diff changeset
516 t = int(data[4], 16) / 2000.00
a637228562a7 added exception drop in uart rx tree
Malte Bayer <mbayer@neo-soft.org>
parents: 82
diff changeset
517 self.sysclk = int(data[5], 16) / 2000.00
95
85c4a4da2ffd added winning ability ;)
Malte Bayer <mbayer@neo-soft.org>
parents: 94
diff changeset
518 self.slot[slot]["laps_last"] = self.slot[slot]["laps"]
85
a637228562a7 added exception drop in uart rx tree
Malte Bayer <mbayer@neo-soft.org>
parents: 82
diff changeset
519 self.slot[slot]["laps"] = l
a637228562a7 added exception drop in uart rx tree
Malte Bayer <mbayer@neo-soft.org>
parents: 82
diff changeset
520 self.slot[slot]["last"] = t
a637228562a7 added exception drop in uart rx tree
Malte Bayer <mbayer@neo-soft.org>
parents: 82
diff changeset
521 self.slot[slot]["clk"] = self.sysclk
a637228562a7 added exception drop in uart rx tree
Malte Bayer <mbayer@neo-soft.org>
parents: 82
diff changeset
522 if (self.slot[slot]["best"] > t) or (self.slot[slot]["best"] == 0):
a637228562a7 added exception drop in uart rx tree
Malte Bayer <mbayer@neo-soft.org>
parents: 82
diff changeset
523 self.slot[slot]["best"] = t
a637228562a7 added exception drop in uart rx tree
Malte Bayer <mbayer@neo-soft.org>
parents: 82
diff changeset
524 if self.bestlap > t:
120
049478896193 hotfixes
Malte Bayer <mbayer@neo-soft.org>
parents: 118
diff changeset
525 if self.freerun:
049478896193 hotfixes
Malte Bayer <mbayer@neo-soft.org>
parents: 118
diff changeset
526 trigger_event("lap_record", slot + 1)
85
a637228562a7 added exception drop in uart rx tree
Malte Bayer <mbayer@neo-soft.org>
parents: 82
diff changeset
527 self.bestlap = t
78
d9126a55295c added sound triggers to live mode
Malte Bayer <mbayer@neo-soft.org>
parents: 77
diff changeset
528
85
a637228562a7 added exception drop in uart rx tree
Malte Bayer <mbayer@neo-soft.org>
parents: 82
diff changeset
529 self.slot[slot]["status"] = "IN-RACE"
95
85c4a4da2ffd added winning ability ;)
Malte Bayer <mbayer@neo-soft.org>
parents: 94
diff changeset
530 if (self.slot[slot]["laps_last"] != l) and (l == self.laplimit):
85c4a4da2ffd added winning ability ;)
Malte Bayer <mbayer@neo-soft.org>
parents: 94
diff changeset
531 # we have lap limit reached!
112
fee43a74bed6 added controller number to event scripts parameter 1
Malte Bayer <mbayer@neo-soft.org>
parents: 111
diff changeset
532 trigger_event("win", slot + 1)
97
9a01c57147db final corrections
Malte Bayer <mbayer@neo-soft.org>
parents: 96
diff changeset
533 self.raceactive = False
95
85c4a4da2ffd added winning ability ;)
Malte Bayer <mbayer@neo-soft.org>
parents: 94
diff changeset
534 self.slot[slot]["status"] = "WINNER!"
85c4a4da2ffd added winning ability ;)
Malte Bayer <mbayer@neo-soft.org>
parents: 94
diff changeset
535 self.box.query("+") # stop race
85c4a4da2ffd added winning ability ;)
Malte Bayer <mbayer@neo-soft.org>
parents: 94
diff changeset
536
137
94d71156517b added textfile event logger
Malte Bayer <mbayer@neo-soft.org>
parents: 124
diff changeset
537 tmpname = "n/a"
94d71156517b added textfile event logger
Malte Bayer <mbayer@neo-soft.org>
parents: 124
diff changeset
538 if not self.freerun:
94d71156517b added textfile event logger
Malte Bayer <mbayer@neo-soft.org>
parents: 124
diff changeset
539 tmpname = self.raceName
94d71156517b added textfile event logger
Malte Bayer <mbayer@neo-soft.org>
parents: 124
diff changeset
540 self.log.push([
94d71156517b added textfile event logger
Malte Bayer <mbayer@neo-soft.org>
parents: 124
diff changeset
541 time(),
94d71156517b added textfile event logger
Malte Bayer <mbayer@neo-soft.org>
parents: 124
diff changeset
542 self.sysclk,
94d71156517b added textfile event logger
Malte Bayer <mbayer@neo-soft.org>
parents: 124
diff changeset
543 tmpname,
94d71156517b added textfile event logger
Malte Bayer <mbayer@neo-soft.org>
parents: 124
diff changeset
544 slot,
94d71156517b added textfile event logger
Malte Bayer <mbayer@neo-soft.org>
parents: 124
diff changeset
545 self.slot[slot]["name"],
94d71156517b added textfile event logger
Malte Bayer <mbayer@neo-soft.org>
parents: 124
diff changeset
546 l,
94d71156517b added textfile event logger
Malte Bayer <mbayer@neo-soft.org>
parents: 124
diff changeset
547 t,
94d71156517b added textfile event logger
Malte Bayer <mbayer@neo-soft.org>
parents: 124
diff changeset
548 self.slot[slot]["best"],
94d71156517b added textfile event logger
Malte Bayer <mbayer@neo-soft.org>
parents: 124
diff changeset
549 self.laplimit,
94d71156517b added textfile event logger
Malte Bayer <mbayer@neo-soft.org>
parents: 124
diff changeset
550 self.timelimit
94d71156517b added textfile event logger
Malte Bayer <mbayer@neo-soft.org>
parents: 124
diff changeset
551 ])
94d71156517b added textfile event logger
Malte Bayer <mbayer@neo-soft.org>
parents: 124
diff changeset
552
94d71156517b added textfile event logger
Malte Bayer <mbayer@neo-soft.org>
parents: 124
diff changeset
553
85
a637228562a7 added exception drop in uart rx tree
Malte Bayer <mbayer@neo-soft.org>
parents: 82
diff changeset
554 self.render_slots()
55
9293f3efcc06 added live display to CLI (lap counter, last and best time)
Malte Bayer <mbayer@neo-soft.org>
parents: 54
diff changeset
555
85
a637228562a7 added exception drop in uart rx tree
Malte Bayer <mbayer@neo-soft.org>
parents: 82
diff changeset
556 if rx[:2] == "F:":
a637228562a7 added exception drop in uart rx tree
Malte Bayer <mbayer@neo-soft.org>
parents: 82
diff changeset
557 # update fuel level
a637228562a7 added exception drop in uart rx tree
Malte Bayer <mbayer@neo-soft.org>
parents: 82
diff changeset
558 slot = int(data[1])
a637228562a7 added exception drop in uart rx tree
Malte Bayer <mbayer@neo-soft.org>
parents: 82
diff changeset
559 f = int(data[2], 16)
a637228562a7 added exception drop in uart rx tree
Malte Bayer <mbayer@neo-soft.org>
parents: 82
diff changeset
560 f = f / 100 # fuel in percent
a637228562a7 added exception drop in uart rx tree
Malte Bayer <mbayer@neo-soft.org>
parents: 82
diff changeset
561 self.sysclk = int(data[3], 16) / 2000.00
a637228562a7 added exception drop in uart rx tree
Malte Bayer <mbayer@neo-soft.org>
parents: 82
diff changeset
562 self.slot[slot]["fuel_last"] = self.slot[slot]["fuel"]
a637228562a7 added exception drop in uart rx tree
Malte Bayer <mbayer@neo-soft.org>
parents: 82
diff changeset
563 self.slot[slot]["fuel"] = f
a637228562a7 added exception drop in uart rx tree
Malte Bayer <mbayer@neo-soft.org>
parents: 82
diff changeset
564 if self.slot[slot]["fuel_last"] != f:
97
9a01c57147db final corrections
Malte Bayer <mbayer@neo-soft.org>
parents: 96
diff changeset
565 if (self.slot[slot]["fuel_last"] == 16) and (f == 15):
9a01c57147db final corrections
Malte Bayer <mbayer@neo-soft.org>
parents: 96
diff changeset
566 # 15 percent fuel, set speed limit for car to 8
85
a637228562a7 added exception drop in uart rx tree
Malte Bayer <mbayer@neo-soft.org>
parents: 82
diff changeset
567 # warning sound
112
fee43a74bed6 added controller number to event scripts parameter 1
Malte Bayer <mbayer@neo-soft.org>
parents: 111
diff changeset
568 trigger_event("fuel_warning1", slot + 1)
85
a637228562a7 added exception drop in uart rx tree
Malte Bayer <mbayer@neo-soft.org>
parents: 82
diff changeset
569 cli.box.speedlimit(slot, 8)
a637228562a7 added exception drop in uart rx tree
Malte Bayer <mbayer@neo-soft.org>
parents: 82
diff changeset
570 if (self.slot[slot]["fuel_last"] == 6) and (f == 5):
97
9a01c57147db final corrections
Malte Bayer <mbayer@neo-soft.org>
parents: 96
diff changeset
571 # 5 percent, set speed limit for car to 6
85
a637228562a7 added exception drop in uart rx tree
Malte Bayer <mbayer@neo-soft.org>
parents: 82
diff changeset
572 # warning sound
112
fee43a74bed6 added controller number to event scripts parameter 1
Malte Bayer <mbayer@neo-soft.org>
parents: 111
diff changeset
573 trigger_event("fuel_warning2", slot + 1)
97
9a01c57147db final corrections
Malte Bayer <mbayer@neo-soft.org>
parents: 96
diff changeset
574 cli.box.speedlimit(slot, 6)
85
a637228562a7 added exception drop in uart rx tree
Malte Bayer <mbayer@neo-soft.org>
parents: 82
diff changeset
575 if (self.slot[slot]["fuel_last"] == 1) and (f == 0):
a637228562a7 added exception drop in uart rx tree
Malte Bayer <mbayer@neo-soft.org>
parents: 82
diff changeset
576 # fuel empty
97
9a01c57147db final corrections
Malte Bayer <mbayer@neo-soft.org>
parents: 96
diff changeset
577 # set speedlimit to 4
9a01c57147db final corrections
Malte Bayer <mbayer@neo-soft.org>
parents: 96
diff changeset
578 cli.box.speedlimit(slot, 4)
85
a637228562a7 added exception drop in uart rx tree
Malte Bayer <mbayer@neo-soft.org>
parents: 82
diff changeset
579 if (self.slot[slot]["fuel_last"] < f) and (f >= 11) and (f < 20):
a637228562a7 added exception drop in uart rx tree
Malte Bayer <mbayer@neo-soft.org>
parents: 82
diff changeset
580 cli.box.speedlimit(slot, 15)
a637228562a7 added exception drop in uart rx tree
Malte Bayer <mbayer@neo-soft.org>
parents: 82
diff changeset
581 if (self.slot[slot]["fuel_last"] < f) and (f == 100):
112
fee43a74bed6 added controller number to event scripts parameter 1
Malte Bayer <mbayer@neo-soft.org>
parents: 111
diff changeset
582 trigger_event("fuel_full", slot + 1)
85
a637228562a7 added exception drop in uart rx tree
Malte Bayer <mbayer@neo-soft.org>
parents: 82
diff changeset
583 self.render_slots()
55
9293f3efcc06 added live display to CLI (lap counter, last and best time)
Malte Bayer <mbayer@neo-soft.org>
parents: 54
diff changeset
584
85
a637228562a7 added exception drop in uart rx tree
Malte Bayer <mbayer@neo-soft.org>
parents: 82
diff changeset
585 if rx[:1] == "~":
a637228562a7 added exception drop in uart rx tree
Malte Bayer <mbayer@neo-soft.org>
parents: 82
diff changeset
586 # jumpstart occured
a637228562a7 added exception drop in uart rx tree
Malte Bayer <mbayer@neo-soft.org>
parents: 82
diff changeset
587 slot = int(rx[1:2])
a637228562a7 added exception drop in uart rx tree
Malte Bayer <mbayer@neo-soft.org>
parents: 82
diff changeset
588 t = int(data[1], 16) / 2000.00
a637228562a7 added exception drop in uart rx tree
Malte Bayer <mbayer@neo-soft.org>
parents: 82
diff changeset
589 self.slot[slot]["jumpstart"] = t
a637228562a7 added exception drop in uart rx tree
Malte Bayer <mbayer@neo-soft.org>
parents: 82
diff changeset
590 self.slot[slot]["status"] = "Jumpstart!"
77
cede78304992 finished live CLI, BB firmware improvements and fixes
Malte Bayer <mbayer@neo-soft.org>
parents: 74
diff changeset
591
85
a637228562a7 added exception drop in uart rx tree
Malte Bayer <mbayer@neo-soft.org>
parents: 82
diff changeset
592 if rx[:3] == "RW:":
a637228562a7 added exception drop in uart rx tree
Malte Bayer <mbayer@neo-soft.org>
parents: 82
diff changeset
593 # ResponseWire packet, do nothing at the moment, just decode
a637228562a7 added exception drop in uart rx tree
Malte Bayer <mbayer@neo-soft.org>
parents: 82
diff changeset
594 slot = int(data[1])
a637228562a7 added exception drop in uart rx tree
Malte Bayer <mbayer@neo-soft.org>
parents: 82
diff changeset
595 devtype = int(data[2])
a637228562a7 added exception drop in uart rx tree
Malte Bayer <mbayer@neo-soft.org>
parents: 82
diff changeset
596 sender = int(data[3], 16)
a637228562a7 added exception drop in uart rx tree
Malte Bayer <mbayer@neo-soft.org>
parents: 82
diff changeset
597 status = int(data[4], 16)
a637228562a7 added exception drop in uart rx tree
Malte Bayer <mbayer@neo-soft.org>
parents: 82
diff changeset
598 self.sysclk = int(data[5], 16)
a637228562a7 added exception drop in uart rx tree
Malte Bayer <mbayer@neo-soft.org>
parents: 82
diff changeset
599 if (devtype == 4):
a637228562a7 added exception drop in uart rx tree
Malte Bayer <mbayer@neo-soft.org>
parents: 82
diff changeset
600 # pitlane sent something
a637228562a7 added exception drop in uart rx tree
Malte Bayer <mbayer@neo-soft.org>
parents: 82
diff changeset
601 if (status == 5):
a637228562a7 added exception drop in uart rx tree
Malte Bayer <mbayer@neo-soft.org>
parents: 82
diff changeset
602 self.slot[slot]["status"] = "PITLANE"
112
fee43a74bed6 added controller number to event scripts parameter 1
Malte Bayer <mbayer@neo-soft.org>
parents: 111
diff changeset
603 trigger_event("pitlane_enter", slot + 1)
104
95b2c23cb973 pitlane checkout bug resolved, prepare for customized pitlane speedlimit
Malte Bayer <mbayer@neo-soft.org>
parents: 103
diff changeset
604 if (status == 7):
85
a637228562a7 added exception drop in uart rx tree
Malte Bayer <mbayer@neo-soft.org>
parents: 82
diff changeset
605 self.slot[slot]["status"] = "IN-RACE"
112
fee43a74bed6 added controller number to event scripts parameter 1
Malte Bayer <mbayer@neo-soft.org>
parents: 111
diff changeset
606 trigger_event("pitlane_exit", slot + 1)
77
cede78304992 finished live CLI, BB firmware improvements and fixes
Malte Bayer <mbayer@neo-soft.org>
parents: 74
diff changeset
607
85
a637228562a7 added exception drop in uart rx tree
Malte Bayer <mbayer@neo-soft.org>
parents: 82
diff changeset
608 self.render_slots()
77
cede78304992 finished live CLI, BB firmware improvements and fixes
Malte Bayer <mbayer@neo-soft.org>
parents: 74
diff changeset
609
85
a637228562a7 added exception drop in uart rx tree
Malte Bayer <mbayer@neo-soft.org>
parents: 82
diff changeset
610 if rx == "!RACE PREPARE":
a637228562a7 added exception drop in uart rx tree
Malte Bayer <mbayer@neo-soft.org>
parents: 82
diff changeset
611 # reset current race status
a637228562a7 added exception drop in uart rx tree
Malte Bayer <mbayer@neo-soft.org>
parents: 82
diff changeset
612 # and display PREPARE PHASE
a637228562a7 added exception drop in uart rx tree
Malte Bayer <mbayer@neo-soft.org>
parents: 82
diff changeset
613 self.reset_slots()
a637228562a7 added exception drop in uart rx tree
Malte Bayer <mbayer@neo-soft.org>
parents: 82
diff changeset
614 for slot in range(MAXSLOTS):
a637228562a7 added exception drop in uart rx tree
Malte Bayer <mbayer@neo-soft.org>
parents: 82
diff changeset
615 self.slot[slot]["status"] = "Prepare"
107
efdf471642f5 added custom event scripts
Malte Bayer <mbayer@neo-soft.org>
parents: 106
diff changeset
616 trigger_event("race_prepare")
85
a637228562a7 added exception drop in uart rx tree
Malte Bayer <mbayer@neo-soft.org>
parents: 82
diff changeset
617
a637228562a7 added exception drop in uart rx tree
Malte Bayer <mbayer@neo-soft.org>
parents: 82
diff changeset
618 if rx == "!RACE START":
a637228562a7 added exception drop in uart rx tree
Malte Bayer <mbayer@neo-soft.org>
parents: 82
diff changeset
619 for slot in range(MAXSLOTS):
a637228562a7 added exception drop in uart rx tree
Malte Bayer <mbayer@neo-soft.org>
parents: 82
diff changeset
620 if self.slot[slot]["status"] == "~~~~~~~~~~":
a637228562a7 added exception drop in uart rx tree
Malte Bayer <mbayer@neo-soft.org>
parents: 82
diff changeset
621 self.slot[slot]["status"] = "Idle"
107
efdf471642f5 added custom event scripts
Malte Bayer <mbayer@neo-soft.org>
parents: 106
diff changeset
622 trigger_event("race_start")
97
9a01c57147db final corrections
Malte Bayer <mbayer@neo-soft.org>
parents: 96
diff changeset
623 self.raceactive = True
77
cede78304992 finished live CLI, BB firmware improvements and fixes
Malte Bayer <mbayer@neo-soft.org>
parents: 74
diff changeset
624
85
a637228562a7 added exception drop in uart rx tree
Malte Bayer <mbayer@neo-soft.org>
parents: 82
diff changeset
625 if rx == "!COUNTDOWN":
a637228562a7 added exception drop in uart rx tree
Malte Bayer <mbayer@neo-soft.org>
parents: 82
diff changeset
626 # countdown initiated
a637228562a7 added exception drop in uart rx tree
Malte Bayer <mbayer@neo-soft.org>
parents: 82
diff changeset
627 for slot in range(MAXSLOTS):
a637228562a7 added exception drop in uart rx tree
Malte Bayer <mbayer@neo-soft.org>
parents: 82
diff changeset
628 self.slot[slot]["status"] = "~~~~~~~~~~"
107
efdf471642f5 added custom event scripts
Malte Bayer <mbayer@neo-soft.org>
parents: 106
diff changeset
629 trigger_event("countdown_start")
77
cede78304992 finished live CLI, BB firmware improvements and fixes
Malte Bayer <mbayer@neo-soft.org>
parents: 74
diff changeset
630
89
4b5b4c7ba03d added panic mode, shortcircuit can be resumed now
Malte Bayer <mbayer@neo-soft.org>
parents: 87
diff changeset
631 if rx == "!PANIC":
4b5b4c7ba03d added panic mode, shortcircuit can be resumed now
Malte Bayer <mbayer@neo-soft.org>
parents: 87
diff changeset
632 # panic mode
107
efdf471642f5 added custom event scripts
Malte Bayer <mbayer@neo-soft.org>
parents: 106
diff changeset
633 trigger_event("panic")
89
4b5b4c7ba03d added panic mode, shortcircuit can be resumed now
Malte Bayer <mbayer@neo-soft.org>
parents: 87
diff changeset
634
4b5b4c7ba03d added panic mode, shortcircuit can be resumed now
Malte Bayer <mbayer@neo-soft.org>
parents: 87
diff changeset
635 if rx == "!SHORTCUT":
4b5b4c7ba03d added panic mode, shortcircuit can be resumed now
Malte Bayer <mbayer@neo-soft.org>
parents: 87
diff changeset
636 # panic mode
107
efdf471642f5 added custom event scripts
Malte Bayer <mbayer@neo-soft.org>
parents: 106
diff changeset
637 trigger_event("panic_shortcut")
89
4b5b4c7ba03d added panic mode, shortcircuit can be resumed now
Malte Bayer <mbayer@neo-soft.org>
parents: 87
diff changeset
638
4b5b4c7ba03d added panic mode, shortcircuit can be resumed now
Malte Bayer <mbayer@neo-soft.org>
parents: 87
diff changeset
639 if rx == "!RESUME":
4b5b4c7ba03d added panic mode, shortcircuit can be resumed now
Malte Bayer <mbayer@neo-soft.org>
parents: 87
diff changeset
640 # panic mode
107
efdf471642f5 added custom event scripts
Malte Bayer <mbayer@neo-soft.org>
parents: 106
diff changeset
641 trigger_event("resume")
89
4b5b4c7ba03d added panic mode, shortcircuit can be resumed now
Malte Bayer <mbayer@neo-soft.org>
parents: 87
diff changeset
642
4b5b4c7ba03d added panic mode, shortcircuit can be resumed now
Malte Bayer <mbayer@neo-soft.org>
parents: 87
diff changeset
643
97
9a01c57147db final corrections
Malte Bayer <mbayer@neo-soft.org>
parents: 96
diff changeset
644 if ((self.timelimit > 0) and (self.raceactive) and
9a01c57147db final corrections
Malte Bayer <mbayer@neo-soft.org>
parents: 96
diff changeset
645 (self.sysclk_last != self.sysclk) and
9a01c57147db final corrections
Malte Bayer <mbayer@neo-soft.org>
parents: 96
diff changeset
646 ((self.sysclk / 60) >= self.timelimit)):
96
bcba10c35f09 added test option without communication
Malte Bayer <mbayer@neo-soft.org>
parents: 95
diff changeset
647 self.sysclk_last = self.sysclk
97
9a01c57147db final corrections
Malte Bayer <mbayer@neo-soft.org>
parents: 96
diff changeset
648 self.raceactive = False
96
bcba10c35f09 added test option without communication
Malte Bayer <mbayer@neo-soft.org>
parents: 95
diff changeset
649 # we have time limit reached!
97
9a01c57147db final corrections
Malte Bayer <mbayer@neo-soft.org>
parents: 96
diff changeset
650 self.box.query("+") # stop race
107
efdf471642f5 added custom event scripts
Malte Bayer <mbayer@neo-soft.org>
parents: 106
diff changeset
651 trigger_event("win")
96
bcba10c35f09 added test option without communication
Malte Bayer <mbayer@neo-soft.org>
parents: 95
diff changeset
652 # get the one with position 1
bcba10c35f09 added test option without communication
Malte Bayer <mbayer@neo-soft.org>
parents: 95
diff changeset
653 for slot in self.slots:
bcba10c35f09 added test option without communication
Malte Bayer <mbayer@neo-soft.org>
parents: 95
diff changeset
654 if slot["position"] == 1:
bcba10c35f09 added test option without communication
Malte Bayer <mbayer@neo-soft.org>
parents: 95
diff changeset
655 slot["status"] = "WINNER!"
120
049478896193 hotfixes
Malte Bayer <mbayer@neo-soft.org>
parents: 118
diff changeset
656 self.render_slots()
96
bcba10c35f09 added test option without communication
Malte Bayer <mbayer@neo-soft.org>
parents: 95
diff changeset
657 self.sysclk_last = self.sysclk
120
049478896193 hotfixes
Malte Bayer <mbayer@neo-soft.org>
parents: 118
diff changeset
658
95
85c4a4da2ffd added winning ability ;)
Malte Bayer <mbayer@neo-soft.org>
parents: 94
diff changeset
659
89
4b5b4c7ba03d added panic mode, shortcircuit can be resumed now
Malte Bayer <mbayer@neo-soft.org>
parents: 87
diff changeset
660
87
761863c71884 added empty lines between live data display entries
Malte Bayer <mbayer@neo-soft.org>
parents: 86
diff changeset
661 self.scr.addstr(17,31,
85
a637228562a7 added exception drop in uart rx tree
Malte Bayer <mbayer@neo-soft.org>
parents: 82
diff changeset
662 "Race Timer: %7.3f min" % (self.sysclk / 60),
a637228562a7 added exception drop in uart rx tree
Malte Bayer <mbayer@neo-soft.org>
parents: 82
diff changeset
663 curses.color_pair(2))
77
cede78304992 finished live CLI, BB firmware improvements and fixes
Malte Bayer <mbayer@neo-soft.org>
parents: 74
diff changeset
664
120
049478896193 hotfixes
Malte Bayer <mbayer@neo-soft.org>
parents: 118
diff changeset
665 tmpmode = "RACE MODE (LAPS)"
049478896193 hotfixes
Malte Bayer <mbayer@neo-soft.org>
parents: 118
diff changeset
666 if self.freerun:
049478896193 hotfixes
Malte Bayer <mbayer@neo-soft.org>
parents: 118
diff changeset
667 tmpmode = "FREERUN (BEST)"
049478896193 hotfixes
Malte Bayer <mbayer@neo-soft.org>
parents: 118
diff changeset
668 self.scr.addstr(18,31,
049478896193 hotfixes
Malte Bayer <mbayer@neo-soft.org>
parents: 118
diff changeset
669 "%19s" % tmpmode, curses.color_pair(2))
049478896193 hotfixes
Malte Bayer <mbayer@neo-soft.org>
parents: 118
diff changeset
670
85
a637228562a7 added exception drop in uart rx tree
Malte Bayer <mbayer@neo-soft.org>
parents: 82
diff changeset
671 self.scr.refresh()
77
cede78304992 finished live CLI, BB firmware improvements and fixes
Malte Bayer <mbayer@neo-soft.org>
parents: 74
diff changeset
672
85
a637228562a7 added exception drop in uart rx tree
Malte Bayer <mbayer@neo-soft.org>
parents: 82
diff changeset
673 except Exception:
107
efdf471642f5 added custom event scripts
Malte Bayer <mbayer@neo-soft.org>
parents: 106
diff changeset
674 trigger_event("data_error")
85
a637228562a7 added exception drop in uart rx tree
Malte Bayer <mbayer@neo-soft.org>
parents: 82
diff changeset
675 pass
54
68eca8057d68 added livemode display to slotcli, without communication yet
Malte Bayer <mbayer@neo-soft.org>
parents: 50
diff changeset
676
68eca8057d68 added livemode display to slotcli, without communication yet
Malte Bayer <mbayer@neo-soft.org>
parents: 50
diff changeset
677 # terminate
68eca8057d68 added livemode display to slotcli, without communication yet
Malte Bayer <mbayer@neo-soft.org>
parents: 50
diff changeset
678 curses.nocbreak()
68eca8057d68 added livemode display to slotcli, without communication yet
Malte Bayer <mbayer@neo-soft.org>
parents: 50
diff changeset
679 self.scr.keypad(0)
68eca8057d68 added livemode display to slotcli, without communication yet
Malte Bayer <mbayer@neo-soft.org>
parents: 50
diff changeset
680 curses.echo()
68eca8057d68 added livemode display to slotcli, without communication yet
Malte Bayer <mbayer@neo-soft.org>
parents: 50
diff changeset
681 curses.endwin()
27
3e617fcf999a added exception, started SlotCli class
Malte Bayer <mbayer@neo-soft.org>
parents: 25
diff changeset
682 return None
3e617fcf999a added exception, started SlotCli class
Malte Bayer <mbayer@neo-soft.org>
parents: 25
diff changeset
683
58
042c490fdfaa better code quality
Tobias Paepke <tobias.paepke@paepke.net>
parents: 56
diff changeset
684 def cyclemode(self):
042c490fdfaa better code quality
Tobias Paepke <tobias.paepke@paepke.net>
parents: 56
diff changeset
685 pass
042c490fdfaa better code quality
Tobias Paepke <tobias.paepke@paepke.net>
parents: 56
diff changeset
686
27
3e617fcf999a added exception, started SlotCli class
Malte Bayer <mbayer@neo-soft.org>
parents: 25
diff changeset
687 if __name__ == "__main__":
35
00166228a419 cli: implemented setting of fuel, brake, speed, blinkstate for any car
Malte Bayer <mbayer@neo-soft.org>
parents: 27
diff changeset
688 parser = OptionParser(version="%prog " + VERSION)
54
68eca8057d68 added livemode display to slotcli, without communication yet
Malte Bayer <mbayer@neo-soft.org>
parents: 50
diff changeset
689 parser.add_option("--live", dest="live", action="store_true", default=False,
68eca8057d68 added livemode display to slotcli, without communication yet
Malte Bayer <mbayer@neo-soft.org>
parents: 50
diff changeset
690 help="Run Live monitor on console", metavar="[0-5]")
116
c2fc650cc48f added option to disable freeslot fuel logic
Malte Bayer <mbayer@neo-soft.org>
parents: 115
diff changeset
691 parser.add_option("--nofuel", dest="nofuel", action="store_true", default=False,
c2fc650cc48f added option to disable freeslot fuel logic
Malte Bayer <mbayer@neo-soft.org>
parents: 115
diff changeset
692 help="Disable Freeslot fuel management", metavar="[0-5]")
124
0b12a8bf23b2 new option to set pitlane entry as finish line too to increase laps
Malte Bayer <mbayer@neo-soft.org>
parents: 123
diff changeset
693 parser.add_option("--pit", dest="pitfinish", action="store_true", default=False,
0b12a8bf23b2 new option to set pitlane entry as finish line too to increase laps
Malte Bayer <mbayer@neo-soft.org>
parents: 123
diff changeset
694 help="Pitlane entry acts as finish line too", metavar="[0-5]")
103
52fd4283cd2c added learn and teach modes for intelligent ghostcars
Malte Bayer <mbayer@neo-soft.org>
parents: 102
diff changeset
695 parser.add_option("--learn", dest="learn", action="store_true", default=False,
52fd4283cd2c added learn and teach modes for intelligent ghostcars
Malte Bayer <mbayer@neo-soft.org>
parents: 102
diff changeset
696 help="Run Learning mode for [slot]", metavar="[0-5]")
52fd4283cd2c added learn and teach modes for intelligent ghostcars
Malte Bayer <mbayer@neo-soft.org>
parents: 102
diff changeset
697 parser.add_option("--teach", dest="playback",
52fd4283cd2c added learn and teach modes for intelligent ghostcars
Malte Bayer <mbayer@neo-soft.org>
parents: 102
diff changeset
698 help="Playback teach file", metavar="[filename]")
54
68eca8057d68 added livemode display to slotcli, without communication yet
Malte Bayer <mbayer@neo-soft.org>
parents: 50
diff changeset
699
86
79fb119cf3c3 added test option without communication
Malte Bayer <mbayer@neo-soft.org>
parents: 85
diff changeset
700 parser.add_option("--slot", dest="carid",
101
92d204c738e1 changed --slot parameter to 1..6 instead of 0..5
Malte Bayer <mbayer@neo-soft.org>
parents: 100
diff changeset
701 help="Required for programming a car directly", metavar="[1-6]")
35
00166228a419 cli: implemented setting of fuel, brake, speed, blinkstate for any car
Malte Bayer <mbayer@neo-soft.org>
parents: 27
diff changeset
702 parser.add_option("--fuel", dest="fuel",
00166228a419 cli: implemented setting of fuel, brake, speed, blinkstate for any car
Malte Bayer <mbayer@neo-soft.org>
parents: 27
diff changeset
703 help="Set maximum CAR fuel level", metavar="[0-15]")
00166228a419 cli: implemented setting of fuel, brake, speed, blinkstate for any car
Malte Bayer <mbayer@neo-soft.org>
parents: 27
diff changeset
704 parser.add_option("--brake", dest="brake",
00166228a419 cli: implemented setting of fuel, brake, speed, blinkstate for any car
Malte Bayer <mbayer@neo-soft.org>
parents: 27
diff changeset
705 help="Set CAR brake strength", metavar="[0-15]")
100
039ab094f79b renamed --speed to --accel and added minimum value 6
Malte Bayer <mbayer@neo-soft.org>
parents: 99
diff changeset
706 parser.add_option("--accel", dest="accel",
039ab094f79b renamed --speed to --accel and added minimum value 6
Malte Bayer <mbayer@neo-soft.org>
parents: 99
diff changeset
707 help="Set CAR acceleration ", metavar="[6-15]")
35
00166228a419 cli: implemented setting of fuel, brake, speed, blinkstate for any car
Malte Bayer <mbayer@neo-soft.org>
parents: 27
diff changeset
708 parser.add_option("--blink", dest="blink",
00166228a419 cli: implemented setting of fuel, brake, speed, blinkstate for any car
Malte Bayer <mbayer@neo-soft.org>
parents: 27
diff changeset
709 help="Set car lights blinking state", metavar="[on|off]")
36
aea84f4f5a12 feature: program a specific controller speed limit without changing the car's acceleration
Malte Bayer <mbayer@neo-soft.org>
parents: 35
diff changeset
710 parser.add_option("--limit", dest="limit",
aea84f4f5a12 feature: program a specific controller speed limit without changing the car's acceleration
Malte Bayer <mbayer@neo-soft.org>
parents: 35
diff changeset
711 help="Controlled SPEED LIMIT (15 = no limit)", metavar="[0-15]")
50
84b8ab4cd79e implemented new --drive command to CLI
Malte Bayer <mbayer@neo-soft.org>
parents: 36
diff changeset
712 parser.add_option("--drive", dest="drive",
84b8ab4cd79e implemented new --drive command to CLI
Malte Bayer <mbayer@neo-soft.org>
parents: 36
diff changeset
713 help="Controlled SPEED MINIMUM (0 = disabled)", metavar="[0-15]")
86
79fb119cf3c3 added test option without communication
Malte Bayer <mbayer@neo-soft.org>
parents: 85
diff changeset
714 parser.add_option("--test", dest="test", action="store_true", default=False,
79fb119cf3c3 added test option without communication
Malte Bayer <mbayer@neo-soft.org>
parents: 85
diff changeset
715 help="", metavar="")
106
11fabe1f7c40 added dev parameter
Malte Bayer <mbayer@neo-soft.org>
parents: 104
diff changeset
716 parser.add_option("--dev", dest="dev", default="/dev/ttyUSB0",
11fabe1f7c40 added dev parameter
Malte Bayer <mbayer@neo-soft.org>
parents: 104
diff changeset
717 help="Communication port", metavar="[/dev/ttyUSB0]")
35
00166228a419 cli: implemented setting of fuel, brake, speed, blinkstate for any car
Malte Bayer <mbayer@neo-soft.org>
parents: 27
diff changeset
718
00166228a419 cli: implemented setting of fuel, brake, speed, blinkstate for any car
Malte Bayer <mbayer@neo-soft.org>
parents: 27
diff changeset
719 (options, args) = parser.parse_args()
106
11fabe1f7c40 added dev parameter
Malte Bayer <mbayer@neo-soft.org>
parents: 104
diff changeset
720 #if not options.dev:
11fabe1f7c40 added dev parameter
Malte Bayer <mbayer@neo-soft.org>
parents: 104
diff changeset
721 # options.dev = "/dev/ttyUSB0"
110
b0e4f4249351 added xmlrpc server to live viewer, cli functions communicate with server
Malte Bayer <mbayer@neo-soft.org>
parents: 109
diff changeset
722
b0e4f4249351 added xmlrpc server to live viewer, cli functions communicate with server
Malte Bayer <mbayer@neo-soft.org>
parents: 109
diff changeset
723 if options.live or options.learn or options.playback:
b0e4f4249351 added xmlrpc server to live viewer, cli functions communicate with server
Malte Bayer <mbayer@neo-soft.org>
parents: 109
diff changeset
724 cli = SlotCli(options.test, options.dev)
b0e4f4249351 added xmlrpc server to live viewer, cli functions communicate with server
Malte Bayer <mbayer@neo-soft.org>
parents: 109
diff changeset
725 else:
b0e4f4249351 added xmlrpc server to live viewer, cli functions communicate with server
Malte Bayer <mbayer@neo-soft.org>
parents: 109
diff changeset
726 cli = SlotClient('http://localhost:8000')
35
00166228a419 cli: implemented setting of fuel, brake, speed, blinkstate for any car
Malte Bayer <mbayer@neo-soft.org>
parents: 27
diff changeset
727 # should a CLI function be started?
00166228a419 cli: implemented setting of fuel, brake, speed, blinkstate for any car
Malte Bayer <mbayer@neo-soft.org>
parents: 27
diff changeset
728
58
042c490fdfaa better code quality
Tobias Paepke <tobias.paepke@paepke.net>
parents: 56
diff changeset
729 if options.live:
54
68eca8057d68 added livemode display to slotcli, without communication yet
Malte Bayer <mbayer@neo-soft.org>
parents: 50
diff changeset
730 # start the live monitor
116
c2fc650cc48f added option to disable freeslot fuel logic
Malte Bayer <mbayer@neo-soft.org>
parents: 115
diff changeset
731 cli.nofuel = options.nofuel
124
0b12a8bf23b2 new option to set pitlane entry as finish line too to increase laps
Malte Bayer <mbayer@neo-soft.org>
parents: 123
diff changeset
732 cli.pitfinish = options.pitfinish
54
68eca8057d68 added livemode display to slotcli, without communication yet
Malte Bayer <mbayer@neo-soft.org>
parents: 50
diff changeset
733 cli.monitor()
68eca8057d68 added livemode display to slotcli, without communication yet
Malte Bayer <mbayer@neo-soft.org>
parents: 50
diff changeset
734 sys.exit(0)
35
00166228a419 cli: implemented setting of fuel, brake, speed, blinkstate for any car
Malte Bayer <mbayer@neo-soft.org>
parents: 27
diff changeset
735
00166228a419 cli: implemented setting of fuel, brake, speed, blinkstate for any car
Malte Bayer <mbayer@neo-soft.org>
parents: 27
diff changeset
736 # check commandline if we have to program something
58
042c490fdfaa better code quality
Tobias Paepke <tobias.paepke@paepke.net>
parents: 56
diff changeset
737 if not options.carid:
101
92d204c738e1 changed --slot parameter to 1..6 instead of 0..5
Malte Bayer <mbayer@neo-soft.org>
parents: 100
diff changeset
738 print "Option --slot is required for all car programming commands!\nUse --help to get a list of available commands"
35
00166228a419 cli: implemented setting of fuel, brake, speed, blinkstate for any car
Malte Bayer <mbayer@neo-soft.org>
parents: 27
diff changeset
739 sys.exit(1)
101
92d204c738e1 changed --slot parameter to 1..6 instead of 0..5
Malte Bayer <mbayer@neo-soft.org>
parents: 100
diff changeset
740 else:
92d204c738e1 changed --slot parameter to 1..6 instead of 0..5
Malte Bayer <mbayer@neo-soft.org>
parents: 100
diff changeset
741 options.carid = int(options.carid) - 1
92d204c738e1 changed --slot parameter to 1..6 instead of 0..5
Malte Bayer <mbayer@neo-soft.org>
parents: 100
diff changeset
742 if (options.carid < 0) or (options.carid > 6):
92d204c738e1 changed --slot parameter to 1..6 instead of 0..5
Malte Bayer <mbayer@neo-soft.org>
parents: 100
diff changeset
743 print "Error: Invalid slot selected"
92d204c738e1 changed --slot parameter to 1..6 instead of 0..5
Malte Bayer <mbayer@neo-soft.org>
parents: 100
diff changeset
744 sys.exit(1)
36
aea84f4f5a12 feature: program a specific controller speed limit without changing the car's acceleration
Malte Bayer <mbayer@neo-soft.org>
parents: 35
diff changeset
745
103
52fd4283cd2c added learn and teach modes for intelligent ghostcars
Malte Bayer <mbayer@neo-soft.org>
parents: 102
diff changeset
746 if options.learn:
52fd4283cd2c added learn and teach modes for intelligent ghostcars
Malte Bayer <mbayer@neo-soft.org>
parents: 102
diff changeset
747 # start the learn monitor
52fd4283cd2c added learn and teach modes for intelligent ghostcars
Malte Bayer <mbayer@neo-soft.org>
parents: 102
diff changeset
748 cli.monitor_learn(options.carid)
52fd4283cd2c added learn and teach modes for intelligent ghostcars
Malte Bayer <mbayer@neo-soft.org>
parents: 102
diff changeset
749 sys.exit(0)
52fd4283cd2c added learn and teach modes for intelligent ghostcars
Malte Bayer <mbayer@neo-soft.org>
parents: 102
diff changeset
750
52fd4283cd2c added learn and teach modes for intelligent ghostcars
Malte Bayer <mbayer@neo-soft.org>
parents: 102
diff changeset
751 if options.playback:
52fd4283cd2c added learn and teach modes for intelligent ghostcars
Malte Bayer <mbayer@neo-soft.org>
parents: 102
diff changeset
752 # start the playback monitor
52fd4283cd2c added learn and teach modes for intelligent ghostcars
Malte Bayer <mbayer@neo-soft.org>
parents: 102
diff changeset
753 cli.monitor_playback(options.carid, options.playback)
52fd4283cd2c added learn and teach modes for intelligent ghostcars
Malte Bayer <mbayer@neo-soft.org>
parents: 102
diff changeset
754 sys.exit(0)
52fd4283cd2c added learn and teach modes for intelligent ghostcars
Malte Bayer <mbayer@neo-soft.org>
parents: 102
diff changeset
755
58
042c490fdfaa better code quality
Tobias Paepke <tobias.paepke@paepke.net>
parents: 56
diff changeset
756 if options.fuel:
35
00166228a419 cli: implemented setting of fuel, brake, speed, blinkstate for any car
Malte Bayer <mbayer@neo-soft.org>
parents: 27
diff changeset
757 print "setFuel: " + cli.box.progcar(int(options.carid), "fuel", int(options.fuel))
36
aea84f4f5a12 feature: program a specific controller speed limit without changing the car's acceleration
Malte Bayer <mbayer@neo-soft.org>
parents: 35
diff changeset
758
100
039ab094f79b renamed --speed to --accel and added minimum value 6
Malte Bayer <mbayer@neo-soft.org>
parents: 99
diff changeset
759 if options.accel:
039ab094f79b renamed --speed to --accel and added minimum value 6
Malte Bayer <mbayer@neo-soft.org>
parents: 99
diff changeset
760 print "setAccel: " + cli.box.progcar(int(options.carid), "accel", int(options.accel))
36
aea84f4f5a12 feature: program a specific controller speed limit without changing the car's acceleration
Malte Bayer <mbayer@neo-soft.org>
parents: 35
diff changeset
761
58
042c490fdfaa better code quality
Tobias Paepke <tobias.paepke@paepke.net>
parents: 56
diff changeset
762 if options.brake:
35
00166228a419 cli: implemented setting of fuel, brake, speed, blinkstate for any car
Malte Bayer <mbayer@neo-soft.org>
parents: 27
diff changeset
763 print "setBrake: " + cli.box.progcar(int(options.carid), "brake", int(options.brake))
36
aea84f4f5a12 feature: program a specific controller speed limit without changing the car's acceleration
Malte Bayer <mbayer@neo-soft.org>
parents: 35
diff changeset
764
58
042c490fdfaa better code quality
Tobias Paepke <tobias.paepke@paepke.net>
parents: 56
diff changeset
765 if options.blink:
35
00166228a419 cli: implemented setting of fuel, brake, speed, blinkstate for any car
Malte Bayer <mbayer@neo-soft.org>
parents: 27
diff changeset
766 state = False
00166228a419 cli: implemented setting of fuel, brake, speed, blinkstate for any car
Malte Bayer <mbayer@neo-soft.org>
parents: 27
diff changeset
767 if options.blink == "on":
00166228a419 cli: implemented setting of fuel, brake, speed, blinkstate for any car
Malte Bayer <mbayer@neo-soft.org>
parents: 27
diff changeset
768 state = True
00166228a419 cli: implemented setting of fuel, brake, speed, blinkstate for any car
Malte Bayer <mbayer@neo-soft.org>
parents: 27
diff changeset
769 print "setBlink: " + cli.box.blinkcar(int(options.carid), state)
36
aea84f4f5a12 feature: program a specific controller speed limit without changing the car's acceleration
Malte Bayer <mbayer@neo-soft.org>
parents: 35
diff changeset
770
58
042c490fdfaa better code quality
Tobias Paepke <tobias.paepke@paepke.net>
parents: 56
diff changeset
771 if options.limit:
36
aea84f4f5a12 feature: program a specific controller speed limit without changing the car's acceleration
Malte Bayer <mbayer@neo-soft.org>
parents: 35
diff changeset
772 print "Change Speed Limit: " + cli.box.speedlimit(int(options.carid), int(options.limit))
aea84f4f5a12 feature: program a specific controller speed limit without changing the car's acceleration
Malte Bayer <mbayer@neo-soft.org>
parents: 35
diff changeset
773
58
042c490fdfaa better code quality
Tobias Paepke <tobias.paepke@paepke.net>
parents: 56
diff changeset
774 if options.drive:
50
84b8ab4cd79e implemented new --drive command to CLI
Malte Bayer <mbayer@neo-soft.org>
parents: 36
diff changeset
775 print "Change minimum Speed drive: " + cli.box.speedminimum(int(options.carid), int(options.drive))
84b8ab4cd79e implemented new --drive command to CLI
Malte Bayer <mbayer@neo-soft.org>
parents: 36
diff changeset
776

mercurial