Added option to retry replica parsing with added Trigger Component

This commit is contained in:
lcdr 2016-10-22 14:04:59 +02:00
parent 5f6a5c9f77
commit b2946a5c28
4 changed files with 26 additions and 11 deletions

View File

@ -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

View File

@ -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)

View 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

View File

@ -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