Compare commits
3 Commits
f1612cf838
...
18f49c1a0c
Author | SHA1 | Date | |
---|---|---|---|
18f49c1a0c | |||
4048cfe94f | |||
a39c5e4615 |
30
otime/cli.py
30
otime/cli.py
@ -28,22 +28,32 @@ def main():
|
|||||||
parser_init.add_argument('--port', required=False, dest='port', action='store', help='specify a serial port')
|
parser_init.add_argument('--port', required=False, dest='port', action='store', help='specify a serial port')
|
||||||
parser_init.add_argument('--xml', required=False, dest='xml_path', action='store', default=None, help='Where the xml result file should be saved')
|
parser_init.add_argument('--xml', required=False, dest='xml_path', action='store', default=None, help='Where the xml result file should be saved')
|
||||||
|
|
||||||
parser_init = subparsers.add_parser('viewer', help='View otime data')
|
parser_init = subparsers.add_parser('gen', help='Generate result files')
|
||||||
parser_init.add_argument('--dir', required=False, dest='dir', action='store', default='./', help='specify a directory')
|
parser_init.add_argument('--dir', required=False, dest='dir', action='store', default='./', help='specify a directory')
|
||||||
parser_init.add_argument('--xml', required=False, dest='xml_path', action='store', default=None, help='Where the xml result file should be saved')
|
parser_init.add_argument('--xml', required=False, dest='xml_path', action='store', default=None, help='Where the xml result file should be saved')
|
||||||
|
|
||||||
|
parser_init = subparsers.add_parser('view', help='View otime data')
|
||||||
|
parser_init.add_argument('--dir', required=False, dest='dir', action='store', default='./', help='specify a directory')
|
||||||
|
parser_init.add_argument('--xml', required=False, dest='xml_path', action='store', default=None, help='Where the xml result file should be saved')
|
||||||
|
|
||||||
|
|
||||||
args = parser.parse_args()
|
args = parser.parse_args()
|
||||||
|
|
||||||
if not args.xml_path:
|
try:
|
||||||
args.xml_path = args.dir + '/output'
|
if not args.xml_path:
|
||||||
|
args.xml_path = args.dir + '/output'
|
||||||
|
except AttributeError:
|
||||||
|
pass
|
||||||
|
|
||||||
match args.command:
|
match args.command:
|
||||||
case 'init':
|
case 'init':
|
||||||
init_dir(args.dir, args.entries_file, args.courses_file)
|
init_dir(args.dir, args.entries_file, args.courses_file)
|
||||||
case 'run':
|
case 'run':
|
||||||
run(args.port, args.dir, args.xml_path)
|
run(args.port, args.dir, args.xml_path)
|
||||||
case 'viewer':
|
case 'view':
|
||||||
search_tui.main(args.dir)
|
search_tui.main(args.dir)
|
||||||
|
case 'gen':
|
||||||
|
gen(args.dir, args.xml_path)
|
||||||
|
|
||||||
def init_dir(project_dir, entries_xml_file, courses_xml_file):
|
def init_dir(project_dir, entries_xml_file, courses_xml_file):
|
||||||
# Lager mappe med en config fil, en csv fil med løpere og en fil med mtr data
|
# Lager mappe med en config fil, en csv fil med løpere og en fil med mtr data
|
||||||
@ -93,6 +103,18 @@ def run(port='/dev/ttyUSB0', project_dir='./', xml_path='./output/'):
|
|||||||
meat = mtr.read(55)
|
meat = mtr.read(55)
|
||||||
inspect(status)
|
inspect(status)
|
||||||
|
|
||||||
|
def gen(project_dir='./', xml_path='./output/'):
|
||||||
|
config_path = project_dir + '/config.yaml'
|
||||||
|
mtr_path = project_dir + '/mtr.yaml'
|
||||||
|
csv_path = project_dir + '/runners.csv'
|
||||||
|
event = file_io.event_from_yaml_and_csv(config_path, mtr_path, csv_path)
|
||||||
|
file_io.write_card_dumps(event, mtr_path)
|
||||||
|
subprocess.run(['git', 'add', './*'], cwd=project_dir, stdout=subprocess.DEVNULL)
|
||||||
|
subprocess.run(['git', 'commit', '-m', f'Manually run'], cwd=project_dir, stdout=subprocess.DEVNULL)
|
||||||
|
|
||||||
|
iof_xml.create_result_file(event, xml_path + '/results.xml')
|
||||||
|
pdf.create_result_list(event, project_dir + '/output/results.pdf')
|
||||||
|
|
||||||
def runner_info(event, card_dump):
|
def runner_info(event, card_dump):
|
||||||
runner = next((i for i in event.runners if str(i.card_id) == str(card_dump.card)), None)
|
runner = next((i for i in event.runners if str(i.card_id) == str(card_dump.card)), None)
|
||||||
if runner is None:
|
if runner is None:
|
||||||
|
@ -22,6 +22,7 @@ def write_card_dumps(event, file_path):
|
|||||||
|
|
||||||
def write_runners_csv(event, file_path):
|
def write_runners_csv(event, file_path):
|
||||||
with open(file_path, 'w') as f:
|
with open(file_path, 'w') as f:
|
||||||
|
f.write('ID;Status;Fornavn, Etternavn;Klasse;klubb;Brikke;Gafling;Starttid\n')
|
||||||
for i in event.runners:
|
for i in event.runners:
|
||||||
f.write(f'{i.id};{i.status_override};{i.first}, {i.last};{i.o_class};{i.club};{i.card_id};{i.fork};{i.start_time}\n')
|
f.write(f'{i.id};{i.status_override};{i.first}, {i.last};{i.o_class};{i.club};{i.card_id};{i.fork};{i.start_time}\n')
|
||||||
|
|
||||||
@ -37,6 +38,7 @@ def event_from_yaml_and_csv(config_path, mtr_path, csv_path):
|
|||||||
|
|
||||||
with open(csv_path, 'r') as f:
|
with open(csv_path, 'r') as f:
|
||||||
data = [i.split(';') for i in f.readlines()]
|
data = [i.split(';') for i in f.readlines()]
|
||||||
|
data.pop(0)
|
||||||
for i in data: i[2] = i[2].split(',')
|
for i in data: i[2] = i[2].split(',')
|
||||||
runners = [otime.Runner(id=i[0], status_override=i[1], first=i[2][0], last=i[2][1].strip(), o_class=i[3], club=i[4], card_id=int(i[5]), fork=int(i[6]), start_time=i[7]) for i in data]
|
runners = [otime.Runner(id=i[0], status_override=i[1], first=i[2][0], last=i[2][1].strip(), o_class=i[3], club=i[4], card_id=int(i[5]), fork=int(i[6]), start_time=i[7]) for i in data]
|
||||||
event.card_dumps = card_dumps
|
event.card_dumps = card_dumps
|
||||||
|
@ -64,14 +64,14 @@ def create_result_file(event, file_path, o_classes=[]):
|
|||||||
xml_child(result, 'Status', n.status)
|
xml_child(result, 'Status', n.status)
|
||||||
# <SplitTime>
|
# <SplitTime>
|
||||||
# TODO: ta utgangspunkt i løypa, ikke det brikka har stempla
|
# TODO: ta utgangspunkt i løypa, ikke det brikka har stempla
|
||||||
for code, split in zip(i.course.codes, n.splits):
|
for code, split in zip(i.course.codes[n.fork], n.splits):
|
||||||
st = ET.SubElement(result, 'SplitTime')
|
st = ET.SubElement(result, 'SplitTime')
|
||||||
xml_child(st, 'ControlCode', code)
|
xml_child(st, 'ControlCode', code)
|
||||||
xml_child(st, 'Time', split)
|
xml_child(st, 'Time', split)
|
||||||
# </SplitTime>
|
# </SplitTime>
|
||||||
elif n.status == 'MissingPunch':
|
elif n.status == 'MissingPunch':
|
||||||
xml_child(result, 'Status', n.status)
|
xml_child(result, 'Status', n.status)
|
||||||
for code, split in zip(i.course.codes, n.splits):
|
for code, split in zip(i.course.codes[n.fork], n.splits):
|
||||||
st = ET.SubElement(result, 'SplitTime')
|
st = ET.SubElement(result, 'SplitTime')
|
||||||
xml_child(st, 'ControlCode', code)
|
xml_child(st, 'ControlCode', code)
|
||||||
if split != 0: xml_child(st, 'Time', split)
|
if split != 0: xml_child(st, 'Time', split)
|
||||||
@ -122,7 +122,7 @@ def runners_from_xml_entries(xml_file):
|
|||||||
|
|
||||||
start_time = None
|
start_time = None
|
||||||
runners.append(otime.Runner(rid, first, last, club=club_name, club_id=club_id,
|
runners.append(otime.Runner(rid, first, last, club=club_name, club_id=club_id,
|
||||||
country=country,card_id=card, o_class_str=class_str,
|
country=country,card_id=card, o_class=class_str,
|
||||||
start_time=start_time, fee_id=fee_id))
|
start_time=start_time, fee_id=fee_id))
|
||||||
return runners
|
return runners
|
||||||
|
|
||||||
@ -201,7 +201,9 @@ def event_from_xml_entries(xml_file):
|
|||||||
o_classes = [otime.OClass(i, []) for i in set(class_names)]
|
o_classes = [otime.OClass(i, []) for i in set(class_names)]
|
||||||
|
|
||||||
runners = runners_from_xml_entries(xml_file)
|
runners = runners_from_xml_entries(xml_file)
|
||||||
fees = fees_from_xml_entries(xml_file)
|
# TODO: fiks fees
|
||||||
|
#fees = fees_from_xml_entries(xml_file)
|
||||||
|
fees = []
|
||||||
|
|
||||||
return otime.Event(event_id, name, organiser=organiser, runners=runners,
|
return otime.Event(event_id, name, organiser=organiser, runners=runners,
|
||||||
fees=fees, start_time=start_time, end_time=end_time, o_classes=o_classes)
|
fees=fees, start_time=start_time, end_time=end_time, o_classes=o_classes)
|
@ -278,19 +278,21 @@ class Event:
|
|||||||
runner = self.get_runner(runner_id)
|
runner = self.get_runner(runner_id)
|
||||||
return next((i for i in produce_class_result(self, runner.o_class).runner_results if i.id == runner_id), None)
|
return next((i for i in produce_class_result(self, runner.o_class).runner_results if i.id == runner_id), None)
|
||||||
|
|
||||||
|
def get_runner_o_class(self, id):
|
||||||
|
runner = self.get_runner(id)
|
||||||
|
return next((copy.copy(i) for i in self.o_classes if i.name == runner.o_class), None)
|
||||||
|
|
||||||
def get_runner_time(self, id):
|
def get_runner_time(self, id):
|
||||||
runner = self.get_runner(id)
|
runner = self.get_runner(id)
|
||||||
card_dump = self.get_card_dump(runner.card_id)
|
card_dump = self.get_card_dump(runner.card_id)
|
||||||
if card_dump == None:
|
course = self.get_course(self.get_runner_o_class(id).course)
|
||||||
|
if card_dump == None or course == None:
|
||||||
return False
|
return False
|
||||||
|
|
||||||
f_control = card_dump.controls[-1]
|
f_control = course.codes[runner.fork][-1]
|
||||||
# TODO: Må gjøres mer robust
|
# TODO: Må gjøres mer robust
|
||||||
try:
|
index = card_dump.controls.index(f_control)
|
||||||
index = card_dump.controls.index(f_control)
|
return card_dump.splits[index]
|
||||||
return card_dump.splits[index]
|
|
||||||
except:
|
|
||||||
return False
|
|
||||||
|
|
||||||
def get_runner_splits(self, id):
|
def get_runner_splits(self, id):
|
||||||
# Tida brukt frem til hver post, ikke tida fra forrige post
|
# Tida brukt frem til hver post, ikke tida fra forrige post
|
||||||
@ -298,6 +300,7 @@ class Event:
|
|||||||
runner = self.get_runner(id)
|
runner = self.get_runner(id)
|
||||||
card_dump = self.get_card_dump(runner.card_id)
|
card_dump = self.get_card_dump(runner.card_id)
|
||||||
course = self.get_course(self.get_o_class(runner.o_class).course)
|
course = self.get_course(self.get_o_class(runner.o_class).course)
|
||||||
|
codes = course.codes[runner.fork]
|
||||||
except AttributeError:
|
except AttributeError:
|
||||||
return None
|
return None
|
||||||
|
|
||||||
@ -305,8 +308,8 @@ class Event:
|
|||||||
return None
|
return None
|
||||||
|
|
||||||
split_iter = zip(card_dump.controls, card_dump.splits).__iter__()
|
split_iter = zip(card_dump.controls, card_dump.splits).__iter__()
|
||||||
splits = [0] * len(course.codes[runner.fork])
|
splits = [0] * len(codes)
|
||||||
for n, control in enumerate(course.codes[runner.fork]):
|
for n, control in enumerate(codes):
|
||||||
if control not in card_dump.controls:
|
if control not in card_dump.controls:
|
||||||
continue
|
continue
|
||||||
while True:
|
while True:
|
||||||
|
Loading…
Reference in New Issue
Block a user