You cannot select more than 25 topics Topics must start with a letter or number, can include dashes ('-') and can be up to 35 characters long.
o3de/Tools/EventLogTools/EventLogger/Utils.py

122 lines
3.0 KiB
Python

#
# All or portions of this file Copyright (c) Amazon.com, Inc. or its affiliates or
# its licensors.
#
# For complete copyright and license terms please see the LICENSE at the root of this
# distribution (the "License"). All use of this software is governed by the License,
# or, if provided, by the license below or the license accompanying this file. Do not
# remove or modify any license notices. This file is distributed on an "AS IS" BASIS,
# WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
#
import struct
import sys
# Simple hash structure based on DJB2a
class EventNameHash(object):
def __init__(self, name):
if isinstance(name, int):
self.hash = name
else:
value = 5381
for i in range(len(name)):
value = ((value << 5) + value) ^ ord(name[i])
self.hash = value & 0xFFFFFFFF
def __hash__(self):
return self.hash
def __eq__(self, rhs):
if isinstance(rhs, EventNameHash):
return self.hash == rhs.hash
else:
return self.hash == rhs
PrologId = EventNameHash("Prolog")
EventBoundary = 8
class LogStructBase(object):
def _unpack(self, member_info, data):
pos = 0
for (member, data_format, data_size) in member_info:
pos_end = pos + data_size
unpacked_value = struct.unpack(data_format, data[pos:pos_end])
setattr(self, member, unpacked_value[0])
pos = pos_end
class LogHeader(LogStructBase):
@staticmethod
def size():
return 16
@staticmethod
def accepted_formats():
return ['AZEL']
def __init__(self):
self.four_cc = None
self.major_version = None
self.minor_version = None
self.user_version = None
def unpack(self, data):
member_info = [
('four_cc', '@4s', 4),
('major_version', '@I', 4),
('minor_version', '@I', 4),
('user_version', '@I', 4),
]
self._unpack(member_info, data)
def get_format(self):
return self.four_cc.decode('utf-8')
def get_version(self):
return f'{self.major_version}.{self.minor_version} ({self.user_version})'
class EventHeader(LogStructBase):
@staticmethod
def size():
return 8
def __init__(self):
self.event_id = None
self.size = None
self.flags = None
def unpack(self, data):
member_info = [
('event_id', '@I', 4),
('size', '@H', 2),
('flags', '@H', 2),
]
self._unpack(member_info, data)
class Prolog(EventHeader):
@staticmethod
def size():
return 16
def __init__(self):
super().__init__()
self.thread_id = None
def unpack(self, data):
member_info = [
('event_id', '@I', 4),
('size', '@H', 2),
('flags', '@H', 2),
('thread_id', '@Q', 8)
]
self._unpack(member_info, data)