From d5e9bbcf96cf98d767ba073774b1ee287569659d Mon Sep 17 00:00:00 2001 From: hch <305670599@qq.com> Date: 星期六, 24 十一月 2018 18:20:13 +0800 Subject: [PATCH] Merge branch 'master' of http://192.168.0.87:10010/r/SnxxServerCode --- ServerPython/CoreServerGroup/GameServer/Script/ChPyNetSendPack.py | 93 +++++++++++++++++++++++++++++++++------------- 1 files changed, 66 insertions(+), 27 deletions(-) diff --git a/ServerPython/CoreServerGroup/GameServer/Script/ChPyNetSendPack.py b/ServerPython/CoreServerGroup/GameServer/Script/ChPyNetSendPack.py index 62203d8..8676a55 100644 --- a/ServerPython/CoreServerGroup/GameServer/Script/ChPyNetSendPack.py +++ b/ServerPython/CoreServerGroup/GameServer/Script/ChPyNetSendPack.py @@ -5821,6 +5821,7 @@ XianyuanCoinAdd = 0 #(WORD XianyuanCoinAdd)// 增加的仙缘币,0代表已达上限 Relation = 0 #(BYTE Relation)// 当时的关系:0-无,1-好友,2-盟友 VIPLV = 0 #(BYTE VIPLV)// 当时的VIP等级 + HelpTime = "" #(char HelpTime[19])// 助战时间yyyy-MM-dd hh:mm:ss data = None def __init__(self): @@ -5837,6 +5838,7 @@ self.XianyuanCoinAdd,_pos = CommFunc.ReadWORD(_lpData, _pos) self.Relation,_pos = CommFunc.ReadBYTE(_lpData, _pos) self.VIPLV,_pos = CommFunc.ReadBYTE(_lpData, _pos) + self.HelpTime,_pos = CommFunc.ReadString(_lpData, _pos,19) return _pos def Clear(self): @@ -5848,6 +5850,7 @@ self.XianyuanCoinAdd = 0 self.Relation = 0 self.VIPLV = 0 + self.HelpTime = "" return def GetLength(self): @@ -5860,6 +5863,7 @@ length += 2 length += 1 length += 1 + length += 19 return length @@ -5873,6 +5877,7 @@ data = CommFunc.WriteWORD(data, self.XianyuanCoinAdd) data = CommFunc.WriteBYTE(data, self.Relation) data = CommFunc.WriteBYTE(data, self.VIPLV) + data = CommFunc.WriteString(data, 19, self.HelpTime) return data def OutputString(self): @@ -5884,7 +5889,8 @@ FuncLineID:%d, XianyuanCoinAdd:%d, Relation:%d, - VIPLV:%d + VIPLV:%d, + HelpTime:%s '''\ %( self.CallPlayerID, @@ -5894,7 +5900,8 @@ self.FuncLineID, self.XianyuanCoinAdd, self.Relation, - self.VIPLV + self.VIPLV, + self.HelpTime ) return DumpString @@ -24640,60 +24647,92 @@ # B2 08 获得仙缘币信息 #tagMCAddXianyuanCoinMsg class tagMCAddXianyuanCoinMsg(Structure): - _pack_ = 1 - _fields_ = [ - ("Cmd", c_ubyte), - ("SubCmd", c_ubyte), - ("MapID", c_int), - ("FuncLineID", c_ubyte), - ("XianyuanCoinAdd", c_ushort), # 增加的仙缘币,0代表已达上限 - ] + Head = tagHead() + MapID = 0 #(DWORD MapID) + FuncLineID = 0 #(BYTE FuncLineID) + XianyuanCoinAdd = 0 #(WORD XianyuanCoinAdd)// 增加的仙缘币,0代表已达上限 + CallPlayerID = 0 #(DWORD CallPlayerID)// 助战的玩家ID,有值时代表真实助战,没有值时为自己打的 + NameLen = 0 #(BYTE NameLen) + CallPlayerName = "" #(String CallPlayerName)// 助战的玩家名,size = NameLen + data = None def __init__(self): self.Clear() - self.Cmd = 0xB2 - self.SubCmd = 0x08 + self.Head.Cmd = 0xB2 + self.Head.SubCmd = 0x08 return - def ReadData(self, stringData, _pos=0, _len=0): + def ReadData(self, _lpData, _pos=0, _Len=0): self.Clear() - memmove(addressof(self), stringData[_pos:], self.GetLength()) - return _pos + self.GetLength() + _pos = self.Head.ReadData(_lpData, _pos) + self.MapID,_pos = CommFunc.ReadDWORD(_lpData, _pos) + self.FuncLineID,_pos = CommFunc.ReadBYTE(_lpData, _pos) + self.XianyuanCoinAdd,_pos = CommFunc.ReadWORD(_lpData, _pos) + self.CallPlayerID,_pos = CommFunc.ReadDWORD(_lpData, _pos) + self.NameLen,_pos = CommFunc.ReadBYTE(_lpData, _pos) + self.CallPlayerName,_pos = CommFunc.ReadString(_lpData, _pos,self.NameLen) + return _pos def Clear(self): - self.Cmd = 0xB2 - self.SubCmd = 0x08 + self.Head = tagHead() + self.Head.Clear() + self.Head.Cmd = 0xB2 + self.Head.SubCmd = 0x08 self.MapID = 0 self.FuncLineID = 0 self.XianyuanCoinAdd = 0 + self.CallPlayerID = 0 + self.NameLen = 0 + self.CallPlayerName = "" return def GetLength(self): - return sizeof(tagMCAddXianyuanCoinMsg) + length = 0 + length += self.Head.GetLength() + length += 4 + length += 1 + length += 2 + length += 4 + length += 1 + length += len(self.CallPlayerName) + + return length def GetBuffer(self): - return string_at(addressof(self), self.GetLength()) + data = '' + data = CommFunc.WriteString(data, self.Head.GetLength(), self.Head.GetBuffer()) + data = CommFunc.WriteDWORD(data, self.MapID) + data = CommFunc.WriteBYTE(data, self.FuncLineID) + data = CommFunc.WriteWORD(data, self.XianyuanCoinAdd) + data = CommFunc.WriteDWORD(data, self.CallPlayerID) + data = CommFunc.WriteBYTE(data, self.NameLen) + data = CommFunc.WriteString(data, self.NameLen, self.CallPlayerName) + return data def OutputString(self): - DumpString = '''// B2 08 获得仙缘币信息 //tagMCAddXianyuanCoinMsg: - Cmd:%s, - SubCmd:%s, + DumpString = ''' + Head:%s, MapID:%d, FuncLineID:%d, - XianyuanCoinAdd:%d + XianyuanCoinAdd:%d, + CallPlayerID:%d, + NameLen:%d, + CallPlayerName:%s '''\ %( - self.Cmd, - self.SubCmd, + self.Head.OutputString(), self.MapID, self.FuncLineID, - self.XianyuanCoinAdd + self.XianyuanCoinAdd, + self.CallPlayerID, + self.NameLen, + self.CallPlayerName ) return DumpString m_NAtagMCAddXianyuanCoinMsg=tagMCAddXianyuanCoinMsg() -ChNetPackDict[eval("0x%02x%02x"%(m_NAtagMCAddXianyuanCoinMsg.Cmd,m_NAtagMCAddXianyuanCoinMsg.SubCmd))] = m_NAtagMCAddXianyuanCoinMsg +ChNetPackDict[eval("0x%02x%02x"%(m_NAtagMCAddXianyuanCoinMsg.Head.Cmd,m_NAtagMCAddXianyuanCoinMsg.Head.SubCmd))] = m_NAtagMCAddXianyuanCoinMsg #------------------------------------------------------ -- Gitblit v1.8.0