summaryrefslogtreecommitdiff
diff options
context:
space:
mode:
authorAndrei Karas <akaras@inbox.ru>2014-09-12 11:49:58 +0300
committerAndrei Karas <akaras@inbox.ru>2014-09-12 11:49:58 +0300
commit0b72e2bde003c95e59cf01328320546df870ec1c (patch)
tree38cb68b6629d5c569b291590999172487b64e24d
parent998c8c5abbc90b959e02b69212222b51e65e232f (diff)
downloadevol-tools-0b72e2bde003c95e59cf01328320546df870ec1c.tar.gz
evol-tools-0b72e2bde003c95e59cf01328320546df870ec1c.tar.bz2
evol-tools-0b72e2bde003c95e59cf01328320546df870ec1c.tar.xz
evol-tools-0b72e2bde003c95e59cf01328320546df870ec1c.zip
add tool for simpler upgrade packet version from hercules.
-rw-r--r--herculesversion/.gitignore1
-rwxr-xr-xherculesversion/packetversion.py97
2 files changed, 98 insertions, 0 deletions
diff --git a/herculesversion/.gitignore b/herculesversion/.gitignore
new file mode 100644
index 0000000..36bfe43
--- /dev/null
+++ b/herculesversion/.gitignore
@@ -0,0 +1 @@
+hercules
diff --git a/herculesversion/packetversion.py b/herculesversion/packetversion.py
new file mode 100755
index 0000000..736d26c
--- /dev/null
+++ b/herculesversion/packetversion.py
@@ -0,0 +1,97 @@
+#! /usr/bin/env python
+# -*- coding: utf8 -*-
+#
+# Copyright (C) 2014 Evol Online
+# Author: Andrei Karas (4144)
+
+import array
+import base64
+import gzip
+import os
+import re
+import datetime
+import xml
+import csv
+import ogg.vorbis
+import StringIO
+import sys
+import zlib
+import struct
+import shutil
+from sets import Set
+
+defStart = "#if PACKETVER >= "
+defEnd = "#endif"
+packetStart = "packet(";
+packetRe = re.compile("\tpacket[(](?P<id>([^,]+)),(?P<size>([^,])+),(?P<func>([^,]+))")
+
+def makeDir(path):
+ if not os.path.exists(path):
+ os.makedirs(path)
+
+def saveFile(fileName, data):
+ with open(fileName, "w") as w:
+ w.write(data)
+
+def parsePacket(line):
+ m = packetRe.search(line)
+ if m is not None:
+ return (m.group("id"), m.group("size"), m.group("func"))
+ return None
+
+def readPackets(path, oldVersion, newVersion):
+ oldPackets = {}
+ newPackets = {}
+ with open(path, "r") as f:
+ searchState = 0
+ newBlock = False
+ for line in f:
+ if searchState == 0: # search for #if PACKETVER
+ if line.find(defStart) == 0:
+ ver = int(line[len(defStart):])
+ if ver <= newVersion:
+ if ver > oldVersion:
+ newBlock = True
+ else:
+ newBlock = False
+ searchState = 1
+ elif searchState == 1: # read block body
+ if line.find(packetStart) == 1:
+ data = parsePacket(line)
+ if data is not None:
+ if newBlock == True:
+ newPackets[data[0]] = data
+ else:
+ oldPackets[data[0]] = data
+ elif line.find(defEnd) == 0:
+ searchState = 0
+ return (oldPackets, newPackets)
+
+def findChangedPackets(data):
+ old = data[0]
+ new = data[1]
+ ret = []
+ for line in old.iteritems():
+ if line[0] in new:
+ ret.append(line[1])
+ return (ret, new)
+
+def showPlan(data):
+ oldFunc = {}
+ newFunc = {}
+ for line in data[0]:
+ oldFunc[line[2]] = line
+ for line in data[1].iteritems():
+ newFunc[line[1][2]] = line[1]
+
+ for line in oldFunc:
+ print "{0:30} {1:4} {2}".format(line, oldFunc[line][0], newFunc[line][0])
+# if line not in newFunc:
+# print line
+
+def main():
+ data = readPackets("hercules/src/map/packets.h", 20131223, 20131230)
+ changed = findChangedPackets(data)
+ showPlan(changed)
+
+main()