From 303a03f56c01092ce7a7194e994dea2089b4728d Mon Sep 17 00:00:00 2001
From: xdh <xiefantasy@qq.com>
Date: 星期四, 11 七月 2019 14:24:45 +0800
Subject: [PATCH] 7982 【后端】【主干】渡劫条件调整
---
ServerPython/CoreServerGroup/GameServer/Script/PyGameDataStruct.py | 417 +++++++++++++++++++++++++++++++++++++++++++++++++++++++----
1 files changed, 389 insertions(+), 28 deletions(-)
diff --git a/ServerPython/CoreServerGroup/GameServer/Script/PyGameDataStruct.py b/ServerPython/CoreServerGroup/GameServer/Script/PyGameDataStruct.py
index 8e1aa6e..383f78c 100644
--- a/ServerPython/CoreServerGroup/GameServer/Script/PyGameDataStruct.py
+++ b/ServerPython/CoreServerGroup/GameServer/Script/PyGameDataStruct.py
@@ -15,6 +15,335 @@
from ctypes import (Structure, memset, memmove, sizeof, addressof, create_string_buffer, string_at)
import CommFunc
+# 玩家数据查看缓存表Py #tagPlayerViewCachePy
+class tagPlayerViewCachePy(Structure):
+ _pack_ = 1
+ _fields_ = [
+ ('PlayerID', ctypes.c_ulong),
+ ('GeTuiIDSize', ctypes.c_ubyte),
+ ('GeTuiID', ctypes.c_char_p),
+ ('LV', ctypes.c_ushort),
+ ('OffTime', ctypes.c_ulong),
+ ('PropDataSize', ctypes.c_ushort),
+ ('PropData', ctypes.c_char_p),
+ ('PlusDataSize', ctypes.c_ushort),
+ ('PlusData', ctypes.c_char_p),
+ ('ItemDataSize1', ctypes.c_ushort),
+ ('ItemData1', ctypes.c_char_p),
+ ('ItemDataSize2', ctypes.c_ushort),
+ ('ItemData2', ctypes.c_char_p),
+ ('ItemDataSize3', ctypes.c_ushort),
+ ('ItemData3', ctypes.c_char_p),
+ ('ItemDataSize4', ctypes.c_ushort),
+ ('ItemData4', ctypes.c_char_p),
+ ('ItemDataSize5', ctypes.c_ushort),
+ ('ItemData5', ctypes.c_char_p),
+ ('ItemDataSize6', ctypes.c_ushort),
+ ('ItemData6', ctypes.c_char_p),
+ ('ItemDataSize7', ctypes.c_ushort),
+ ('ItemData7', ctypes.c_char_p),
+ ('ItemDataSize8', ctypes.c_ushort),
+ ('ItemData8', ctypes.c_char_p),
+ ('ItemDataSize9', ctypes.c_ushort),
+ ('ItemData9', ctypes.c_char_p),
+ ('ItemDataSize10', ctypes.c_ushort),
+ ('ItemData10', ctypes.c_char_p),
+ ('ItemDataSize11', ctypes.c_ushort),
+ ('ItemData11', ctypes.c_char_p),
+ ('ItemDataSize12', ctypes.c_ushort),
+ ('ItemData12', ctypes.c_char_p),
+ ('ItemDataSize13', ctypes.c_ushort),
+ ('ItemData13', ctypes.c_char_p),
+ ('ItemDataSize14', ctypes.c_ushort),
+ ('ItemData14', ctypes.c_char_p),
+ ('ItemDataSize15', ctypes.c_ushort),
+ ('ItemData15', ctypes.c_char_p),
+ ('ADOResult', ctypes.c_ulong),
+ ]
+
+ def __init__(self):
+ Structure.__init__(self)
+ self.clear()
+
+ def clear(self):
+ self.PlayerID = 0
+ self.GeTuiIDSize = 0
+ self.GeTuiID = ''
+ self.LV = 0
+ self.OffTime = 0
+ self.PropDataSize = 0
+ self.PropData = ''
+ self.PlusDataSize = 0
+ self.PlusData = ''
+ self.ItemDataSize1 = 0
+ self.ItemData1 = ''
+ self.ItemDataSize2 = 0
+ self.ItemData2 = ''
+ self.ItemDataSize3 = 0
+ self.ItemData3 = ''
+ self.ItemDataSize4 = 0
+ self.ItemData4 = ''
+ self.ItemDataSize5 = 0
+ self.ItemData5 = ''
+ self.ItemDataSize6 = 0
+ self.ItemData6 = ''
+ self.ItemDataSize7 = 0
+ self.ItemData7 = ''
+ self.ItemDataSize8 = 0
+ self.ItemData8 = ''
+ self.ItemDataSize9 = 0
+ self.ItemData9 = ''
+ self.ItemDataSize10 = 0
+ self.ItemData10 = ''
+ self.ItemDataSize11 = 0
+ self.ItemData11 = ''
+ self.ItemDataSize12 = 0
+ self.ItemData12 = ''
+ self.ItemDataSize13 = 0
+ self.ItemData13 = ''
+ self.ItemDataSize14 = 0
+ self.ItemData14 = ''
+ self.ItemDataSize15 = 0
+ self.ItemData15 = ''
+
+ def readData(self, buf, pos = 0, length = 0):
+ if not pos <= length:
+ return -1
+ if len(buf) < pos + self.getLength():
+ return -1
+ self.clear()
+ self.PlayerID, pos = CommFunc.ReadDWORD(buf, pos)
+ self.GeTuiIDSize, pos = CommFunc.ReadBYTE(buf, pos)
+ tmp, pos = CommFunc.ReadString(buf, pos, self.GeTuiIDSize)
+ self.GeTuiID = ctypes.c_char_p(tmp)
+ self.LV, pos = CommFunc.ReadWORD(buf, pos)
+ self.OffTime, pos = CommFunc.ReadDWORD(buf, pos)
+ self.PropDataSize, pos = CommFunc.ReadWORD(buf, pos)
+ tmp, pos = CommFunc.ReadString(buf, pos, self.PropDataSize)
+ self.PropData = ctypes.c_char_p(tmp)
+ self.PlusDataSize, pos = CommFunc.ReadWORD(buf, pos)
+ tmp, pos = CommFunc.ReadString(buf, pos, self.PlusDataSize)
+ self.PlusData = ctypes.c_char_p(tmp)
+ self.ItemDataSize1, pos = CommFunc.ReadWORD(buf, pos)
+ tmp, pos = CommFunc.ReadString(buf, pos, self.ItemDataSize1)
+ self.ItemData1 = ctypes.c_char_p(tmp)
+ self.ItemDataSize2, pos = CommFunc.ReadWORD(buf, pos)
+ tmp, pos = CommFunc.ReadString(buf, pos, self.ItemDataSize2)
+ self.ItemData2 = ctypes.c_char_p(tmp)
+ self.ItemDataSize3, pos = CommFunc.ReadWORD(buf, pos)
+ tmp, pos = CommFunc.ReadString(buf, pos, self.ItemDataSize3)
+ self.ItemData3 = ctypes.c_char_p(tmp)
+ self.ItemDataSize4, pos = CommFunc.ReadWORD(buf, pos)
+ tmp, pos = CommFunc.ReadString(buf, pos, self.ItemDataSize4)
+ self.ItemData4 = ctypes.c_char_p(tmp)
+ self.ItemDataSize5, pos = CommFunc.ReadWORD(buf, pos)
+ tmp, pos = CommFunc.ReadString(buf, pos, self.ItemDataSize5)
+ self.ItemData5 = ctypes.c_char_p(tmp)
+ self.ItemDataSize6, pos = CommFunc.ReadWORD(buf, pos)
+ tmp, pos = CommFunc.ReadString(buf, pos, self.ItemDataSize6)
+ self.ItemData6 = ctypes.c_char_p(tmp)
+ self.ItemDataSize7, pos = CommFunc.ReadWORD(buf, pos)
+ tmp, pos = CommFunc.ReadString(buf, pos, self.ItemDataSize7)
+ self.ItemData7 = ctypes.c_char_p(tmp)
+ self.ItemDataSize8, pos = CommFunc.ReadWORD(buf, pos)
+ tmp, pos = CommFunc.ReadString(buf, pos, self.ItemDataSize8)
+ self.ItemData8 = ctypes.c_char_p(tmp)
+ self.ItemDataSize9, pos = CommFunc.ReadWORD(buf, pos)
+ tmp, pos = CommFunc.ReadString(buf, pos, self.ItemDataSize9)
+ self.ItemData9 = ctypes.c_char_p(tmp)
+ self.ItemDataSize10, pos = CommFunc.ReadWORD(buf, pos)
+ tmp, pos = CommFunc.ReadString(buf, pos, self.ItemDataSize10)
+ self.ItemData10 = ctypes.c_char_p(tmp)
+ self.ItemDataSize11, pos = CommFunc.ReadWORD(buf, pos)
+ tmp, pos = CommFunc.ReadString(buf, pos, self.ItemDataSize11)
+ self.ItemData11 = ctypes.c_char_p(tmp)
+ self.ItemDataSize12, pos = CommFunc.ReadWORD(buf, pos)
+ tmp, pos = CommFunc.ReadString(buf, pos, self.ItemDataSize12)
+ self.ItemData12 = ctypes.c_char_p(tmp)
+ self.ItemDataSize13, pos = CommFunc.ReadWORD(buf, pos)
+ tmp, pos = CommFunc.ReadString(buf, pos, self.ItemDataSize13)
+ self.ItemData13 = ctypes.c_char_p(tmp)
+ self.ItemDataSize14, pos = CommFunc.ReadWORD(buf, pos)
+ tmp, pos = CommFunc.ReadString(buf, pos, self.ItemDataSize14)
+ self.ItemData14 = ctypes.c_char_p(tmp)
+ self.ItemDataSize15, pos = CommFunc.ReadWORD(buf, pos)
+ tmp, pos = CommFunc.ReadString(buf, pos, self.ItemDataSize15)
+ self.ItemData15 = ctypes.c_char_p(tmp)
+ return self.getLength()
+
+ def getBuffer(self):
+ buf = ''
+ buf = CommFunc.WriteDWORD(buf, self.PlayerID)
+ buf = CommFunc.WriteBYTE(buf, self.GeTuiIDSize)
+ buf = CommFunc.WriteString(buf, self.GeTuiIDSize, self.GeTuiID)
+ buf = CommFunc.WriteWORD(buf, self.LV)
+ buf = CommFunc.WriteDWORD(buf, self.OffTime)
+ buf = CommFunc.WriteWORD(buf, self.PropDataSize)
+ buf = CommFunc.WriteString(buf, self.PropDataSize, self.PropData)
+ buf = CommFunc.WriteWORD(buf, self.PlusDataSize)
+ buf = CommFunc.WriteString(buf, self.PlusDataSize, self.PlusData)
+ buf = CommFunc.WriteWORD(buf, self.ItemDataSize1)
+ buf = CommFunc.WriteString(buf, self.ItemDataSize1, self.ItemData1)
+ buf = CommFunc.WriteWORD(buf, self.ItemDataSize2)
+ buf = CommFunc.WriteString(buf, self.ItemDataSize2, self.ItemData2)
+ buf = CommFunc.WriteWORD(buf, self.ItemDataSize3)
+ buf = CommFunc.WriteString(buf, self.ItemDataSize3, self.ItemData3)
+ buf = CommFunc.WriteWORD(buf, self.ItemDataSize4)
+ buf = CommFunc.WriteString(buf, self.ItemDataSize4, self.ItemData4)
+ buf = CommFunc.WriteWORD(buf, self.ItemDataSize5)
+ buf = CommFunc.WriteString(buf, self.ItemDataSize5, self.ItemData5)
+ buf = CommFunc.WriteWORD(buf, self.ItemDataSize6)
+ buf = CommFunc.WriteString(buf, self.ItemDataSize6, self.ItemData6)
+ buf = CommFunc.WriteWORD(buf, self.ItemDataSize7)
+ buf = CommFunc.WriteString(buf, self.ItemDataSize7, self.ItemData7)
+ buf = CommFunc.WriteWORD(buf, self.ItemDataSize8)
+ buf = CommFunc.WriteString(buf, self.ItemDataSize8, self.ItemData8)
+ buf = CommFunc.WriteWORD(buf, self.ItemDataSize9)
+ buf = CommFunc.WriteString(buf, self.ItemDataSize9, self.ItemData9)
+ buf = CommFunc.WriteWORD(buf, self.ItemDataSize10)
+ buf = CommFunc.WriteString(buf, self.ItemDataSize10, self.ItemData10)
+ buf = CommFunc.WriteWORD(buf, self.ItemDataSize11)
+ buf = CommFunc.WriteString(buf, self.ItemDataSize11, self.ItemData11)
+ buf = CommFunc.WriteWORD(buf, self.ItemDataSize12)
+ buf = CommFunc.WriteString(buf, self.ItemDataSize12, self.ItemData12)
+ buf = CommFunc.WriteWORD(buf, self.ItemDataSize13)
+ buf = CommFunc.WriteString(buf, self.ItemDataSize13, self.ItemData13)
+ buf = CommFunc.WriteWORD(buf, self.ItemDataSize14)
+ buf = CommFunc.WriteString(buf, self.ItemDataSize14, self.ItemData14)
+ buf = CommFunc.WriteWORD(buf, self.ItemDataSize15)
+ buf = CommFunc.WriteString(buf, self.ItemDataSize15, self.ItemData15)
+ return buf
+
+ def getLength(self):
+ length = 0
+ length += sizeof(ctypes.c_ulong)
+ length += sizeof(ctypes.c_ubyte)
+ length += self.GeTuiIDSize
+ length += sizeof(ctypes.c_ushort)
+ length += sizeof(ctypes.c_ulong)
+ length += sizeof(ctypes.c_ushort)
+ length += self.PropDataSize
+ length += sizeof(ctypes.c_ushort)
+ length += self.PlusDataSize
+ length += sizeof(ctypes.c_ushort)
+ length += self.ItemDataSize1
+ length += sizeof(ctypes.c_ushort)
+ length += self.ItemDataSize2
+ length += sizeof(ctypes.c_ushort)
+ length += self.ItemDataSize3
+ length += sizeof(ctypes.c_ushort)
+ length += self.ItemDataSize4
+ length += sizeof(ctypes.c_ushort)
+ length += self.ItemDataSize5
+ length += sizeof(ctypes.c_ushort)
+ length += self.ItemDataSize6
+ length += sizeof(ctypes.c_ushort)
+ length += self.ItemDataSize7
+ length += sizeof(ctypes.c_ushort)
+ length += self.ItemDataSize8
+ length += sizeof(ctypes.c_ushort)
+ length += self.ItemDataSize9
+ length += sizeof(ctypes.c_ushort)
+ length += self.ItemDataSize10
+ length += sizeof(ctypes.c_ushort)
+ length += self.ItemDataSize11
+ length += sizeof(ctypes.c_ushort)
+ length += self.ItemDataSize12
+ length += sizeof(ctypes.c_ushort)
+ length += self.ItemDataSize13
+ length += sizeof(ctypes.c_ushort)
+ length += self.ItemDataSize14
+ length += sizeof(ctypes.c_ushort)
+ length += self.ItemDataSize15
+ return length
+
+ def outputString(self):
+ output = '''// 玩家数据查看缓存表Py #tagPlayerViewCachePy:
+ PlayerID = %s,
+ GeTuiIDSize = %s,
+ GeTuiID = %s,
+ LV = %s,
+ OffTime = %s,
+ PropDataSize = %s,
+ PropData = %s,
+ PlusDataSize = %s,
+ PlusData = %s,
+ ItemDataSize1 = %s,
+ ItemData1 = %s,
+ ItemDataSize2 = %s,
+ ItemData2 = %s,
+ ItemDataSize3 = %s,
+ ItemData3 = %s,
+ ItemDataSize4 = %s,
+ ItemData4 = %s,
+ ItemDataSize5 = %s,
+ ItemData5 = %s,
+ ItemDataSize6 = %s,
+ ItemData6 = %s,
+ ItemDataSize7 = %s,
+ ItemData7 = %s,
+ ItemDataSize8 = %s,
+ ItemData8 = %s,
+ ItemDataSize9 = %s,
+ ItemData9 = %s,
+ ItemDataSize10 = %s,
+ ItemData10 = %s,
+ ItemDataSize11 = %s,
+ ItemData11 = %s,
+ ItemDataSize12 = %s,
+ ItemData12 = %s,
+ ItemDataSize13 = %s,
+ ItemData13 = %s,
+ ItemDataSize14 = %s,
+ ItemData14 = %s,
+ ItemDataSize15 = %s,
+ ItemData15 = %s,
+ ADOResult = %s,
+ '''%(
+ self.PlayerID,
+ self.GeTuiIDSize,
+ self.GeTuiID,
+ self.LV,
+ self.OffTime,
+ self.PropDataSize,
+ self.PropData,
+ self.PlusDataSize,
+ self.PlusData,
+ self.ItemDataSize1,
+ self.ItemData1,
+ self.ItemDataSize2,
+ self.ItemData2,
+ self.ItemDataSize3,
+ self.ItemData3,
+ self.ItemDataSize4,
+ self.ItemData4,
+ self.ItemDataSize5,
+ self.ItemData5,
+ self.ItemDataSize6,
+ self.ItemData6,
+ self.ItemDataSize7,
+ self.ItemData7,
+ self.ItemDataSize8,
+ self.ItemData8,
+ self.ItemDataSize9,
+ self.ItemData9,
+ self.ItemDataSize10,
+ self.ItemData10,
+ self.ItemDataSize11,
+ self.ItemData11,
+ self.ItemDataSize12,
+ self.ItemData12,
+ self.ItemDataSize13,
+ self.ItemData13,
+ self.ItemDataSize14,
+ self.ItemData14,
+ self.ItemDataSize15,
+ self.ItemData15,
+ self.ADOResult,
+ )
+ return output
+
+
# 拍卖关注表 #tagDBAuctionAttention
class tagDBAuctionAttention(Structure):
_pack_ = 1
@@ -83,8 +412,10 @@
('PlayerID', ctypes.c_ulong),
('FamilyID', ctypes.c_ulong),
('RecordType', ctypes.c_ubyte),
+ ('RecordResult', ctypes.c_ubyte),
('RecordTime', ctypes.c_char * 19),
- ('RecordPrice', ctypes.c_ulong),
+ ('BidderPrice', ctypes.c_ulong),
+ ('BidderName', ctypes.c_char * 33),
('ItemID', ctypes.c_ulong),
('Count', ctypes.c_ushort),
('UserDataLen', ctypes.c_ushort),
@@ -101,8 +432,10 @@
self.PlayerID = 0
self.FamilyID = 0
self.RecordType = 0
+ self.RecordResult = 0
self.RecordTime = ''
- self.RecordPrice = 0
+ self.BidderPrice = 0
+ self.BidderName = ''
self.ItemID = 0
self.Count = 0
self.UserDataLen = 0
@@ -118,8 +451,10 @@
self.PlayerID, pos = CommFunc.ReadDWORD(buf, pos)
self.FamilyID, pos = CommFunc.ReadDWORD(buf, pos)
self.RecordType, pos = CommFunc.ReadBYTE(buf, pos)
+ self.RecordResult, pos = CommFunc.ReadBYTE(buf, pos)
self.RecordTime, pos = CommFunc.ReadString(buf, pos, 19)
- self.RecordPrice, pos = CommFunc.ReadDWORD(buf, pos)
+ self.BidderPrice, pos = CommFunc.ReadDWORD(buf, pos)
+ self.BidderName, pos = CommFunc.ReadString(buf, pos, 33)
self.ItemID, pos = CommFunc.ReadDWORD(buf, pos)
self.Count, pos = CommFunc.ReadWORD(buf, pos)
self.UserDataLen, pos = CommFunc.ReadWORD(buf, pos)
@@ -133,8 +468,10 @@
buf = CommFunc.WriteDWORD(buf, self.PlayerID)
buf = CommFunc.WriteDWORD(buf, self.FamilyID)
buf = CommFunc.WriteBYTE(buf, self.RecordType)
+ buf = CommFunc.WriteBYTE(buf, self.RecordResult)
buf = CommFunc.WriteString(buf, sizeof(ctypes.c_char) * 19, self.RecordTime)
- buf = CommFunc.WriteDWORD(buf, self.RecordPrice)
+ buf = CommFunc.WriteDWORD(buf, self.BidderPrice)
+ buf = CommFunc.WriteString(buf, sizeof(ctypes.c_char) * 33, self.BidderName)
buf = CommFunc.WriteDWORD(buf, self.ItemID)
buf = CommFunc.WriteWORD(buf, self.Count)
buf = CommFunc.WriteWORD(buf, self.UserDataLen)
@@ -147,8 +484,10 @@
length += sizeof(ctypes.c_ulong)
length += sizeof(ctypes.c_ulong)
length += sizeof(ctypes.c_ubyte)
+ length += sizeof(ctypes.c_ubyte)
length += sizeof(ctypes.c_char) * 19
length += sizeof(ctypes.c_ulong)
+ length += sizeof(ctypes.c_char) * 33
length += sizeof(ctypes.c_ulong)
length += sizeof(ctypes.c_ushort)
length += sizeof(ctypes.c_ushort)
@@ -161,8 +500,10 @@
PlayerID = %s,
FamilyID = %s,
RecordType = %s,
+ RecordResult = %s,
RecordTime = %s,
- RecordPrice = %s,
+ BidderPrice = %s,
+ BidderName = %s,
ItemID = %s,
Count = %s,
UserDataLen = %s,
@@ -173,8 +514,10 @@
self.PlayerID,
self.FamilyID,
self.RecordType,
+ self.RecordResult,
self.RecordTime,
- self.RecordPrice,
+ self.BidderPrice,
+ self.BidderName,
self.ItemID,
self.Count,
self.UserDataLen,
@@ -195,6 +538,12 @@
self.RecordTime = Str
else:
self.RecordTime = Str[:19]
+
+ def SetBidderName(self,Str):
+ if len(Str)<=33:
+ self.BidderName = Str
+ else:
+ self.BidderName = Str[:33]
# 拍卖物品表 #tagDBAuctionItem
@@ -585,14 +934,22 @@
def clear(self):
memset(addressof(self), 0, self.getLength())
-
def readData(self, buf, pos = 0, length = 0):
if not pos <= length:
return -1
if len(buf) < pos + self.getLength():
return -1
self.clear()
- memmove(addressof(self), buf[pos:], self.getLength())
+ self.ZoneID, pos = CommFunc.ReadBYTE(buf, pos)
+ self.SeasonID, pos = CommFunc.ReadBYTE(buf, pos)
+ self.PlayerID, pos = CommFunc.ReadDWORD(buf, pos)
+ self.PlayerName, pos = CommFunc.ReadString(buf, pos, 33)
+ self.Job, pos = CommFunc.ReadBYTE(buf, pos)
+ self.FightPower, pos = CommFunc.ReadDWORD(buf, pos)
+ self.RealmLV, pos = CommFunc.ReadWORD(buf, pos)
+ self.PKScore, pos = CommFunc.ReadDWORD(buf, pos)
+ self.DanLV, pos = CommFunc.ReadBYTE(buf, pos)
+ self.Time, pos = CommFunc.ReadDWORD(buf, pos)
return self.getLength()
@@ -638,7 +995,7 @@
self.PlayerName = Str
else:
self.PlayerName = Str[:33]
-
+
#仙魔之争记录表#tagDBPyXMZZ
class tagDBPyXMZZ(Structure):
@@ -775,14 +1132,15 @@
def clear(self):
memset(addressof(self), 0, self.getLength())
-
def readData(self, buf, pos = 0, length = 0):
if not pos <= length:
return -1
if len(buf) < pos + self.getLength():
return -1
self.clear()
- memmove(addressof(self), buf[pos:], self.getLength())
+ self.PlayerID, pos = CommFunc.ReadDWORD(buf, pos)
+ self.LineID, pos = CommFunc.ReadBYTE(buf, pos)
+ self.Rank, pos = CommFunc.ReadWORD(buf, pos)
return self.getLength()
@@ -807,7 +1165,6 @@
self.ADOResult,
)
return output
-
#Boss关注记录表#tagDBPyBossAttention
@@ -870,7 +1227,6 @@
return output
-
#交易所物品最近成交单价表#tagDBPyBourseItemLastPrice
class tagDBPyBourseItemLastPrice(Structure):
_pack_ = 1
@@ -888,14 +1244,14 @@
def clear(self):
memset(addressof(self), 0, self.getLength())
-
def readData(self, buf, pos = 0, length = 0):
if not pos <= length:
return -1
if len(buf) < pos + self.getLength():
return -1
self.clear()
- memmove(addressof(self), buf[pos:], self.getLength())
+ self.ItemID, pos = CommFunc.ReadDWORD(buf, pos)
+ self.LastPrice, pos = CommFunc.ReadDWORD(buf, pos)
return self.getLength()
@@ -1081,7 +1437,6 @@
)
return output
-
#玩家黑名单 #tagDBPyPlayerBlack
class tagDBPyPlayerBlack(Structure):
_pack_ = 1
@@ -1099,14 +1454,14 @@
def clear(self):
memset(addressof(self), 0, self.getLength())
-
def readData(self, buf, pos = 0, length = 0):
if not pos <= length:
return -1
if len(buf) < pos + self.getLength():
return -1
self.clear()
- memmove(addressof(self), buf[pos:], self.getLength())
+ self.PlayerID, pos = CommFunc.ReadDWORD(buf, pos)
+ self.TagID, pos = CommFunc.ReadDWORD(buf, pos)
return self.getLength()
@@ -1148,14 +1503,15 @@
def clear(self):
memset(addressof(self), 0, self.getLength())
-
def readData(self, buf, pos = 0, length = 0):
if not pos <= length:
return -1
if len(buf) < pos + self.getLength():
return -1
self.clear()
- memmove(addressof(self), buf[pos:], self.getLength())
+ self.PlayerID, pos = CommFunc.ReadDWORD(buf, pos)
+ self.TagID, pos = CommFunc.ReadDWORD(buf, pos)
+ self.Timestamp, pos = CommFunc.ReadDWORD(buf, pos)
return self.getLength()
@@ -1198,14 +1554,14 @@
def clear(self):
memset(addressof(self), 0, self.getLength())
-
def readData(self, buf, pos = 0, length = 0):
if not pos <= length:
return -1
if len(buf) < pos + self.getLength():
return -1
self.clear()
- memmove(addressof(self), buf[pos:], self.getLength())
+ self.PlayerID, pos = CommFunc.ReadDWORD(buf, pos)
+ self.TagID, pos = CommFunc.ReadDWORD(buf, pos)
return self.getLength()
@@ -1229,6 +1585,7 @@
)
return output
+
#玩家仇人表#tagPlayerEnemy
class tagPlayerEnemy(Structure):
_pack_ = 1
@@ -1247,14 +1604,15 @@
def clear(self):
memset(addressof(self), 0, self.getLength())
-
def readData(self, buf, pos = 0, length = 0):
if not pos <= length:
return -1
if len(buf) < pos + self.getLength():
return -1
self.clear()
- memmove(addressof(self), buf[pos:], self.getLength())
+ self.PlayerID, pos = CommFunc.ReadDWORD(buf, pos)
+ self.TagID, pos = CommFunc.ReadDWORD(buf, pos)
+ self.Timestamp, pos = CommFunc.ReadDWORD(buf, pos)
return self.getLength()
@@ -1281,7 +1639,6 @@
return output
-
#个人社交总表 #tagPersonalSocial
class tagPersonalSocial(Structure):
_pack_ = 1
@@ -1304,14 +1661,19 @@
def clear(self):
memset(addressof(self), 0, self.getLength())
-
def readData(self, buf, pos = 0, length = 0):
if not pos <= length:
return -1
if len(buf) < pos + self.getLength():
return -1
self.clear()
- memmove(addressof(self), buf[pos:], self.getLength())
+ self.PlayerID, pos = CommFunc.ReadDWORD(buf, pos)
+ self.PlayerName, pos = CommFunc.ReadString(buf, pos, 33)
+ self.Job, pos = CommFunc.ReadBYTE(buf, pos)
+ self.LV, pos = CommFunc.ReadWORD(buf, pos)
+ self.RealmLV, pos = CommFunc.ReadWORD(buf, pos)
+ self.OnlineType, pos = CommFunc.ReadBYTE(buf, pos)
+ self.RefCount, pos = CommFunc.ReadDWORD(buf, pos)
return self.getLength()
@@ -1352,5 +1714,4 @@
else:
self.PlayerName = Str[:33]
-
--
Gitblit v1.8.0