summaryrefslogtreecommitdiff
path: root/servergreps/hercules/src/ragemu.py
diff options
context:
space:
mode:
authorAndrei Karas <akaras@inbox.ru>2016-09-09 02:00:43 +0300
committerAndrei Karas <akaras@inbox.ru>2016-09-09 02:00:43 +0300
commit73c5db63ab53190e82adca823c6e400e0d1fa8ca (patch)
treefa25850b24989503cf9b4fab1e5e54b447c22237 /servergreps/hercules/src/ragemu.py
parentfe161e907c03f6c148c45658367a57eb2349534c (diff)
downloadevol-tools-73c5db63ab53190e82adca823c6e400e0d1fa8ca.tar.gz
evol-tools-73c5db63ab53190e82adca823c6e400e0d1fa8ca.tar.bz2
evol-tools-73c5db63ab53190e82adca823c6e400e0d1fa8ca.tar.xz
evol-tools-73c5db63ab53190e82adca823c6e400e0d1fa8ca.zip
servergreps: add parsing more packets.
Diffstat (limited to 'servergreps/hercules/src/ragemu.py')
-rwxr-xr-xservergreps/hercules/src/ragemu.py14
1 files changed, 14 insertions, 0 deletions
diff --git a/servergreps/hercules/src/ragemu.py b/servergreps/hercules/src/ragemu.py
index 90dbf35..47811a4 100755
--- a/servergreps/hercules/src/ragemu.py
+++ b/servergreps/hercules/src/ragemu.py
@@ -31,6 +31,9 @@ class Ragemu:
"(WFIFOW|WBUFW)([ ]*)[(]([ ]*)([\w>_-]+),([ ]*)" +
"(?P<offset>0)([ ]*)[)]([ ]*)=([ ]*)(?P<packet>[0-9\w]+)([ ]*)[;]")
ourPacketre4 = re.compile("int cmd([ ]*)=([ ]*)0x(?P<packet>[0-9a-fA-F]+);")
+ ourPacketre5 = re.compile(
+ "(WFIFOW|WBUFW)([ ]*)[(]([ ]*)([\w>_-]+),([ ]*)" +
+ "(count[*]p_len)([ ]*)[)]([ ]*)=([ ]*)(?P<packet>[0-9\w]+)([ ]*)[;]")
outPacketLoginre = re.compile(
"([ ]*)PACKET_ID_(?P<name>[A-Z0-9_]+)([ ]*)=" +
"([ ]*)0x(?P<packet>[0-9a-fA-F]+),")
@@ -62,6 +65,10 @@ class Ragemu:
return
self.packetsSet.add(val)
else:
+ if len(data) > 2 and data[:2] == "0x":
+ data = data[2:]
+ while len(data) < 4:
+ data = "0" + data
try:
if int(data, 16) > 4096:
return
@@ -89,6 +96,13 @@ class Ragemu:
while len(data) < 4:
data = "0" + data
self.addServerPacket(data)
+ m = self.ourPacketre5.findall(line)
+ if len(m) > 0:
+ for str in m:
+ data = str[9]
+ while len(data) < 4:
+ data = "0" + data
+ self.addServerPacket(data)
m = self.outPacketLoginre.findall(line)
if len(m) > 0:
for str in m: