mirror of
https://github.com/lcdr/utils.git
synced 2024-08-30 17:32:16 +00:00
Added option to retry replica parsing with added Trigger Component
This commit is contained in:
parent
5f6a5c9f77
commit
b2946a5c28
@ -6,3 +6,4 @@ serializations=True
|
|||||||
game_messages=True
|
game_messages=True
|
||||||
normal_packets=True
|
normal_packets=True
|
||||||
retry_with_script_component=True
|
retry_with_script_component=True
|
||||||
|
retry_with_trigger_component=True
|
||||||
|
@ -64,6 +64,7 @@ component_name[71] = "RacingControl",
|
|||||||
component_name[75] = "Exhibit",
|
component_name[75] = "Exhibit",
|
||||||
component_name[2] = "Render",
|
component_name[2] = "Render",
|
||||||
component_name[107] = "Component 107",
|
component_name[107] = "Component 107",
|
||||||
|
component_name[69] = "Trigger",
|
||||||
component_name[12] = None
|
component_name[12] = None
|
||||||
component_name[27] = None
|
component_name[27] = None
|
||||||
component_name[31] = None
|
component_name[31] = None
|
||||||
@ -164,6 +165,7 @@ class CaptureViewer(viewer.Viewer):
|
|||||||
self.parse_game_messages = BooleanVar(value=False)
|
self.parse_game_messages = BooleanVar(value=False)
|
||||||
self.parse_normal_packets = BooleanVar(value=config["parse"]["normal_packets"])
|
self.parse_normal_packets = BooleanVar(value=config["parse"]["normal_packets"])
|
||||||
self.retry_with_script_component = BooleanVar(value=config["parse"]["retry_with_script_component"])
|
self.retry_with_script_component = BooleanVar(value=config["parse"]["retry_with_script_component"])
|
||||||
|
self.retry_with_trigger_component = BooleanVar(value=config["parse"]["retry_with_trigger_component"])
|
||||||
self.create_widgets()
|
self.create_widgets()
|
||||||
|
|
||||||
def create_widgets(self):
|
def create_widgets(self):
|
||||||
@ -177,6 +179,7 @@ class CaptureViewer(viewer.Viewer):
|
|||||||
parse_menu.add_checkbutton(label="Parse Game Messages", variable=self.parse_game_messages)
|
parse_menu.add_checkbutton(label="Parse Game Messages", variable=self.parse_game_messages)
|
||||||
parse_menu.add_checkbutton(label="Parse Normal Packets", variable=self.parse_normal_packets)
|
parse_menu.add_checkbutton(label="Parse Normal Packets", variable=self.parse_normal_packets)
|
||||||
parse_menu.add_checkbutton(label="Retry parsing with script component if failed", variable=self.retry_with_script_component)
|
parse_menu.add_checkbutton(label="Retry parsing with script component if failed", variable=self.retry_with_script_component)
|
||||||
|
parse_menu.add_checkbutton(label="Retry parsing with trigger component if failed", variable=self.retry_with_trigger_component)
|
||||||
menubar.add_cascade(label="Parse", menu=parse_menu)
|
menubar.add_cascade(label="Parse", menu=parse_menu)
|
||||||
self.master.config(menu=menubar)
|
self.master.config(menu=menubar)
|
||||||
|
|
||||||
@ -232,7 +235,7 @@ class CaptureViewer(viewer.Viewer):
|
|||||||
packet = BitStream(capture.read(packet_name))
|
packet = BitStream(capture.read(packet_name))
|
||||||
self.parse_normal_packet(packet_name, packet)
|
self.parse_normal_packet(packet_name, packet)
|
||||||
|
|
||||||
def parse_creation(self, packet_name, packet, is_retry=False):
|
def parse_creation(self, packet_name, packet, retry_with_components=[]):
|
||||||
packet.skip_read(1)
|
packet.skip_read(1)
|
||||||
has_network_id = packet.read(c_bit)
|
has_network_id = packet.read(c_bit)
|
||||||
assert has_network_id
|
assert has_network_id
|
||||||
@ -249,8 +252,8 @@ class CaptureViewer(viewer.Viewer):
|
|||||||
print("Name for lot", lot, "not found")
|
print("Name for lot", lot, "not found")
|
||||||
lot_name = str(lot)
|
lot_name = str(lot)
|
||||||
component_types = [i[0] for i in self.db.execute("select component_type from ComponentsRegistry where id == "+str(lot)).fetchall()]
|
component_types = [i[0] for i in self.db.execute("select component_type from ComponentsRegistry where id == "+str(lot)).fetchall()]
|
||||||
if is_retry:
|
component_types.extend(retry_with_components)
|
||||||
component_types.append(5) # script component
|
|
||||||
parsers = OrderedDict()
|
parsers = OrderedDict()
|
||||||
try:
|
try:
|
||||||
component_types.sort(key=comp_ids.index)
|
component_types.sort(key=comp_ids.index)
|
||||||
@ -278,15 +281,21 @@ class CaptureViewer(viewer.Viewer):
|
|||||||
try:
|
try:
|
||||||
self.parse_serialization(packet, parser_output, parsers, is_creation=True)
|
self.parse_serialization(packet, parser_output, parsers, is_creation=True)
|
||||||
except (AssertionError, IndexError):
|
except (AssertionError, IndexError):
|
||||||
if self.retry_with_script_component and not is_retry:
|
if retry_with_components:
|
||||||
print("retrying", packet_name)
|
|
||||||
del self.lot_data[lot]
|
|
||||||
packet._read_offset = 0
|
|
||||||
self.parse_creation(packet_name, packet, is_retry=True)
|
|
||||||
return
|
|
||||||
else:
|
|
||||||
print("retry was not able to resolve parsing error")
|
print("retry was not able to resolve parsing error")
|
||||||
raise
|
raise
|
||||||
|
retry_with_components = []
|
||||||
|
if self.retry_with_script_component.get():
|
||||||
|
retry_with_components.append(5)
|
||||||
|
elif self.retry_with_trigger_component.get():
|
||||||
|
retry_with_components.append(69)
|
||||||
|
|
||||||
|
if retry_with_components:
|
||||||
|
print("retrying with", retry_with_components, packet_name)
|
||||||
|
del self.lot_data[lot]
|
||||||
|
packet._read_offset = 0
|
||||||
|
self.parse_creation(packet_name, packet, retry_with_components)
|
||||||
|
return
|
||||||
|
|
||||||
obj = CaptureObject(network_id=network_id, object_id=object_id, lot=lot)
|
obj = CaptureObject(network_id=network_id, object_id=object_id, lot=lot)
|
||||||
self.objects.append(obj)
|
self.objects.append(obj)
|
||||||
|
5
packetdefinitions/replica/components/Trigger.structs
Normal file
5
packetdefinitions/replica/components/Trigger.structs
Normal file
@ -0,0 +1,5 @@
|
|||||||
|
Trigger Component
|
||||||
|
Seems like this component is append when there is a trigger_id entry in the luz
|
||||||
|
See also .lutriggers files in the client
|
||||||
|
[bit] - flag
|
||||||
|
[s32] - ???, expect == -1
|
@ -7,7 +7,7 @@ objectID=[s64] - objectID
|
|||||||
[u32] - time_since_created_on_server?
|
[u32] - time_since_created_on_server?
|
||||||
[bit] - flag, expect == False
|
[bit] - flag, expect == False
|
||||||
[compressed_ldf] - config variables?
|
[compressed_ldf] - config variables?
|
||||||
[bit] - trigger_id, expect == False
|
[bit] - has trigger component
|
||||||
[bit] - flag
|
[bit] - flag
|
||||||
[s64] - spawner object ID
|
[s64] - spawner object ID
|
||||||
[bit] - flag
|
[bit] - flag
|
||||||
|
Loading…
Reference in New Issue
Block a user