From f102647272dd2f369d5d5ee03610776cf5647aaa Mon Sep 17 00:00:00 2001 From: j-t-1 <120829237+j-t-1@users.noreply.github.com> Date: Thu, 5 Dec 2024 19:09:26 +0000 Subject: [PATCH] Non-functional change in parse_rich_header Change rich header check to be more logical in checking the DanS bytes; functionally equivalent. --- pefile.py | 6 +----- 1 file changed, 1 insertion(+), 5 deletions(-) diff --git a/pefile.py b/pefile.py index f804678..6a46c7a 100644 --- a/pefile.py +++ b/pefile.py @@ -3373,7 +3373,6 @@ def parse_rich_header(self): """ # Rich Header constants - # DANS = 0x536E6144 # 'DanS' as dword RICH = 0x68636952 # 'Rich' as dword @@ -3417,7 +3416,7 @@ def parse_rich_header(self): checksum = int.from_bytes(key, "little") # the checksum should be present 3 times after the DanS signature if ( - data[0] ^ checksum != DANS + data[0] != DANS ^ checksum or data[1] != checksum or data[2] != checksum or data[3] != checksum @@ -3433,16 +3432,13 @@ def parse_rich_header(self): data = data[4:] for i in range(len(data) // 2): # Stop until the Rich footer signature is found - # if data[2 * i] == RICH: # it should be followed by the checksum - # if data[2 * i + 1] != checksum: self.__warnings.append("Rich Header is malformed") break # header values come by pairs - # headervalues += [data[2 * i] ^ checksum, data[2 * i + 1] ^ checksum] return result