Bug fikser med totaltid og strekktid

This commit is contained in:
Trygve 2023-11-28 01:34:18 +01:00
parent 4048cfe94f
commit 18f49c1a0c
2 changed files with 18 additions and 13 deletions

View File

@ -64,14 +64,14 @@ def create_result_file(event, file_path, o_classes=[]):
xml_child(result, 'Status', n.status)
# <SplitTime>
# 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')
xml_child(st, 'ControlCode', code)
xml_child(st, 'Time', split)
# </SplitTime>
elif n.status == 'MissingPunch':
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')
xml_child(st, 'ControlCode', code)
if split != 0: xml_child(st, 'Time', split)
@ -122,7 +122,7 @@ def runners_from_xml_entries(xml_file):
start_time = None
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))
return runners
@ -201,7 +201,9 @@ def event_from_xml_entries(xml_file):
o_classes = [otime.OClass(i, []) for i in set(class_names)]
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,
fees=fees, start_time=start_time, end_time=end_time, o_classes=o_classes)

View File

@ -278,19 +278,21 @@ class Event:
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)
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):
runner = self.get_runner(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
f_control = card_dump.controls[-1]
f_control = course.codes[runner.fork][-1]
# TODO: Må gjøres mer robust
try:
index = card_dump.controls.index(f_control)
return card_dump.splits[index]
except:
return False
index = card_dump.controls.index(f_control)
return card_dump.splits[index]
def get_runner_splits(self, id):
# Tida brukt frem til hver post, ikke tida fra forrige post
@ -298,6 +300,7 @@ class Event:
runner = self.get_runner(id)
card_dump = self.get_card_dump(runner.card_id)
course = self.get_course(self.get_o_class(runner.o_class).course)
codes = course.codes[runner.fork]
except AttributeError:
return None
@ -305,8 +308,8 @@ class Event:
return None
split_iter = zip(card_dump.controls, card_dump.splits).__iter__()
splits = [0] * len(course.codes[runner.fork])
for n, control in enumerate(course.codes[runner.fork]):
splits = [0] * len(codes)
for n, control in enumerate(codes):
if control not in card_dump.controls:
continue
while True: