hch
2018-12-26 7b9354771ba6087012ca989f02d7bca345ed1764
860312 脱机工具封包补齐
7个文件已修改
22391 ■■■■■ 已修改文件
Tool/Robot/Protocol/PacketsReceived.py 174 ●●●●● 补丁 | 查看 | 原始文档 | blame | 历史
Tool/Robot/Protocol/PacketsReceivedPY.py 4547 ●●●● 补丁 | 查看 | 原始文档 | blame | 历史
Tool/Robot/Protocol/PacketsSendPY.py 1407 ●●●● 补丁 | 查看 | 原始文档 | blame | 历史
Tool/RobotTest/Protocol/PacketsReceived.py 272 ●●●●● 补丁 | 查看 | 原始文档 | blame | 历史
Tool/RobotTest/Protocol/PacketsReceivedPY.py 11466 ●●●●● 补丁 | 查看 | 原始文档 | blame | 历史
Tool/RobotTest/Protocol/PacketsSend.py 34 ●●●● 补丁 | 查看 | 原始文档 | blame | 历史
Tool/RobotTest/Protocol/PacketsSendPY.py 4491 ●●●●● 补丁 | 查看 | 原始文档 | blame | 历史
Tool/Robot/Protocol/PacketsReceived.py
@@ -983,7 +983,7 @@
    LV = 0    #(WORD LV)//等级
    LVEx = 0    #(WORD LVEx)//玩家等级副本,用于转生
    LV2 = 0    #(WORD LV2)//大师等级
    ExpPoint = 0    #(WORD ExpPoint)//扩充经验点数
    ExpPoint = 0    #(DWORD ExpPoint)//扩充经验点数
    TotalExp = 0    #(DWORD TotalExp)//总经验
    Family = 0    #(DWORD Family)//家族
    FamilyName = ""    #(char FamilyName[33])//家族名称
@@ -1062,6 +1062,12 @@
    OperateInfo = 0    #(DWORD OperateInfo)//玩家附加运营商信息
    Operate = ""    #(char Operate[15])//所属运营商平台名
    ServerID = 0    #(DWORD ServerID)//所属区服ID
    ExAttr15 = 0    #(DWORD ExAttr15)//预留的扩展属性字段,用来存放项目特定的属性
    ExAttr16 = 0    #(DWORD ExAttr16)//预留的扩展属性字段,用来存放项目特定的属性
    ExAttr17 = 0    #(DWORD ExAttr17)//预留的扩展属性字段,用来存放项目特定的属性
    ExAttr18 = 0    #(DWORD ExAttr18)//预留的扩展属性字段,用来存放项目特定的属性
    ExAttr19 = 0    #(DWORD ExAttr19)//预留的扩展属性字段,用来存放项目特定的属性
    ExAttr20 = 0    #(DWORD ExAttr20)//预留的扩展属性字段,用来存放项目特定的属性
    data = None
    def __init__(self):
@@ -1084,7 +1090,7 @@
        self.LV,_pos = CommFunc.ReadWORD(_lpData, _pos)
        self.LVEx,_pos = CommFunc.ReadWORD(_lpData, _pos)
        self.LV2,_pos = CommFunc.ReadWORD(_lpData, _pos)
        self.ExpPoint,_pos = CommFunc.ReadWORD(_lpData, _pos)
        self.ExpPoint,_pos = CommFunc.ReadDWORD(_lpData, _pos)
        self.TotalExp,_pos = CommFunc.ReadDWORD(_lpData, _pos)
        self.Family,_pos = CommFunc.ReadDWORD(_lpData, _pos)
        self.FamilyName,_pos = CommFunc.ReadString(_lpData, _pos,33)
@@ -1163,6 +1169,12 @@
        self.OperateInfo,_pos = CommFunc.ReadDWORD(_lpData, _pos)
        self.Operate,_pos = CommFunc.ReadString(_lpData, _pos,15)
        self.ServerID,_pos = CommFunc.ReadDWORD(_lpData, _pos)
        self.ExAttr15,_pos = CommFunc.ReadDWORD(_lpData, _pos)
        self.ExAttr16,_pos = CommFunc.ReadDWORD(_lpData, _pos)
        self.ExAttr17,_pos = CommFunc.ReadDWORD(_lpData, _pos)
        self.ExAttr18,_pos = CommFunc.ReadDWORD(_lpData, _pos)
        self.ExAttr19,_pos = CommFunc.ReadDWORD(_lpData, _pos)
        self.ExAttr20,_pos = CommFunc.ReadDWORD(_lpData, _pos)
        return _pos
    def Clear(self):
@@ -1260,6 +1272,12 @@
        self.OperateInfo = 0
        self.Operate = ""
        self.ServerID = 0
        self.ExAttr15 = 0
        self.ExAttr16 = 0
        self.ExAttr17 = 0
        self.ExAttr18 = 0
        self.ExAttr19 = 0
        self.ExAttr20 = 0
        return
    def GetLength(self):
@@ -1276,7 +1294,7 @@
        length += 2
        length += 2
        length += 2
        length += 2
        length += 4
        length += 4
        length += 4
        length += 33
@@ -1355,6 +1373,12 @@
        length += 4
        length += 15
        length += 4
        length += 4
        length += 4
        length += 4
        length += 4
        length += 4
        length += 4
        return length
@@ -1372,7 +1396,7 @@
        data = CommFunc.WriteWORD(data, self.LV)
        data = CommFunc.WriteWORD(data, self.LVEx)
        data = CommFunc.WriteWORD(data, self.LV2)
        data = CommFunc.WriteWORD(data, self.ExpPoint)
        data = CommFunc.WriteDWORD(data, self.ExpPoint)
        data = CommFunc.WriteDWORD(data, self.TotalExp)
        data = CommFunc.WriteDWORD(data, self.Family)
        data = CommFunc.WriteString(data, 33, self.FamilyName)
@@ -1451,6 +1475,12 @@
        data = CommFunc.WriteDWORD(data, self.OperateInfo)
        data = CommFunc.WriteString(data, 15, self.Operate)
        data = CommFunc.WriteDWORD(data, self.ServerID)
        data = CommFunc.WriteDWORD(data, self.ExAttr15)
        data = CommFunc.WriteDWORD(data, self.ExAttr16)
        data = CommFunc.WriteDWORD(data, self.ExAttr17)
        data = CommFunc.WriteDWORD(data, self.ExAttr18)
        data = CommFunc.WriteDWORD(data, self.ExAttr19)
        data = CommFunc.WriteDWORD(data, self.ExAttr20)
        return data
    def OutputString(self):
@@ -1545,7 +1575,13 @@
                                ExAttr14:%d,
                                OperateInfo:%d,
                                Operate:%s,
                                ServerID:%d
                                ServerID:%d,
                                ExAttr15:%d,
                                ExAttr16:%d,
                                ExAttr17:%d,
                                ExAttr18:%d,
                                ExAttr19:%d,
                                ExAttr20:%d
                                '''\
                                %(
                                self.Head.OutputString(),
@@ -1638,7 +1674,13 @@
                                self.ExAttr14,
                                self.OperateInfo,
                                self.Operate,
                                self.ServerID
                                self.ServerID,
                                self.ExAttr15,
                                self.ExAttr16,
                                self.ExAttr17,
                                self.ExAttr18,
                                self.ExAttr19,
                                self.ExAttr20
                                )
        return DumpString
@@ -7095,6 +7137,16 @@
    EquipCount = 0    #(BYTE EquipCount)
    EquipInfo = list()    #(vector<tagLoginInfoEquip> EquipInfo)//size = EquipCount
    EquipShowSwitch = 0    #(DWORD EquipShowSwitch)//玩家装备显示开关
    ExAttr15 = 0    #(DWORD ExAttr15)//预留的扩展属性字段,用来存放项目特定的属性
    ExAttr16 = 0    #(DWORD ExAttr16)//预留的扩展属性字段,用来存放项目特定的属性
    ExAttr17 = 0    #(DWORD ExAttr17)//预留的扩展属性字段,用来存放项目特定的属性
    ExAttr18 = 0    #(DWORD ExAttr18)//预留的扩展属性字段,用来存放项目特定的属性
    ExAttr19 = 0    #(DWORD ExAttr19)//预留的扩展属性字段,用来存放项目特定的属性
    ExAttr20 = 0    #(DWORD ExAttr20)//预留的扩展属性字段,用来存放项目特定的属性
    IPLen = 0    #(BYTE IPLen)
    IP = ""    #(String IP)// 跨服IP
    Port = 0    #(WORD Port)// 跨服端口
    CrossState = 0    #(BYTE CrossState)// 跨服状态0-非跨服状态,1-跨服状态,2-跨服状态异常
    data = None
    def __init__(self):
@@ -7118,6 +7170,16 @@
            _pos = temEquipInfo.ReadData(_lpData, _pos)
            self.EquipInfo.append(temEquipInfo)
        self.EquipShowSwitch,_pos = CommFunc.ReadDWORD(_lpData, _pos)
        self.ExAttr15,_pos = CommFunc.ReadDWORD(_lpData, _pos)
        self.ExAttr16,_pos = CommFunc.ReadDWORD(_lpData, _pos)
        self.ExAttr17,_pos = CommFunc.ReadDWORD(_lpData, _pos)
        self.ExAttr18,_pos = CommFunc.ReadDWORD(_lpData, _pos)
        self.ExAttr19,_pos = CommFunc.ReadDWORD(_lpData, _pos)
        self.ExAttr20,_pos = CommFunc.ReadDWORD(_lpData, _pos)
        self.IPLen,_pos = CommFunc.ReadBYTE(_lpData, _pos)
        self.IP,_pos = CommFunc.ReadString(_lpData, _pos,self.IPLen)
        self.Port,_pos = CommFunc.ReadWORD(_lpData, _pos)
        self.CrossState,_pos = CommFunc.ReadBYTE(_lpData, _pos)
        return _pos
    def Clear(self):
@@ -7134,6 +7196,16 @@
        self.EquipCount = 0
        self.EquipInfo = list()
        self.EquipShowSwitch = 0
        self.ExAttr15 = 0
        self.ExAttr16 = 0
        self.ExAttr17 = 0
        self.ExAttr18 = 0
        self.ExAttr19 = 0
        self.ExAttr20 = 0
        self.IPLen = 0
        self.IP = ""
        self.Port = 0
        self.CrossState = 0
        return
    def GetLength(self):
@@ -7149,6 +7221,16 @@
        for i in range(self.EquipCount):
            length += self.EquipInfo[i].GetLength()
        length += 4
        length += 4
        length += 4
        length += 4
        length += 4
        length += 4
        length += 4
        length += 1
        length += len(self.IP)
        length += 2
        length += 1
        return length
@@ -7165,6 +7247,16 @@
        for i in range(self.EquipCount):
            data = CommFunc.WriteString(data, self.EquipInfo[i].GetLength(), self.EquipInfo[i].GetBuffer())
        data = CommFunc.WriteDWORD(data, self.EquipShowSwitch)
        data = CommFunc.WriteDWORD(data, self.ExAttr15)
        data = CommFunc.WriteDWORD(data, self.ExAttr16)
        data = CommFunc.WriteDWORD(data, self.ExAttr17)
        data = CommFunc.WriteDWORD(data, self.ExAttr18)
        data = CommFunc.WriteDWORD(data, self.ExAttr19)
        data = CommFunc.WriteDWORD(data, self.ExAttr20)
        data = CommFunc.WriteBYTE(data, self.IPLen)
        data = CommFunc.WriteString(data, self.IPLen, self.IP)
        data = CommFunc.WriteWORD(data, self.Port)
        data = CommFunc.WriteBYTE(data, self.CrossState)
        return data
    def OutputString(self):
@@ -7178,7 +7270,17 @@
                                HavePswLV2:%d,
                                EquipCount:%d,
                                EquipInfo:%s,
                                EquipShowSwitch:%d
                                EquipShowSwitch:%d,
                                ExAttr15:%d,
                                ExAttr16:%d,
                                ExAttr17:%d,
                                ExAttr18:%d,
                                ExAttr19:%d,
                                ExAttr20:%d,
                                IPLen:%d,
                                IP:%s,
                                Port:%d,
                                CrossState:%d
                                '''\
                                %(
                                self.Head.OutputString(),
@@ -7190,7 +7292,17 @@
                                self.HavePswLV2,
                                self.EquipCount,
                                "...",
                                self.EquipShowSwitch
                                self.EquipShowSwitch,
                                self.ExAttr15,
                                self.ExAttr16,
                                self.ExAttr17,
                                self.ExAttr18,
                                self.ExAttr19,
                                self.ExAttr20,
                                self.IPLen,
                                self.IP,
                                self.Port,
                                self.CrossState
                                )
        return DumpString
@@ -8639,6 +8751,12 @@
    ExAttr5 = 0    #(DWORD ExAttr5)//预留的扩展属性字段,用来存放项目特定的属性
    ServerID = 0    #(DWORD ServerID)//所属区服ID
    State = 0    #(BYTE State)// 0.正常在线1.脱机挂在线 2脱机挂死亡
    ExAttr15 = 0    #(DWORD ExAttr15)//预留的扩展属性字段,用来存放项目特定的属性
    ExAttr16 = 0    #(DWORD ExAttr16)//预留的扩展属性字段,用来存放项目特定的属性
    ExAttr17 = 0    #(DWORD ExAttr17)//预留的扩展属性字段,用来存放项目特定的属性
    ExAttr18 = 0    #(DWORD ExAttr18)//预留的扩展属性字段,用来存放项目特定的属性
    ExAttr19 = 0    #(DWORD ExAttr19)//预留的扩展属性字段,用来存放项目特定的属性
    ExAttr20 = 0    #(DWORD ExAttr20)//预留的扩展属性字段,用来存放项目特定的属性
    data = None
    def __init__(self):
@@ -8696,6 +8814,12 @@
        self.ExAttr5,_pos = CommFunc.ReadDWORD(_lpData, _pos)
        self.ServerID,_pos = CommFunc.ReadDWORD(_lpData, _pos)
        self.State,_pos = CommFunc.ReadBYTE(_lpData, _pos)
        self.ExAttr15,_pos = CommFunc.ReadDWORD(_lpData, _pos)
        self.ExAttr16,_pos = CommFunc.ReadDWORD(_lpData, _pos)
        self.ExAttr17,_pos = CommFunc.ReadDWORD(_lpData, _pos)
        self.ExAttr18,_pos = CommFunc.ReadDWORD(_lpData, _pos)
        self.ExAttr19,_pos = CommFunc.ReadDWORD(_lpData, _pos)
        self.ExAttr20,_pos = CommFunc.ReadDWORD(_lpData, _pos)
        return _pos
    def Clear(self):
@@ -8743,6 +8867,12 @@
        self.ExAttr5 = 0
        self.ServerID = 0
        self.State = 0
        self.ExAttr15 = 0
        self.ExAttr16 = 0
        self.ExAttr17 = 0
        self.ExAttr18 = 0
        self.ExAttr19 = 0
        self.ExAttr20 = 0
        return
    def GetLength(self):
@@ -8790,6 +8920,12 @@
        length += 4
        length += 4
        length += 1
        length += 4
        length += 4
        length += 4
        length += 4
        length += 4
        length += 4
        return length
@@ -8838,6 +8974,12 @@
        data = CommFunc.WriteDWORD(data, self.ExAttr5)
        data = CommFunc.WriteDWORD(data, self.ServerID)
        data = CommFunc.WriteBYTE(data, self.State)
        data = CommFunc.WriteDWORD(data, self.ExAttr15)
        data = CommFunc.WriteDWORD(data, self.ExAttr16)
        data = CommFunc.WriteDWORD(data, self.ExAttr17)
        data = CommFunc.WriteDWORD(data, self.ExAttr18)
        data = CommFunc.WriteDWORD(data, self.ExAttr19)
        data = CommFunc.WriteDWORD(data, self.ExAttr20)
        return data
    def OutputString(self):
@@ -8882,7 +9024,13 @@
                                ExAttr4:%d,
                                ExAttr5:%d,
                                ServerID:%d,
                                State:%d
                                State:%d,
                                ExAttr15:%d,
                                ExAttr16:%d,
                                ExAttr17:%d,
                                ExAttr18:%d,
                                ExAttr19:%d,
                                ExAttr20:%d
                                '''\
                                %(
                                self.Head.OutputString(),
@@ -8925,7 +9073,13 @@
                                self.ExAttr4,
                                self.ExAttr5,
                                self.ServerID,
                                self.State
                                self.State,
                                self.ExAttr15,
                                self.ExAttr16,
                                self.ExAttr17,
                                self.ExAttr18,
                                self.ExAttr19,
                                self.ExAttr20
                                )
        return DumpString
Tool/Robot/Protocol/PacketsReceivedPY.py
Diff too large
Tool/Robot/Protocol/PacketsSendPY.py
@@ -1234,6 +1234,73 @@
#------------------------------------------------------
# A9 04 查询boss信息 #tagCGQueryBossInfo
class  tagCGQueryBossInfo(Structure):
    Head = tagHead()
    Count = 0    #(BYTE Count)//数量
    BossIDList = list()    #(vector<DWORD> BossIDList)//boosid
    data = None
    def __init__(self):
        self.Clear()
        self.Head.Cmd = 0xA9
        self.Head.SubCmd = 0x04
        return
    def ReadData(self, _lpData, _pos=0, _Len=0):
        self.Clear()
        _pos = self.Head.ReadData(_lpData, _pos)
        self.Count,_pos = CommFunc.ReadBYTE(_lpData, _pos)
        for i in range(self.Count):
            value,_pos=CommFunc.ReadDWORD(_lpData,_pos)
            self.BossIDList.append(value)
        return _pos
    def Clear(self):
        self.Head = tagHead()
        self.Head.Clear()
        self.Head.Cmd = 0xA9
        self.Head.SubCmd = 0x04
        self.Count = 0
        self.BossIDList = list()
        return
    def GetLength(self):
        length = 0
        length += self.Head.GetLength()
        length += 1
        length += 4 * self.Count
        return length
    def GetBuffer(self):
        data = ''
        data = CommFunc.WriteString(data, self.Head.GetLength(), self.Head.GetBuffer())
        data = CommFunc.WriteBYTE(data, self.Count)
        for i in range(self.Count):
            data = CommFunc.WriteDWORD(data, self.BossIDList[i])
        return data
    def OutputString(self):
        DumpString = '''
                                Head:%s,
                                Count:%d,
                                BossIDList:%s
                                '''\
                                %(
                                self.Head.OutputString(),
                                self.Count,
                                "..."
                                )
        return DumpString
m_NAtagCGQueryBossInfo=tagCGQueryBossInfo()
ChNetPackDict[eval("0x%02x%02x"%(m_NAtagCGQueryBossInfo.Head.Cmd,m_NAtagCGQueryBossInfo.Head.SubCmd))] = m_NAtagCGQueryBossInfo
#------------------------------------------------------
#A9 A1 查询玩家补偿#tagCGQueryCompensation
class  tagCGQueryCompensation(Structure):
@@ -2916,20 +2983,21 @@
#------------------------------------------------------
#C0 11 上传数据的活动类型 #tagActionMergeRegister
# C0 01 查看跨服竞技场赛季排行榜 #tagCGViewCrossPKBillboard
class  tagActionMergeRegister(Structure):
class  tagCGViewCrossPKBillboard(Structure):
    _pack_ = 1
    _fields_ = [
                  ("Cmd", c_ubyte),
                  ("SubCmd", c_ubyte),
                  ("ActionType", c_ubyte),    #活动类型
                  ("ZoneID", c_ubyte),    # 赛区ID
                  ("SeasonID", c_ubyte),    # 赛季ID
                  ]
    def __init__(self):
        self.Clear()
        self.Cmd = 0xC0
        self.SubCmd = 0x11
        self.SubCmd = 0x01
        return
    def ReadData(self, stringData, _pos=0, _len=0):
@@ -2939,49 +3007,52 @@
    def Clear(self):
        self.Cmd = 0xC0
        self.SubCmd = 0x11
        self.ActionType = 0
        self.SubCmd = 0x01
        self.ZoneID = 0
        self.SeasonID = 0
        return
    def GetLength(self):
        return sizeof(tagActionMergeRegister)
        return sizeof(tagCGViewCrossPKBillboard)
    def GetBuffer(self):
        return string_at(addressof(self), self.GetLength())
    def OutputString(self):
        DumpString = '''//C0 11 上传数据的活动类型 //tagActionMergeRegister:
        DumpString = '''// C0 01 查看跨服竞技场赛季排行榜 //tagCGViewCrossPKBillboard:
                                Cmd:%s,
                                SubCmd:%s,
                                ActionType:%d
                                ZoneID:%d,
                                SeasonID:%d
                                '''\
                                %(
                                self.Cmd,
                                self.SubCmd,
                                self.ActionType
                                self.ZoneID,
                                self.SeasonID
                                )
        return DumpString
m_NAtagActionMergeRegister=tagActionMergeRegister()
ChNetPackDict[eval("0x%02x%02x"%(m_NAtagActionMergeRegister.Cmd,m_NAtagActionMergeRegister.SubCmd))] = m_NAtagActionMergeRegister
m_NAtagCGViewCrossPKBillboard=tagCGViewCrossPKBillboard()
ChNetPackDict[eval("0x%02x%02x"%(m_NAtagCGViewCrossPKBillboard.Cmd,m_NAtagCGViewCrossPKBillboard.SubCmd))] = m_NAtagCGViewCrossPKBillboard
#------------------------------------------------------
#C0 12 跨服上传数据账号查询 #tagMergeRegisterAccQuery
# C0 02 查看跨服玩家信息 #tagCGViewCrossPlayerInfo
class  tagMergeRegisterAccQuery(Structure):
class  tagCGViewCrossPlayerInfo(Structure):
    _pack_ = 1
    _fields_ = [
                  ("Cmd", c_ubyte),
                  ("SubCmd", c_ubyte),
                  ("ActionType", c_ubyte),    #活动类型
                  ("PlayerID", c_int),    # 跨服玩家ID
                  ]
    def __init__(self):
        self.Clear()
        self.Cmd = 0xC0
        self.SubCmd = 0x12
        self.SubCmd = 0x02
        return
    def ReadData(self, stringData, _pos=0, _len=0):
@@ -2991,80 +3062,32 @@
    def Clear(self):
        self.Cmd = 0xC0
        self.SubCmd = 0x12
        self.ActionType = 0
        self.SubCmd = 0x02
        self.PlayerID = 0
        return
    def GetLength(self):
        return sizeof(tagMergeRegisterAccQuery)
        return sizeof(tagCGViewCrossPlayerInfo)
    def GetBuffer(self):
        return string_at(addressof(self), self.GetLength())
    def OutputString(self):
        DumpString = '''//C0 12 跨服上传数据账号查询 //tagMergeRegisterAccQuery:
        DumpString = '''// C0 02 查看跨服玩家信息 //tagCGViewCrossPlayerInfo:
                                Cmd:%s,
                                SubCmd:%s,
                                ActionType:%d
                                PlayerID:%d
                                '''\
                                %(
                                self.Cmd,
                                self.SubCmd,
                                self.ActionType
                                self.PlayerID
                                )
        return DumpString
m_NAtagMergeRegisterAccQuery=tagMergeRegisterAccQuery()
ChNetPackDict[eval("0x%02x%02x"%(m_NAtagMergeRegisterAccQuery.Cmd,m_NAtagMergeRegisterAccQuery.SubCmd))] = m_NAtagMergeRegisterAccQuery
#------------------------------------------------------
# C0 15 通知即将登录跳转到跨服服务器 #tagCGGotoMergeServer
class  tagCGGotoMergeServer(Structure):
    _pack_ = 1
    _fields_ = [
                  ("Cmd", c_ubyte),
                  ("SubCmd", c_ubyte),
                  ]
    def __init__(self):
        self.Clear()
        self.Cmd = 0xC0
        self.SubCmd = 0x15
        return
    def ReadData(self, stringData, _pos=0, _len=0):
        self.Clear()
        memmove(addressof(self), stringData[_pos:], self.GetLength())
        return _pos + self.GetLength()
    def Clear(self):
        self.Cmd = 0xC0
        self.SubCmd = 0x15
        return
    def GetLength(self):
        return sizeof(tagCGGotoMergeServer)
    def GetBuffer(self):
        return string_at(addressof(self), self.GetLength())
    def OutputString(self):
        DumpString = '''// C0 15 通知即将登录跳转到跨服服务器 //tagCGGotoMergeServer:
                                Cmd:%s,
                                SubCmd:%s
                                '''\
                                %(
                                self.Cmd,
                                self.SubCmd
                                )
        return DumpString
m_NAtagCGGotoMergeServer=tagCGGotoMergeServer()
ChNetPackDict[eval("0x%02x%02x"%(m_NAtagCGGotoMergeServer.Cmd,m_NAtagCGGotoMergeServer.SubCmd))] = m_NAtagCGGotoMergeServer
m_NAtagCGViewCrossPlayerInfo=tagCGViewCrossPlayerInfo()
ChNetPackDict[eval("0x%02x%02x"%(m_NAtagCGViewCrossPlayerInfo.Cmd,m_NAtagCGViewCrossPlayerInfo.SubCmd))] = m_NAtagCGViewCrossPlayerInfo
#------------------------------------------------------
@@ -4755,6 +4778,58 @@
#------------------------------------------------------
# A2 30 设置聊天气泡框 #tagCMSetChatBubbleBox
class  tagCMSetChatBubbleBox(Structure):
    _pack_ = 1
    _fields_ = [
                  ("Cmd", c_ubyte),
                  ("SubCmd", c_ubyte),
                  ("BubbleBoxType", c_ubyte),    #气泡框类型
                  ]
    def __init__(self):
        self.Clear()
        self.Cmd = 0xA2
        self.SubCmd = 0x30
        return
    def ReadData(self, stringData, _pos=0, _len=0):
        self.Clear()
        memmove(addressof(self), stringData[_pos:], self.GetLength())
        return _pos + self.GetLength()
    def Clear(self):
        self.Cmd = 0xA2
        self.SubCmd = 0x30
        self.BubbleBoxType = 0
        return
    def GetLength(self):
        return sizeof(tagCMSetChatBubbleBox)
    def GetBuffer(self):
        return string_at(addressof(self), self.GetLength())
    def OutputString(self):
        DumpString = '''// A2 30 设置聊天气泡框 //tagCMSetChatBubbleBox:
                                Cmd:%s,
                                SubCmd:%s,
                                BubbleBoxType:%d
                                '''\
                                %(
                                self.Cmd,
                                self.SubCmd,
                                self.BubbleBoxType
                                )
        return DumpString
m_NAtagCMSetChatBubbleBox=tagCMSetChatBubbleBox()
ChNetPackDict[eval("0x%02x%02x"%(m_NAtagCMSetChatBubbleBox.Cmd,m_NAtagCMSetChatBubbleBox.SubCmd))] = m_NAtagCMSetChatBubbleBox
#------------------------------------------------------
# A2 22 设置引导成功 #tagCMSetGuideOK
class  tagCMSetGuideOK(Structure):
@@ -4808,6 +4883,82 @@
m_NAtagCMSetGuideOK=tagCMSetGuideOK()
ChNetPackDict[eval("0x%02x%02x"%(m_NAtagCMSetGuideOK.Cmd,m_NAtagCMSetGuideOK.SubCmd))] = m_NAtagCMSetGuideOK
#------------------------------------------------------
# A2 29 设置小助手 #tagCMSetLittleHelper
class  tagCMSetLittleHelper(Structure):
    _pack_ = 1
    _fields_ = [
                  ("Cmd", c_ubyte),
                  ("SubCmd", c_ubyte),
                  ("SetNum", c_ubyte),    # 托管功能设置编号1~20,每个编号对应的托管功能前端自定义
                  ("Value1", c_int),    # 自定义值1
                  ("Value2", c_int),    # 自定义值2
                  ("Value3", c_int),    # 自定义值3
                  ("Value4", c_int),    # 自定义值4
                  ("Value5", c_int),    # 自定义值5
                  ("Value6", c_int),    # 自定义值6
                  ]
    def __init__(self):
        self.Clear()
        self.Cmd = 0xA2
        self.SubCmd = 0x29
        return
    def ReadData(self, stringData, _pos=0, _len=0):
        self.Clear()
        memmove(addressof(self), stringData[_pos:], self.GetLength())
        return _pos + self.GetLength()
    def Clear(self):
        self.Cmd = 0xA2
        self.SubCmd = 0x29
        self.SetNum = 0
        self.Value1 = 0
        self.Value2 = 0
        self.Value3 = 0
        self.Value4 = 0
        self.Value5 = 0
        self.Value6 = 0
        return
    def GetLength(self):
        return sizeof(tagCMSetLittleHelper)
    def GetBuffer(self):
        return string_at(addressof(self), self.GetLength())
    def OutputString(self):
        DumpString = '''// A2 29 设置小助手 //tagCMSetLittleHelper:
                                Cmd:%s,
                                SubCmd:%s,
                                SetNum:%d,
                                Value1:%d,
                                Value2:%d,
                                Value3:%d,
                                Value4:%d,
                                Value5:%d,
                                Value6:%d
                                '''\
                                %(
                                self.Cmd,
                                self.SubCmd,
                                self.SetNum,
                                self.Value1,
                                self.Value2,
                                self.Value3,
                                self.Value4,
                                self.Value5,
                                self.Value6
                                )
        return DumpString
m_NAtagCMSetLittleHelper=tagCMSetLittleHelper()
ChNetPackDict[eval("0x%02x%02x"%(m_NAtagCMSetLittleHelper.Cmd,m_NAtagCMSetLittleHelper.SubCmd))] = m_NAtagCMSetLittleHelper
#------------------------------------------------------
@@ -5366,8 +5517,10 @@
class  tagCMEquipDecompose(Structure):
    Head = tagHead()
    IndexCount = 0    #(BYTE IndexCount)//材料所在背包索引的数量
    IndexList = list()    #(vector<BYTE> IndexList)//材料所在背包索引列表
    Count = 0    #(BYTE Count)//材料所在背包索引的数量
    IndexList = list()    #(vector<WORD> IndexList)//材料所在背包索引列表
    ItemIDList = list()    #(vector<DWORD> ItemIDList)//材料所在背包物品ID列表
    IsAuto = 0    #(BYTE IsAuto)//是否自动分解
    data = None
    def __init__(self):
@@ -5379,10 +5532,14 @@
    def ReadData(self, _lpData, _pos=0, _Len=0):
        self.Clear()
        _pos = self.Head.ReadData(_lpData, _pos)
        self.IndexCount,_pos = CommFunc.ReadBYTE(_lpData, _pos)
        for i in range(self.IndexCount):
            value,_pos=CommFunc.ReadBYTE(_lpData,_pos)
        self.Count,_pos = CommFunc.ReadBYTE(_lpData, _pos)
        for i in range(self.Count):
            value,_pos=CommFunc.ReadWORD(_lpData,_pos)
            self.IndexList.append(value)
        for i in range(self.Count):
            value,_pos=CommFunc.ReadDWORD(_lpData,_pos)
            self.ItemIDList.append(value)
        self.IsAuto,_pos = CommFunc.ReadBYTE(_lpData, _pos)
        return _pos
    def Clear(self):
@@ -5390,36 +5547,47 @@
        self.Head.Clear()
        self.Head.Cmd = 0xA3
        self.Head.SubCmd = 0x2C
        self.IndexCount = 0
        self.Count = 0
        self.IndexList = list()
        self.ItemIDList = list()
        self.IsAuto = 0
        return
    def GetLength(self):
        length = 0
        length += self.Head.GetLength()
        length += 1
        length += 1 * self.IndexCount
        length += 2 * self.Count
        length += 4 * self.Count
        length += 1
        return length
    def GetBuffer(self):
        data = ''
        data = CommFunc.WriteString(data, self.Head.GetLength(), self.Head.GetBuffer())
        data = CommFunc.WriteBYTE(data, self.IndexCount)
        for i in range(self.IndexCount):
            data = CommFunc.WriteBYTE(data, self.IndexList[i])
        data = CommFunc.WriteBYTE(data, self.Count)
        for i in range(self.Count):
            data = CommFunc.WriteWORD(data, self.IndexList[i])
        for i in range(self.Count):
            data = CommFunc.WriteDWORD(data, self.ItemIDList[i])
        data = CommFunc.WriteBYTE(data, self.IsAuto)
        return data
    def OutputString(self):
        DumpString = '''
                                Head:%s,
                                IndexCount:%d,
                                IndexList:%s
                                Count:%d,
                                IndexList:%s,
                                ItemIDList:%s,
                                IsAuto:%d
                                '''\
                                %(
                                self.Head.OutputString(),
                                self.IndexCount,
                                "..."
                                self.Count,
                                "...",
                                "...",
                                self.IsAuto
                                )
        return DumpString
@@ -5892,6 +6060,58 @@
#------------------------------------------------------
# A3 13 物品拆解 #tagCMItemDecompound
class  tagCMItemDecompound(Structure):
    _pack_ = 1
    _fields_ = [
                  ("Cmd", c_ubyte),
                  ("SubCmd", c_ubyte),
                  ("Index", c_ubyte),    # 拆解物品所在背包索引
                  ]
    def __init__(self):
        self.Clear()
        self.Cmd = 0xA3
        self.SubCmd = 0x13
        return
    def ReadData(self, stringData, _pos=0, _len=0):
        self.Clear()
        memmove(addressof(self), stringData[_pos:], self.GetLength())
        return _pos + self.GetLength()
    def Clear(self):
        self.Cmd = 0xA3
        self.SubCmd = 0x13
        self.Index = 0
        return
    def GetLength(self):
        return sizeof(tagCMItemDecompound)
    def GetBuffer(self):
        return string_at(addressof(self), self.GetLength())
    def OutputString(self):
        DumpString = '''// A3 13 物品拆解 //tagCMItemDecompound:
                                Cmd:%s,
                                SubCmd:%s,
                                Index:%d
                                '''\
                                %(
                                self.Cmd,
                                self.SubCmd,
                                self.Index
                                )
        return DumpString
m_NAtagCMItemDecompound=tagCMItemDecompound()
ChNetPackDict[eval("0x%02x%02x"%(m_NAtagCMItemDecompound.Cmd,m_NAtagCMItemDecompound.SubCmd))] = m_NAtagCMItemDecompound
#------------------------------------------------------
#A3 02 丢弃背包物品 #tagPlayerDropItem
class  tagPlayerDropItem(Structure):
@@ -6046,6 +6266,8 @@
    AddonsItemIndexCnt = 0    #(BYTE AddonsItemIndexCnt)// 附加物品在背包中索引个数
    AddonsItemIndex = list()    #(vector<BYTE> AddonsItemIndex)// 附加物品在背包的索引列表
    AddonsItemCount = list()    #(vector<BYTE> AddonsItemCount)// 附加物品在背包的索引对应扣除数量列表
    RateIncreaseItemIndexCnt = 0    #(BYTE RateIncreaseItemIndexCnt)// 提升概率物品在背包中索引个数
    RateIncreaseItemIndex = list()    #(vector<BYTE> RateIncreaseItemIndex)// 提升概率物品在背包的索引列表
    data = None
    def __init__(self):
@@ -6074,6 +6296,10 @@
        for i in range(self.AddonsItemIndexCnt):
            value,_pos=CommFunc.ReadBYTE(_lpData,_pos)
            self.AddonsItemCount.append(value)
        self.RateIncreaseItemIndexCnt,_pos = CommFunc.ReadBYTE(_lpData, _pos)
        for i in range(self.RateIncreaseItemIndexCnt):
            value,_pos=CommFunc.ReadBYTE(_lpData,_pos)
            self.RateIncreaseItemIndex.append(value)
        return _pos
    def Clear(self):
@@ -6090,6 +6316,8 @@
        self.AddonsItemIndexCnt = 0
        self.AddonsItemIndex = list()
        self.AddonsItemCount = list()
        self.RateIncreaseItemIndexCnt = 0
        self.RateIncreaseItemIndex = list()
        return
    def GetLength(self):
@@ -6104,6 +6332,8 @@
        length += 1
        length += 1 * self.AddonsItemIndexCnt
        length += 1 * self.AddonsItemIndexCnt
        length += 1
        length += 1 * self.RateIncreaseItemIndexCnt
        return length
@@ -6123,6 +6353,9 @@
            data = CommFunc.WriteBYTE(data, self.AddonsItemIndex[i])
        for i in range(self.AddonsItemIndexCnt):
            data = CommFunc.WriteBYTE(data, self.AddonsItemCount[i])
        data = CommFunc.WriteBYTE(data, self.RateIncreaseItemIndexCnt)
        for i in range(self.RateIncreaseItemIndexCnt):
            data = CommFunc.WriteBYTE(data, self.RateIncreaseItemIndex[i])
        return data
    def OutputString(self):
@@ -6136,7 +6369,9 @@
                                FixedItemIndex:%s,
                                AddonsItemIndexCnt:%d,
                                AddonsItemIndex:%s,
                                AddonsItemCount:%s
                                AddonsItemCount:%s,
                                RateIncreaseItemIndexCnt:%d,
                                RateIncreaseItemIndex:%s
                                '''\
                                %(
                                self.Head.OutputString(),
@@ -6148,6 +6383,8 @@
                                "...",
                                self.AddonsItemIndexCnt,
                                "...",
                                "...",
                                self.RateIncreaseItemIndexCnt,
                                "..."
                                )
        return DumpString
@@ -7095,8 +7332,9 @@
                  ("MapID", c_int),    
                  ("LineID", c_ushort),    
                  ("Cnt", c_ubyte),    # 扫荡次数
                  ("IsFinish", c_ubyte),    # 是否立即完成
                  ("IsFinish", c_ubyte),    # 是否立即完成; 0-否;1-花钱立即完成;2-客户端自行倒计时间到后发送2代表领取扫荡完成奖励
                  ("DataEx", c_int),    #附带信息
                  ("IsLittleHelper", c_ubyte),    # 是否小助手扫荡
                  ]
    def __init__(self):
@@ -7118,6 +7356,7 @@
        self.Cnt = 0
        self.IsFinish = 0
        self.DataEx = 0
        self.IsLittleHelper = 0
        return
    def GetLength(self):
@@ -7134,7 +7373,8 @@
                                LineID:%d,
                                Cnt:%d,
                                IsFinish:%d,
                                DataEx:%d
                                DataEx:%d,
                                IsLittleHelper:%d
                                '''\
                                %(
                                self.Cmd,
@@ -7143,7 +7383,8 @@
                                self.LineID,
                                self.Cnt,
                                self.IsFinish,
                                self.DataEx
                                self.DataEx,
                                self.IsLittleHelper
                                )
        return DumpString
@@ -8210,56 +8451,74 @@
# A5 C0 神兽穿戴装备 #tagCMDogzEquipItem
class  tagCMDogzEquipItem(Structure):
    _pack_ = 1
    _fields_ = [
                  ("Cmd", c_ubyte),
                  ("SubCmd", c_ubyte),
                  ("DogzID", c_ubyte),    # 神兽ID
                  ("EquipIndex", c_ubyte),    #神兽装备所在神兽背包索引
                  ]
    Head = tagHead()
    DogzID = 0    #(BYTE DogzID)// 神兽ID
    EquipIndexCount = 0    #(BYTE EquipIndexCount)
    EquipIndexList = list()    #(vector<BYTE> EquipIndexList)//神兽装备所在神兽背包索引列表
    data = None
    def __init__(self):
        self.Clear()
        self.Cmd = 0xA5
        self.SubCmd = 0xC0
        self.Head.Cmd = 0xA5
        self.Head.SubCmd = 0xC0
        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.DogzID,_pos = CommFunc.ReadBYTE(_lpData, _pos)
        self.EquipIndexCount,_pos = CommFunc.ReadBYTE(_lpData, _pos)
        for i in range(self.EquipIndexCount):
            value,_pos=CommFunc.ReadBYTE(_lpData,_pos)
            self.EquipIndexList.append(value)
        return _pos
    def Clear(self):
        self.Cmd = 0xA5
        self.SubCmd = 0xC0
        self.Head = tagHead()
        self.Head.Clear()
        self.Head.Cmd = 0xA5
        self.Head.SubCmd = 0xC0
        self.DogzID = 0
        self.EquipIndex = 0
        self.EquipIndexCount = 0
        self.EquipIndexList = list()
        return
    def GetLength(self):
        return sizeof(tagCMDogzEquipItem)
        length = 0
        length += self.Head.GetLength()
        length += 1
        length += 1
        length += 1 * self.EquipIndexCount
        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.WriteBYTE(data, self.DogzID)
        data = CommFunc.WriteBYTE(data, self.EquipIndexCount)
        for i in range(self.EquipIndexCount):
            data = CommFunc.WriteBYTE(data, self.EquipIndexList[i])
        return data
    def OutputString(self):
        DumpString = '''// A5 C0 神兽穿戴装备 //tagCMDogzEquipItem:
                                Cmd:%s,
                                SubCmd:%s,
        DumpString = '''
                                Head:%s,
                                DogzID:%d,
                                EquipIndex:%d
                                EquipIndexCount:%d,
                                EquipIndexList:%s
                                '''\
                                %(
                                self.Cmd,
                                self.SubCmd,
                                self.Head.OutputString(),
                                self.DogzID,
                                self.EquipIndex
                                self.EquipIndexCount,
                                "..."
                                )
        return DumpString
m_NAtagCMDogzEquipItem=tagCMDogzEquipItem()
ChNetPackDict[eval("0x%02x%02x"%(m_NAtagCMDogzEquipItem.Cmd,m_NAtagCMDogzEquipItem.SubCmd))] = m_NAtagCMDogzEquipItem
ChNetPackDict[eval("0x%02x%02x"%(m_NAtagCMDogzEquipItem.Head.Cmd,m_NAtagCMDogzEquipItem.Head.SubCmd))] = m_NAtagCMDogzEquipItem
#------------------------------------------------------
@@ -8270,6 +8529,7 @@
    EquipIndex = 0    #(BYTE EquipIndex)//神兽装备背包中索引
    IndexCount = 0    #(BYTE IndexCount)//材料所在神兽物品背包索引的数量
    IndexList = list()    #(vector<BYTE> IndexList)//材料所在神兽物品背包索引列表
    IndexUseCountList = list()    #(vector<DWORD> IndexUseCountList)//材料所在神兽物品背包索引对应使用个数列表
    IsDouble = 0    #(BYTE IsDouble)//是否双倍强化
    data = None
@@ -8287,6 +8547,9 @@
        for i in range(self.IndexCount):
            value,_pos=CommFunc.ReadBYTE(_lpData,_pos)
            self.IndexList.append(value)
        for i in range(self.IndexCount):
            value,_pos=CommFunc.ReadDWORD(_lpData,_pos)
            self.IndexUseCountList.append(value)
        self.IsDouble,_pos = CommFunc.ReadBYTE(_lpData, _pos)
        return _pos
@@ -8298,6 +8561,7 @@
        self.EquipIndex = 0
        self.IndexCount = 0
        self.IndexList = list()
        self.IndexUseCountList = list()
        self.IsDouble = 0
        return
@@ -8307,6 +8571,7 @@
        length += 1
        length += 1
        length += 1 * self.IndexCount
        length += 4 * self.IndexCount
        length += 1
        return length
@@ -8318,6 +8583,8 @@
        data = CommFunc.WriteBYTE(data, self.IndexCount)
        for i in range(self.IndexCount):
            data = CommFunc.WriteBYTE(data, self.IndexList[i])
        for i in range(self.IndexCount):
            data = CommFunc.WriteDWORD(data, self.IndexUseCountList[i])
        data = CommFunc.WriteBYTE(data, self.IsDouble)
        return data
@@ -8327,12 +8594,14 @@
                                EquipIndex:%d,
                                IndexCount:%d,
                                IndexList:%s,
                                IndexUseCountList:%s,
                                IsDouble:%d
                                '''\
                                %(
                                self.Head.OutputString(),
                                self.EquipIndex,
                                self.IndexCount,
                                "...",
                                "...",
                                self.IsDouble
                                )
@@ -8512,6 +8781,220 @@
#------------------------------------------------------
# A5 1C 聚魂合成 #tagCMGatherSoulCompound
class  tagCMGatherSoulCompound(Structure):
    Head = tagHead()
    Cnt = 0    #(BYTE Cnt)
    PackList = list()    #(vector<BYTE> PackList)//所在位置 0-背包 1-孔
    IndexList = list()    #(vector<WORD> IndexList)//物品索引
    TagItemID = 0    #(DWORD TagItemID)//合成目标物品ID
    data = None
    def __init__(self):
        self.Clear()
        self.Head.Cmd = 0xA5
        self.Head.SubCmd = 0x1C
        return
    def ReadData(self, _lpData, _pos=0, _Len=0):
        self.Clear()
        _pos = self.Head.ReadData(_lpData, _pos)
        self.Cnt,_pos = CommFunc.ReadBYTE(_lpData, _pos)
        for i in range(self.Cnt):
            value,_pos=CommFunc.ReadBYTE(_lpData,_pos)
            self.PackList.append(value)
        for i in range(self.Cnt):
            value,_pos=CommFunc.ReadWORD(_lpData,_pos)
            self.IndexList.append(value)
        self.TagItemID,_pos = CommFunc.ReadDWORD(_lpData, _pos)
        return _pos
    def Clear(self):
        self.Head = tagHead()
        self.Head.Clear()
        self.Head.Cmd = 0xA5
        self.Head.SubCmd = 0x1C
        self.Cnt = 0
        self.PackList = list()
        self.IndexList = list()
        self.TagItemID = 0
        return
    def GetLength(self):
        length = 0
        length += self.Head.GetLength()
        length += 1
        length += 1 * self.Cnt
        length += 2 * self.Cnt
        length += 4
        return length
    def GetBuffer(self):
        data = ''
        data = CommFunc.WriteString(data, self.Head.GetLength(), self.Head.GetBuffer())
        data = CommFunc.WriteBYTE(data, self.Cnt)
        for i in range(self.Cnt):
            data = CommFunc.WriteBYTE(data, self.PackList[i])
        for i in range(self.Cnt):
            data = CommFunc.WriteWORD(data, self.IndexList[i])
        data = CommFunc.WriteDWORD(data, self.TagItemID)
        return data
    def OutputString(self):
        DumpString = '''
                                Head:%s,
                                Cnt:%d,
                                PackList:%s,
                                IndexList:%s,
                                TagItemID:%d
                                '''\
                                %(
                                self.Head.OutputString(),
                                self.Cnt,
                                "...",
                                "...",
                                self.TagItemID
                                )
        return DumpString
m_NAtagCMGatherSoulCompound=tagCMGatherSoulCompound()
ChNetPackDict[eval("0x%02x%02x"%(m_NAtagCMGatherSoulCompound.Head.Cmd,m_NAtagCMGatherSoulCompound.Head.SubCmd))] = m_NAtagCMGatherSoulCompound
#------------------------------------------------------
# A5 19 聚魂分解 #tagCMGatherSoulDecompose
class  tagCMGatherSoulDecompose(Structure):
    Head = tagHead()
    IsAuto = 0    #(BYTE IsAuto)// 是否自动分解
    Count = 0    #(BYTE Count)// 指定批量分解数,最大不超过50个
    PlaceIndexList = list()    #(vector<WORD> PlaceIndexList)// 批量分解位置索引列表
    data = None
    def __init__(self):
        self.Clear()
        self.Head.Cmd = 0xA5
        self.Head.SubCmd = 0x19
        return
    def ReadData(self, _lpData, _pos=0, _Len=0):
        self.Clear()
        _pos = self.Head.ReadData(_lpData, _pos)
        self.IsAuto,_pos = CommFunc.ReadBYTE(_lpData, _pos)
        self.Count,_pos = CommFunc.ReadBYTE(_lpData, _pos)
        for i in range(self.Count):
            value,_pos=CommFunc.ReadWORD(_lpData,_pos)
            self.PlaceIndexList.append(value)
        return _pos
    def Clear(self):
        self.Head = tagHead()
        self.Head.Clear()
        self.Head.Cmd = 0xA5
        self.Head.SubCmd = 0x19
        self.IsAuto = 0
        self.Count = 0
        self.PlaceIndexList = list()
        return
    def GetLength(self):
        length = 0
        length += self.Head.GetLength()
        length += 1
        length += 1
        length += 2 * self.Count
        return length
    def GetBuffer(self):
        data = ''
        data = CommFunc.WriteString(data, self.Head.GetLength(), self.Head.GetBuffer())
        data = CommFunc.WriteBYTE(data, self.IsAuto)
        data = CommFunc.WriteBYTE(data, self.Count)
        for i in range(self.Count):
            data = CommFunc.WriteWORD(data, self.PlaceIndexList[i])
        return data
    def OutputString(self):
        DumpString = '''
                                Head:%s,
                                IsAuto:%d,
                                Count:%d,
                                PlaceIndexList:%s
                                '''\
                                %(
                                self.Head.OutputString(),
                                self.IsAuto,
                                self.Count,
                                "..."
                                )
        return DumpString
m_NAtagCMGatherSoulDecompose=tagCMGatherSoulDecompose()
ChNetPackDict[eval("0x%02x%02x"%(m_NAtagCMGatherSoulDecompose.Head.Cmd,m_NAtagCMGatherSoulDecompose.Head.SubCmd))] = m_NAtagCMGatherSoulDecompose
#------------------------------------------------------
# A5 18 聚魂升级 #tagCMGatherSoulUp
class  tagCMGatherSoulUp(Structure):
    _pack_ = 1
    _fields_ = [
                  ("Cmd", c_ubyte),
                  ("SubCmd", c_ubyte),
                  ("PlaceType", c_ubyte),    # 位置类型;0-背包,1-孔
                  ("PlaceIndex", c_ushort),    # 位置索引
                  ]
    def __init__(self):
        self.Clear()
        self.Cmd = 0xA5
        self.SubCmd = 0x18
        return
    def ReadData(self, stringData, _pos=0, _len=0):
        self.Clear()
        memmove(addressof(self), stringData[_pos:], self.GetLength())
        return _pos + self.GetLength()
    def Clear(self):
        self.Cmd = 0xA5
        self.SubCmd = 0x18
        self.PlaceType = 0
        self.PlaceIndex = 0
        return
    def GetLength(self):
        return sizeof(tagCMGatherSoulUp)
    def GetBuffer(self):
        return string_at(addressof(self), self.GetLength())
    def OutputString(self):
        DumpString = '''// A5 18 聚魂升级 //tagCMGatherSoulUp:
                                Cmd:%s,
                                SubCmd:%s,
                                PlaceType:%d,
                                PlaceIndex:%d
                                '''\
                                %(
                                self.Cmd,
                                self.SubCmd,
                                self.PlaceType,
                                self.PlaceIndex
                                )
        return DumpString
m_NAtagCMGatherSoulUp=tagCMGatherSoulUp()
ChNetPackDict[eval("0x%02x%02x"%(m_NAtagCMGatherSoulUp.Cmd,m_NAtagCMGatherSoulUp.SubCmd))] = m_NAtagCMGatherSoulUp
#------------------------------------------------------
# A5 41 领取投资理财回报 #tagCMGetInvestReward
class  tagCMGetInvestReward(Structure):
@@ -8672,6 +9155,58 @@
#------------------------------------------------------
# A5 56 神兵激活 #tagCMGodWeaponActivate
class  tagCMGodWeaponActivate(Structure):
    _pack_ = 1
    _fields_ = [
                  ("Cmd", c_ubyte),
                  ("SubCmd", c_ubyte),
                  ("WeaponType", c_int),    # 神兵类型
                  ]
    def __init__(self):
        self.Clear()
        self.Cmd = 0xA5
        self.SubCmd = 0x56
        return
    def ReadData(self, stringData, _pos=0, _len=0):
        self.Clear()
        memmove(addressof(self), stringData[_pos:], self.GetLength())
        return _pos + self.GetLength()
    def Clear(self):
        self.Cmd = 0xA5
        self.SubCmd = 0x56
        self.WeaponType = 0
        return
    def GetLength(self):
        return sizeof(tagCMGodWeaponActivate)
    def GetBuffer(self):
        return string_at(addressof(self), self.GetLength())
    def OutputString(self):
        DumpString = '''// A5 56 神兵激活 //tagCMGodWeaponActivate:
                                Cmd:%s,
                                SubCmd:%s,
                                WeaponType:%d
                                '''\
                                %(
                                self.Cmd,
                                self.SubCmd,
                                self.WeaponType
                                )
        return DumpString
m_NAtagCMGodWeaponActivate=tagCMGodWeaponActivate()
ChNetPackDict[eval("0x%02x%02x"%(m_NAtagCMGodWeaponActivate.Cmd,m_NAtagCMGodWeaponActivate.SubCmd))] = m_NAtagCMGodWeaponActivate
#------------------------------------------------------
# A5 55 神兵升级 #tagCMGodWeaponPlus
class  tagCMGodWeaponPlus(Structure):
@@ -8681,6 +9216,8 @@
                  ("SubCmd", c_ubyte),
                  ("WeaponType", c_int),    # 神兵类型
                  ("ItemID", c_int),    #消耗的物品ID
                  ("ItemCount", c_ubyte),    #消耗个数,默认1
                  ("IsAutoBuy", c_ubyte),    #是否自动购买,默认0
                  ]
    def __init__(self):
@@ -8699,6 +9236,8 @@
        self.SubCmd = 0x55
        self.WeaponType = 0
        self.ItemID = 0
        self.ItemCount = 0
        self.IsAutoBuy = 0
        return
    def GetLength(self):
@@ -8712,13 +9251,17 @@
                                Cmd:%s,
                                SubCmd:%s,
                                WeaponType:%d,
                                ItemID:%d
                                ItemID:%d,
                                ItemCount:%d,
                                IsAutoBuy:%d
                                '''\
                                %(
                                self.Cmd,
                                self.SubCmd,
                                self.WeaponType,
                                self.ItemID
                                self.ItemID,
                                self.ItemCount,
                                self.IsAutoBuy
                                )
        return DumpString
@@ -10247,6 +10790,54 @@
#------------------------------------------------------
# A5 17 绑玉转盘开始 #tagCMStartBindJadeWheel
class  tagCMStartBindJadeWheel(Structure):
    _pack_ = 1
    _fields_ = [
                  ("Cmd", c_ubyte),
                  ("SubCmd", c_ubyte),
                  ]
    def __init__(self):
        self.Clear()
        self.Cmd = 0xA5
        self.SubCmd = 0x17
        return
    def ReadData(self, stringData, _pos=0, _len=0):
        self.Clear()
        memmove(addressof(self), stringData[_pos:], self.GetLength())
        return _pos + self.GetLength()
    def Clear(self):
        self.Cmd = 0xA5
        self.SubCmd = 0x17
        return
    def GetLength(self):
        return sizeof(tagCMStartBindJadeWheel)
    def GetBuffer(self):
        return string_at(addressof(self), self.GetLength())
    def OutputString(self):
        DumpString = '''// A5 17 绑玉转盘开始 //tagCMStartBindJadeWheel:
                                Cmd:%s,
                                SubCmd:%s
                                '''\
                                %(
                                self.Cmd,
                                self.SubCmd
                                )
        return DumpString
m_NAtagCMStartBindJadeWheel=tagCMStartBindJadeWheel()
ChNetPackDict[eval("0x%02x%02x"%(m_NAtagCMStartBindJadeWheel.Cmd,m_NAtagCMStartBindJadeWheel.SubCmd))] = m_NAtagCMStartBindJadeWheel
#------------------------------------------------------
# A5 11 试用首充武器 #tagCMTryFirstGoldItem
class  tagCMTryFirstGoldItem(Structure):
@@ -10460,6 +11051,62 @@
m_NAtagUseNewGuyCard=tagUseNewGuyCard()
ChNetPackDict[eval("0x%02x%02x"%(m_NAtagUseNewGuyCard.Head.Cmd,m_NAtagUseNewGuyCard.Head.SubCmd))] = m_NAtagUseNewGuyCard
#------------------------------------------------------
# A5 1D 法宝佩戴 #tagCMWearMagicWeapon
class  tagCMWearMagicWeapon(Structure):
    _pack_ = 1
    _fields_ = [
                  ("Cmd", c_ubyte),
                  ("SubCmd", c_ubyte),
                  ("MWID", c_int),    #法宝ID
                  ("State", c_ubyte),    #0-卸下 1-佩戴
                  ]
    def __init__(self):
        self.Clear()
        self.Cmd = 0xA5
        self.SubCmd = 0x1D
        return
    def ReadData(self, stringData, _pos=0, _len=0):
        self.Clear()
        memmove(addressof(self), stringData[_pos:], self.GetLength())
        return _pos + self.GetLength()
    def Clear(self):
        self.Cmd = 0xA5
        self.SubCmd = 0x1D
        self.MWID = 0
        self.State = 0
        return
    def GetLength(self):
        return sizeof(tagCMWearMagicWeapon)
    def GetBuffer(self):
        return string_at(addressof(self), self.GetLength())
    def OutputString(self):
        DumpString = '''// A5 1D 法宝佩戴 //tagCMWearMagicWeapon:
                                Cmd:%s,
                                SubCmd:%s,
                                MWID:%d,
                                State:%d
                                '''\
                                %(
                                self.Cmd,
                                self.SubCmd,
                                self.MWID,
                                self.State
                                )
        return DumpString
m_NAtagCMWearMagicWeapon=tagCMWearMagicWeapon()
ChNetPackDict[eval("0x%02x%02x"%(m_NAtagCMWearMagicWeapon.Cmd,m_NAtagCMWearMagicWeapon.SubCmd))] = m_NAtagCMWearMagicWeapon
#------------------------------------------------------
@@ -11249,6 +11896,178 @@
m_NAtagCMVIPKillNPCLVInfoSwitch=tagCMVIPKillNPCLVInfoSwitch()
ChNetPackDict[eval("0x%02x%02x"%(m_NAtagCMVIPKillNPCLVInfoSwitch.Cmd,m_NAtagCMVIPKillNPCLVInfoSwitch.SubCmd))] = m_NAtagCMVIPKillNPCLVInfoSwitch
#------------------------------------------------------
# AA 07 许愿池活动刷新奖池 #tagCMActWishingRefresh
class  tagCMActWishingRefresh(Structure):
    _pack_ = 1
    _fields_ = [
                  ("Cmd", c_ubyte),
                  ("SubCmd", c_ubyte),
                  ("IsFree", c_ubyte),    # 是否免费刷新
                  ]
    def __init__(self):
        self.Clear()
        self.Cmd = 0xAA
        self.SubCmd = 0x07
        return
    def ReadData(self, stringData, _pos=0, _len=0):
        self.Clear()
        memmove(addressof(self), stringData[_pos:], self.GetLength())
        return _pos + self.GetLength()
    def Clear(self):
        self.Cmd = 0xAA
        self.SubCmd = 0x07
        self.IsFree = 0
        return
    def GetLength(self):
        return sizeof(tagCMActWishingRefresh)
    def GetBuffer(self):
        return string_at(addressof(self), self.GetLength())
    def OutputString(self):
        DumpString = '''// AA 07 许愿池活动刷新奖池 //tagCMActWishingRefresh:
                                Cmd:%s,
                                SubCmd:%s,
                                IsFree:%d
                                '''\
                                %(
                                self.Cmd,
                                self.SubCmd,
                                self.IsFree
                                )
        return DumpString
m_NAtagCMActWishingRefresh=tagCMActWishingRefresh()
ChNetPackDict[eval("0x%02x%02x"%(m_NAtagCMActWishingRefresh.Cmd,m_NAtagCMActWishingRefresh.SubCmd))] = m_NAtagCMActWishingRefresh
#------------------------------------------------------
# AA 06 许愿池活动许愿 #tagCMActWishing
class  tagCMActWishing(Structure):
    _pack_ = 1
    _fields_ = [
                  ("Cmd", c_ubyte),
                  ("SubCmd", c_ubyte),
                  ("SrcWellType", c_ubyte),    # 来源库 0-可选库 1-结果库
                  ("SrcIndex", c_ubyte),    # 来源索引
                  ("DesWellType", c_ubyte),    # 目标库 0-可选库 1-结果库
                  ("DesIndex", c_ubyte),    # 目标索引
                  ]
    def __init__(self):
        self.Clear()
        self.Cmd = 0xAA
        self.SubCmd = 0x06
        return
    def ReadData(self, stringData, _pos=0, _len=0):
        self.Clear()
        memmove(addressof(self), stringData[_pos:], self.GetLength())
        return _pos + self.GetLength()
    def Clear(self):
        self.Cmd = 0xAA
        self.SubCmd = 0x06
        self.SrcWellType = 0
        self.SrcIndex = 0
        self.DesWellType = 0
        self.DesIndex = 0
        return
    def GetLength(self):
        return sizeof(tagCMActWishing)
    def GetBuffer(self):
        return string_at(addressof(self), self.GetLength())
    def OutputString(self):
        DumpString = '''// AA 06 许愿池活动许愿 //tagCMActWishing:
                                Cmd:%s,
                                SubCmd:%s,
                                SrcWellType:%d,
                                SrcIndex:%d,
                                DesWellType:%d,
                                DesIndex:%d
                                '''\
                                %(
                                self.Cmd,
                                self.SubCmd,
                                self.SrcWellType,
                                self.SrcIndex,
                                self.DesWellType,
                                self.DesIndex
                                )
        return DumpString
m_NAtagCMActWishing=tagCMActWishing()
ChNetPackDict[eval("0x%02x%02x"%(m_NAtagCMActWishing.Cmd,m_NAtagCMActWishing.SubCmd))] = m_NAtagCMActWishing
#------------------------------------------------------
# AA 05 限时抢购预约 #tagCMFlashSaleAppointment
class  tagCMFlashSaleAppointment(Structure):
    _pack_ = 1
    _fields_ = [
                  ("Cmd", c_ubyte),
                  ("SubCmd", c_ubyte),
                  ("GoodsID", c_int),    # 抢购商品标识
                  ("State", c_ubyte),    # 1-预约 0-取消
                  ]
    def __init__(self):
        self.Clear()
        self.Cmd = 0xAA
        self.SubCmd = 0x05
        return
    def ReadData(self, stringData, _pos=0, _len=0):
        self.Clear()
        memmove(addressof(self), stringData[_pos:], self.GetLength())
        return _pos + self.GetLength()
    def Clear(self):
        self.Cmd = 0xAA
        self.SubCmd = 0x05
        self.GoodsID = 0
        self.State = 0
        return
    def GetLength(self):
        return sizeof(tagCMFlashSaleAppointment)
    def GetBuffer(self):
        return string_at(addressof(self), self.GetLength())
    def OutputString(self):
        DumpString = '''// AA 05 限时抢购预约 //tagCMFlashSaleAppointment:
                                Cmd:%s,
                                SubCmd:%s,
                                GoodsID:%d,
                                State:%d
                                '''\
                                %(
                                self.Cmd,
                                self.SubCmd,
                                self.GoodsID,
                                self.State
                                )
        return DumpString
m_NAtagCMFlashSaleAppointment=tagCMFlashSaleAppointment()
ChNetPackDict[eval("0x%02x%02x"%(m_NAtagCMFlashSaleAppointment.Cmd,m_NAtagCMFlashSaleAppointment.SubCmd))] = m_NAtagCMFlashSaleAppointment
#------------------------------------------------------
@@ -12790,6 +13609,162 @@
#------------------------------------------------------
# B1 06 助战召唤 #tagCMHelpBattleCall
class  tagCMHelpBattleCall(Structure):
    _pack_ = 1
    _fields_ = [
                  ("Cmd", c_ubyte),
                  ("SubCmd", c_ubyte),
                  ("IsOneKeyCall", c_ubyte),    # 是否一键召唤
                  ("PlayerID", c_int),    # 召唤的玩家ID,大于1小于100代表机器人
                  ("IsGoldCall", c_ubyte),    # 是否仙玉召唤
                  ]
    def __init__(self):
        self.Clear()
        self.Cmd = 0xB1
        self.SubCmd = 0x06
        return
    def ReadData(self, stringData, _pos=0, _len=0):
        self.Clear()
        memmove(addressof(self), stringData[_pos:], self.GetLength())
        return _pos + self.GetLength()
    def Clear(self):
        self.Cmd = 0xB1
        self.SubCmd = 0x06
        self.IsOneKeyCall = 0
        self.PlayerID = 0
        self.IsGoldCall = 0
        return
    def GetLength(self):
        return sizeof(tagCMHelpBattleCall)
    def GetBuffer(self):
        return string_at(addressof(self), self.GetLength())
    def OutputString(self):
        DumpString = '''// B1 06 助战召唤 //tagCMHelpBattleCall:
                                Cmd:%s,
                                SubCmd:%s,
                                IsOneKeyCall:%d,
                                PlayerID:%d,
                                IsGoldCall:%d
                                '''\
                                %(
                                self.Cmd,
                                self.SubCmd,
                                self.IsOneKeyCall,
                                self.PlayerID,
                                self.IsGoldCall
                                )
        return DumpString
m_NAtagCMHelpBattleCall=tagCMHelpBattleCall()
ChNetPackDict[eval("0x%02x%02x"%(m_NAtagCMHelpBattleCall.Cmd,m_NAtagCMHelpBattleCall.SubCmd))] = m_NAtagCMHelpBattleCall
#------------------------------------------------------
# B1 05 助战登记 #tagCMHelpBattleCheckIn
class  tagCMHelpBattleCheckIn(Structure):
    _pack_ = 1
    _fields_ = [
                  ("Cmd", c_ubyte),
                  ("SubCmd", c_ubyte),
                  ]
    def __init__(self):
        self.Clear()
        self.Cmd = 0xB1
        self.SubCmd = 0x05
        return
    def ReadData(self, stringData, _pos=0, _len=0):
        self.Clear()
        memmove(addressof(self), stringData[_pos:], self.GetLength())
        return _pos + self.GetLength()
    def Clear(self):
        self.Cmd = 0xB1
        self.SubCmd = 0x05
        return
    def GetLength(self):
        return sizeof(tagCMHelpBattleCheckIn)
    def GetBuffer(self):
        return string_at(addressof(self), self.GetLength())
    def OutputString(self):
        DumpString = '''// B1 05 助战登记 //tagCMHelpBattleCheckIn:
                                Cmd:%s,
                                SubCmd:%s
                                '''\
                                %(
                                self.Cmd,
                                self.SubCmd
                                )
        return DumpString
m_NAtagCMHelpBattleCheckIn=tagCMHelpBattleCheckIn()
ChNetPackDict[eval("0x%02x%02x"%(m_NAtagCMHelpBattleCheckIn.Cmd,m_NAtagCMHelpBattleCheckIn.SubCmd))] = m_NAtagCMHelpBattleCheckIn
#------------------------------------------------------
# B1 07 助战刷新 #tagCMHelpBattleRefresh
class  tagCMHelpBattleRefresh(Structure):
    _pack_ = 1
    _fields_ = [
                  ("Cmd", c_ubyte),
                  ("SubCmd", c_ubyte),
                  ]
    def __init__(self):
        self.Clear()
        self.Cmd = 0xB1
        self.SubCmd = 0x07
        return
    def ReadData(self, stringData, _pos=0, _len=0):
        self.Clear()
        memmove(addressof(self), stringData[_pos:], self.GetLength())
        return _pos + self.GetLength()
    def Clear(self):
        self.Cmd = 0xB1
        self.SubCmd = 0x07
        return
    def GetLength(self):
        return sizeof(tagCMHelpBattleRefresh)
    def GetBuffer(self):
        return string_at(addressof(self), self.GetLength())
    def OutputString(self):
        DumpString = '''// B1 07 助战刷新 //tagCMHelpBattleRefresh:
                                Cmd:%s,
                                SubCmd:%s
                                '''\
                                %(
                                self.Cmd,
                                self.SubCmd
                                )
        return DumpString
m_NAtagCMHelpBattleRefresh=tagCMHelpBattleRefresh()
ChNetPackDict[eval("0x%02x%02x"%(m_NAtagCMHelpBattleRefresh.Cmd,m_NAtagCMHelpBattleRefresh.SubCmd))] = m_NAtagCMHelpBattleRefresh
#------------------------------------------------------
# B1 02 领取多倍副本奖励 #tagCMGetMultiFBPrize
class  tagCMGetMultiFBPrize(Structure):
@@ -14174,61 +15149,9 @@
#------------------------------------------------------
#C1 03 领取奖励表奖励 #tagMSGetReward
# C1 02 跨服PK购买次数 #tagCMCrossRealmPKBuy
class  tagMSGetReward(Structure):
    _pack_ = 1
    _fields_ = [
                  ("Cmd", c_ubyte),
                  ("SubCmd", c_ubyte),
                  ("RewardType", c_ubyte),    #奖励表奖励类型
                  ]
    def __init__(self):
        self.Clear()
        self.Cmd = 0xC1
        self.SubCmd = 0x03
        return
    def ReadData(self, stringData, _pos=0, _len=0):
        self.Clear()
        memmove(addressof(self), stringData[_pos:], self.GetLength())
        return _pos + self.GetLength()
    def Clear(self):
        self.Cmd = 0xC1
        self.SubCmd = 0x03
        self.RewardType = 0
        return
    def GetLength(self):
        return sizeof(tagMSGetReward)
    def GetBuffer(self):
        return string_at(addressof(self), self.GetLength())
    def OutputString(self):
        DumpString = '''//C1 03 领取奖励表奖励 //tagMSGetReward:
                                Cmd:%s,
                                SubCmd:%s,
                                RewardType:%d
                                '''\
                                %(
                                self.Cmd,
                                self.SubCmd,
                                self.RewardType
                                )
        return DumpString
m_NAtagMSGetReward=tagMSGetReward()
ChNetPackDict[eval("0x%02x%02x"%(m_NAtagMSGetReward.Cmd,m_NAtagMSGetReward.SubCmd))] = m_NAtagMSGetReward
#------------------------------------------------------
#C1 08 玩家执行膜拜 #tagPlayerMergeWorship
class  tagPlayerMergeWorship(Structure):
class  tagCMCrossRealmPKBuy(Structure):
    _pack_ = 1
    _fields_ = [
                  ("Cmd", c_ubyte),
@@ -14238,7 +15161,7 @@
    def __init__(self):
        self.Clear()
        self.Cmd = 0xC1
        self.SubCmd = 0x08
        self.SubCmd = 0x02
        return
    def ReadData(self, stringData, _pos=0, _len=0):
@@ -14248,17 +15171,17 @@
    def Clear(self):
        self.Cmd = 0xC1
        self.SubCmd = 0x08
        self.SubCmd = 0x02
        return
    def GetLength(self):
        return sizeof(tagPlayerMergeWorship)
        return sizeof(tagCMCrossRealmPKBuy)
    def GetBuffer(self):
        return string_at(addressof(self), self.GetLength())
    def OutputString(self):
        DumpString = '''//C1 08 玩家执行膜拜 //tagPlayerMergeWorship:
        DumpString = '''// C1 02 跨服PK购买次数 //tagCMCrossRealmPKBuy:
                                Cmd:%s,
                                SubCmd:%s
                                '''\
@@ -14269,106 +15192,70 @@
        return DumpString
m_NAtagPlayerMergeWorship=tagPlayerMergeWorship()
ChNetPackDict[eval("0x%02x%02x"%(m_NAtagPlayerMergeWorship.Cmd,m_NAtagPlayerMergeWorship.SubCmd))] = m_NAtagPlayerMergeWorship
m_NAtagCMCrossRealmPKBuy=tagCMCrossRealmPKBuy()
ChNetPackDict[eval("0x%02x%02x"%(m_NAtagCMCrossRealmPKBuy.Cmd,m_NAtagCMCrossRealmPKBuy.SubCmd))] = m_NAtagCMCrossRealmPKBuy
#------------------------------------------------------
# C1 11 跨服王者争霸押注 #tagCMMergeKingSupport
# C1 03 跨服PK领取奖励 #tagCMCrossRealmPKGetAward
class  tagCMMergeKingSupport(Structure):
    Head = tagHead()
    SupportType = 0    #(BYTE SupportType)// 0-押注; 1-贿赂
    GroupType = 0    #(BYTE GroupType)// 组类型;如32强、16强等
    BattleIndex = 0    #(BYTE BattleIndex)// 对战组索引,每种组类型的索引从1开始
    MoneyType = 0    #(BYTE MoneyType)// 押注的货币类型
    AccIDLen = 0    #(BYTE AccIDLen)
    TagAccID = ""    #(String TagAccID)// 支持的目标账号
    data = None
class  tagCMCrossRealmPKGetAward(Structure):
    _pack_ = 1
    _fields_ = [
                  ("Cmd", c_ubyte),
                  ("SubCmd", c_ubyte),
                  ("AwardType", c_ubyte),    # 奖励类型;1-每日匹配奖励,2-每日胜利奖励,3-段位达标奖励,4-赛季结算奖励
                  ("AwardData", c_ubyte),    # 奖励类型对应领取值;每日匹配奖励时为匹配次数,每日胜利奖励时为胜利次数,段位达标奖励时为领取的段位
                  ]
    def __init__(self):
        self.Clear()
        self.Head.Cmd = 0xC1
        self.Head.SubCmd = 0x11
        self.Cmd = 0xC1
        self.SubCmd = 0x03
        return
    def ReadData(self, _lpData, _pos=0, _Len=0):
    def ReadData(self, stringData, _pos=0, _len=0):
        self.Clear()
        _pos = self.Head.ReadData(_lpData, _pos)
        self.SupportType,_pos = CommFunc.ReadBYTE(_lpData, _pos)
        self.GroupType,_pos = CommFunc.ReadBYTE(_lpData, _pos)
        self.BattleIndex,_pos = CommFunc.ReadBYTE(_lpData, _pos)
        self.MoneyType,_pos = CommFunc.ReadBYTE(_lpData, _pos)
        self.AccIDLen,_pos = CommFunc.ReadBYTE(_lpData, _pos)
        self.TagAccID,_pos = CommFunc.ReadString(_lpData, _pos,self.AccIDLen)
        return _pos
        memmove(addressof(self), stringData[_pos:], self.GetLength())
        return _pos + self.GetLength()
    def Clear(self):
        self.Head = tagHead()
        self.Head.Clear()
        self.Head.Cmd = 0xC1
        self.Head.SubCmd = 0x11
        self.SupportType = 0
        self.GroupType = 0
        self.BattleIndex = 0
        self.MoneyType = 0
        self.AccIDLen = 0
        self.TagAccID = ""
        self.Cmd = 0xC1
        self.SubCmd = 0x03
        self.AwardType = 0
        self.AwardData = 0
        return
    def GetLength(self):
        length = 0
        length += self.Head.GetLength()
        length += 1
        length += 1
        length += 1
        length += 1
        length += 1
        length += len(self.TagAccID)
        return length
        return sizeof(tagCMCrossRealmPKGetAward)
    def GetBuffer(self):
        data = ''
        data = CommFunc.WriteString(data, self.Head.GetLength(), self.Head.GetBuffer())
        data = CommFunc.WriteBYTE(data, self.SupportType)
        data = CommFunc.WriteBYTE(data, self.GroupType)
        data = CommFunc.WriteBYTE(data, self.BattleIndex)
        data = CommFunc.WriteBYTE(data, self.MoneyType)
        data = CommFunc.WriteBYTE(data, self.AccIDLen)
        data = CommFunc.WriteString(data, self.AccIDLen, self.TagAccID)
        return data
        return string_at(addressof(self), self.GetLength())
    def OutputString(self):
        DumpString = '''
                                Head:%s,
                                SupportType:%d,
                                GroupType:%d,
                                BattleIndex:%d,
                                MoneyType:%d,
                                AccIDLen:%d,
                                TagAccID:%s
        DumpString = '''// C1 03 跨服PK领取奖励 //tagCMCrossRealmPKGetAward:
                                Cmd:%s,
                                SubCmd:%s,
                                AwardType:%d,
                                AwardData:%d
                                '''\
                                %(
                                self.Head.OutputString(),
                                self.SupportType,
                                self.GroupType,
                                self.BattleIndex,
                                self.MoneyType,
                                self.AccIDLen,
                                self.TagAccID
                                self.Cmd,
                                self.SubCmd,
                                self.AwardType,
                                self.AwardData
                                )
        return DumpString
m_NAtagCMMergeKingSupport=tagCMMergeKingSupport()
ChNetPackDict[eval("0x%02x%02x"%(m_NAtagCMMergeKingSupport.Head.Cmd,m_NAtagCMMergeKingSupport.Head.SubCmd))] = m_NAtagCMMergeKingSupport
m_NAtagCMCrossRealmPKGetAward=tagCMCrossRealmPKGetAward()
ChNetPackDict[eval("0x%02x%02x"%(m_NAtagCMCrossRealmPKGetAward.Cmd,m_NAtagCMCrossRealmPKGetAward.SubCmd))] = m_NAtagCMCrossRealmPKGetAward
#------------------------------------------------------
# C1 09 跨服PK匹配 #tagCMMergePKMatch
# C1 01 跨服PK匹配 #tagCMCrossRealmPKMatch
class  tagCMMergePKMatch(Structure):
class  tagCMCrossRealmPKMatch(Structure):
    _pack_ = 1
    _fields_ = [
                  ("Cmd", c_ubyte),
@@ -14379,7 +15266,7 @@
    def __init__(self):
        self.Clear()
        self.Cmd = 0xC1
        self.SubCmd = 0x09
        self.SubCmd = 0x01
        return
    def ReadData(self, stringData, _pos=0, _len=0):
@@ -14389,18 +15276,18 @@
    def Clear(self):
        self.Cmd = 0xC1
        self.SubCmd = 0x09
        self.SubCmd = 0x01
        self.Type = 0
        return
    def GetLength(self):
        return sizeof(tagCMMergePKMatch)
        return sizeof(tagCMCrossRealmPKMatch)
    def GetBuffer(self):
        return string_at(addressof(self), self.GetLength())
    def OutputString(self):
        DumpString = '''// C1 09 跨服PK匹配 //tagCMMergePKMatch:
        DumpString = '''// C1 01 跨服PK匹配 //tagCMCrossRealmPKMatch:
                                Cmd:%s,
                                SubCmd:%s,
                                Type:%d
@@ -14413,14 +15300,14 @@
        return DumpString
m_NAtagCMMergePKMatch=tagCMMergePKMatch()
ChNetPackDict[eval("0x%02x%02x"%(m_NAtagCMMergePKMatch.Cmd,m_NAtagCMMergePKMatch.SubCmd))] = m_NAtagCMMergePKMatch
m_NAtagCMCrossRealmPKMatch=tagCMCrossRealmPKMatch()
ChNetPackDict[eval("0x%02x%02x"%(m_NAtagCMCrossRealmPKMatch.Cmd,m_NAtagCMCrossRealmPKMatch.SubCmd))] = m_NAtagCMCrossRealmPKMatch
#------------------------------------------------------
# C1 10 跨服PK恢复连胜次数 #tagCMRecoverMergePKWin
# C1 04 主动退出跨服 #tagCMExitCrossRealm
class  tagCMRecoverMergePKWin(Structure):
class  tagCMExitCrossRealm(Structure):
    _pack_ = 1
    _fields_ = [
                  ("Cmd", c_ubyte),
@@ -14430,7 +15317,7 @@
    def __init__(self):
        self.Clear()
        self.Cmd = 0xC1
        self.SubCmd = 0x10
        self.SubCmd = 0x04
        return
    def ReadData(self, stringData, _pos=0, _len=0):
@@ -14440,17 +15327,17 @@
    def Clear(self):
        self.Cmd = 0xC1
        self.SubCmd = 0x10
        self.SubCmd = 0x04
        return
    def GetLength(self):
        return sizeof(tagCMRecoverMergePKWin)
        return sizeof(tagCMExitCrossRealm)
    def GetBuffer(self):
        return string_at(addressof(self), self.GetLength())
    def OutputString(self):
        DumpString = '''// C1 10 跨服PK恢复连胜次数 //tagCMRecoverMergePKWin:
        DumpString = '''// C1 04 主动退出跨服 //tagCMExitCrossRealm:
                                Cmd:%s,
                                SubCmd:%s
                                '''\
@@ -14461,5 +15348,5 @@
        return DumpString
m_NAtagCMRecoverMergePKWin=tagCMRecoverMergePKWin()
ChNetPackDict[eval("0x%02x%02x"%(m_NAtagCMRecoverMergePKWin.Cmd,m_NAtagCMRecoverMergePKWin.SubCmd))] = m_NAtagCMRecoverMergePKWin
m_NAtagCMExitCrossRealm=tagCMExitCrossRealm()
ChNetPackDict[eval("0x%02x%02x"%(m_NAtagCMExitCrossRealm.Cmd,m_NAtagCMExitCrossRealm.SubCmd))] = m_NAtagCMExitCrossRealm
Tool/RobotTest/Protocol/PacketsReceived.py
@@ -983,7 +983,7 @@
    LV = 0    #(WORD LV)//等级
    LVEx = 0    #(WORD LVEx)//玩家等级副本,用于转生
    LV2 = 0    #(WORD LV2)//大师等级
    ExpPoint = 0    #(WORD ExpPoint)//扩充经验点数
    ExpPoint = 0    #(DWORD ExpPoint)//扩充经验点数
    TotalExp = 0    #(DWORD TotalExp)//总经验
    Family = 0    #(DWORD Family)//家族
    FamilyName = ""    #(char FamilyName[33])//家族名称
@@ -1062,6 +1062,12 @@
    OperateInfo = 0    #(DWORD OperateInfo)//玩家附加运营商信息
    Operate = ""    #(char Operate[15])//所属运营商平台名
    ServerID = 0    #(DWORD ServerID)//所属区服ID
    ExAttr15 = 0    #(DWORD ExAttr15)//预留的扩展属性字段,用来存放项目特定的属性
    ExAttr16 = 0    #(DWORD ExAttr16)//预留的扩展属性字段,用来存放项目特定的属性
    ExAttr17 = 0    #(DWORD ExAttr17)//预留的扩展属性字段,用来存放项目特定的属性
    ExAttr18 = 0    #(DWORD ExAttr18)//预留的扩展属性字段,用来存放项目特定的属性
    ExAttr19 = 0    #(DWORD ExAttr19)//预留的扩展属性字段,用来存放项目特定的属性
    ExAttr20 = 0    #(DWORD ExAttr20)//预留的扩展属性字段,用来存放项目特定的属性
    data = None
    def __init__(self):
@@ -1084,7 +1090,7 @@
        self.LV,_pos = CommFunc.ReadWORD(_lpData, _pos)
        self.LVEx,_pos = CommFunc.ReadWORD(_lpData, _pos)
        self.LV2,_pos = CommFunc.ReadWORD(_lpData, _pos)
        self.ExpPoint,_pos = CommFunc.ReadWORD(_lpData, _pos)
        self.ExpPoint,_pos = CommFunc.ReadDWORD(_lpData, _pos)
        self.TotalExp,_pos = CommFunc.ReadDWORD(_lpData, _pos)
        self.Family,_pos = CommFunc.ReadDWORD(_lpData, _pos)
        self.FamilyName,_pos = CommFunc.ReadString(_lpData, _pos,33)
@@ -1163,6 +1169,12 @@
        self.OperateInfo,_pos = CommFunc.ReadDWORD(_lpData, _pos)
        self.Operate,_pos = CommFunc.ReadString(_lpData, _pos,15)
        self.ServerID,_pos = CommFunc.ReadDWORD(_lpData, _pos)
        self.ExAttr15,_pos = CommFunc.ReadDWORD(_lpData, _pos)
        self.ExAttr16,_pos = CommFunc.ReadDWORD(_lpData, _pos)
        self.ExAttr17,_pos = CommFunc.ReadDWORD(_lpData, _pos)
        self.ExAttr18,_pos = CommFunc.ReadDWORD(_lpData, _pos)
        self.ExAttr19,_pos = CommFunc.ReadDWORD(_lpData, _pos)
        self.ExAttr20,_pos = CommFunc.ReadDWORD(_lpData, _pos)
        return _pos
    def Clear(self):
@@ -1260,6 +1272,12 @@
        self.OperateInfo = 0
        self.Operate = ""
        self.ServerID = 0
        self.ExAttr15 = 0
        self.ExAttr16 = 0
        self.ExAttr17 = 0
        self.ExAttr18 = 0
        self.ExAttr19 = 0
        self.ExAttr20 = 0
        return
    def GetLength(self):
@@ -1276,7 +1294,7 @@
        length += 2
        length += 2
        length += 2
        length += 2
        length += 4
        length += 4
        length += 4
        length += 33
@@ -1355,6 +1373,12 @@
        length += 4
        length += 15
        length += 4
        length += 4
        length += 4
        length += 4
        length += 4
        length += 4
        length += 4
        return length
@@ -1372,7 +1396,7 @@
        data = CommFunc.WriteWORD(data, self.LV)
        data = CommFunc.WriteWORD(data, self.LVEx)
        data = CommFunc.WriteWORD(data, self.LV2)
        data = CommFunc.WriteWORD(data, self.ExpPoint)
        data = CommFunc.WriteDWORD(data, self.ExpPoint)
        data = CommFunc.WriteDWORD(data, self.TotalExp)
        data = CommFunc.WriteDWORD(data, self.Family)
        data = CommFunc.WriteString(data, 33, self.FamilyName)
@@ -1451,6 +1475,12 @@
        data = CommFunc.WriteDWORD(data, self.OperateInfo)
        data = CommFunc.WriteString(data, 15, self.Operate)
        data = CommFunc.WriteDWORD(data, self.ServerID)
        data = CommFunc.WriteDWORD(data, self.ExAttr15)
        data = CommFunc.WriteDWORD(data, self.ExAttr16)
        data = CommFunc.WriteDWORD(data, self.ExAttr17)
        data = CommFunc.WriteDWORD(data, self.ExAttr18)
        data = CommFunc.WriteDWORD(data, self.ExAttr19)
        data = CommFunc.WriteDWORD(data, self.ExAttr20)
        return data
    def OutputString(self):
@@ -1545,7 +1575,13 @@
                                ExAttr14:%d,
                                OperateInfo:%d,
                                Operate:%s,
                                ServerID:%d
                                ServerID:%d,
                                ExAttr15:%d,
                                ExAttr16:%d,
                                ExAttr17:%d,
                                ExAttr18:%d,
                                ExAttr19:%d,
                                ExAttr20:%d
                                '''\
                                %(
                                self.Head.OutputString(),
@@ -1638,7 +1674,13 @@
                                self.ExAttr14,
                                self.OperateInfo,
                                self.Operate,
                                self.ServerID
                                self.ServerID,
                                self.ExAttr15,
                                self.ExAttr16,
                                self.ExAttr17,
                                self.ExAttr18,
                                self.ExAttr19,
                                self.ExAttr20
                                )
        return DumpString
@@ -2549,6 +2591,70 @@
m_NAtagCheckSecurityCardResult=tagCheckSecurityCardResult()
ChNetPackDict[eval("0x%02x%02x"%(m_NAtagCheckSecurityCardResult.Cmd,m_NAtagCheckSecurityCardResult.SubCmd))] = m_NAtagCheckSecurityCardResult
#------------------------------------------------------
#01 32 创角成功 #tagCreateRoleSucess
class  tagCreateRoleSucess(Structure):
    Head = tagHead()
    PlayerID = 0    #(DWORD PlayerID)
    PlayerName = ""    #(char PlayerName[33])
    data = None
    def __init__(self):
        self.Clear()
        self.Head.Cmd = 0x01
        self.Head.SubCmd = 0x32
        return
    def ReadData(self, _lpData, _pos=0, _Len=0):
        self.Clear()
        _pos = self.Head.ReadData(_lpData, _pos)
        self.PlayerID,_pos = CommFunc.ReadDWORD(_lpData, _pos)
        self.PlayerName,_pos = CommFunc.ReadString(_lpData, _pos,33)
        return _pos
    def Clear(self):
        self.Head = tagHead()
        self.Head.Clear()
        self.Head.Cmd = 0x01
        self.Head.SubCmd = 0x32
        self.PlayerID = 0
        self.PlayerName = ""
        return
    def GetLength(self):
        length = 0
        length += self.Head.GetLength()
        length += 4
        length += 33
        return length
    def GetBuffer(self):
        data = ''
        data = CommFunc.WriteString(data, self.Head.GetLength(), self.Head.GetBuffer())
        data = CommFunc.WriteDWORD(data, self.PlayerID)
        data = CommFunc.WriteString(data, 33, self.PlayerName)
        return data
    def OutputString(self):
        DumpString = '''
                                Head:%s,
                                PlayerID:%d,
                                PlayerName:%s
                                '''\
                                %(
                                self.Head.OutputString(),
                                self.PlayerID,
                                self.PlayerName
                                )
        return DumpString
m_NAtagCreateRoleSucess=tagCreateRoleSucess()
ChNetPackDict[eval("0x%02x%02x"%(m_NAtagCreateRoleSucess.Head.Cmd,m_NAtagCreateRoleSucess.Head.SubCmd))] = m_NAtagCreateRoleSucess
#------------------------------------------------------
@@ -6543,6 +6649,7 @@
    GradID = 0    #(DWORD GradID)//头衔ID
    State = 0    #(BYTE State)//装备和使用状态 按位判定,第一位0未装备1已装备 第二位0未使用 1使用
    CreateTime = ""    #(char CreateTime[30])//获得时间
    ExpireTime = 0    #(DWORD ExpireTime)// 持续时间,0为配表固定时间
    data = None
    def __init__(self):
@@ -6554,12 +6661,14 @@
        self.GradID,_pos = CommFunc.ReadDWORD(_lpData, _pos)
        self.State,_pos = CommFunc.ReadBYTE(_lpData, _pos)
        self.CreateTime,_pos = CommFunc.ReadString(_lpData, _pos,30)
        self.ExpireTime,_pos = CommFunc.ReadDWORD(_lpData, _pos)
        return _pos
    def Clear(self):
        self.GradID = 0
        self.State = 0
        self.CreateTime = ""
        self.ExpireTime = 0
        return
    def GetLength(self):
@@ -6567,6 +6676,7 @@
        length += 4
        length += 1
        length += 30
        length += 4
        return length
@@ -6575,18 +6685,21 @@
        data = CommFunc.WriteDWORD(data, self.GradID)
        data = CommFunc.WriteBYTE(data, self.State)
        data = CommFunc.WriteString(data, 30, self.CreateTime)
        data = CommFunc.WriteDWORD(data, self.ExpireTime)
        return data
    def OutputString(self):
        DumpString = '''
                                GradID:%d,
                                State:%d,
                                CreateTime:%s
                                CreateTime:%s,
                                ExpireTime:%d
                                '''\
                                %(
                                self.GradID,
                                self.State,
                                self.CreateTime
                                self.CreateTime,
                                self.ExpireTime
                                )
        return DumpString
@@ -6664,6 +6777,7 @@
    Head = tagHead()
    GradID = 0    #(DWORD GradID)//头衔ID
    CreateTime = ""    #(char CreateTime[30])//获得时间
    ExpireTime = 0    #(DWORD ExpireTime)// 持续时间,0为配表固定时间
    data = None
    def __init__(self):
@@ -6677,6 +6791,7 @@
        _pos = self.Head.ReadData(_lpData, _pos)
        self.GradID,_pos = CommFunc.ReadDWORD(_lpData, _pos)
        self.CreateTime,_pos = CommFunc.ReadString(_lpData, _pos,30)
        self.ExpireTime,_pos = CommFunc.ReadDWORD(_lpData, _pos)
        return _pos
    def Clear(self):
@@ -6686,6 +6801,7 @@
        self.Head.SubCmd = 0x36
        self.GradID = 0
        self.CreateTime = ""
        self.ExpireTime = 0
        return
    def GetLength(self):
@@ -6693,6 +6809,7 @@
        length += self.Head.GetLength()
        length += 4
        length += 30
        length += 4
        return length
@@ -6701,18 +6818,21 @@
        data = CommFunc.WriteString(data, self.Head.GetLength(), self.Head.GetBuffer())
        data = CommFunc.WriteDWORD(data, self.GradID)
        data = CommFunc.WriteString(data, 30, self.CreateTime)
        data = CommFunc.WriteDWORD(data, self.ExpireTime)
        return data
    def OutputString(self):
        DumpString = '''
                                Head:%s,
                                GradID:%d,
                                CreateTime:%s
                                CreateTime:%s,
                                ExpireTime:%d
                                '''\
                                %(
                                self.Head.OutputString(),
                                self.GradID,
                                self.CreateTime
                                self.CreateTime,
                                self.ExpireTime
                                )
        return DumpString
@@ -7017,6 +7137,16 @@
    EquipCount = 0    #(BYTE EquipCount)
    EquipInfo = list()    #(vector<tagLoginInfoEquip> EquipInfo)//size = EquipCount
    EquipShowSwitch = 0    #(DWORD EquipShowSwitch)//玩家装备显示开关
    ExAttr15 = 0    #(DWORD ExAttr15)//预留的扩展属性字段,用来存放项目特定的属性
    ExAttr16 = 0    #(DWORD ExAttr16)//预留的扩展属性字段,用来存放项目特定的属性
    ExAttr17 = 0    #(DWORD ExAttr17)//预留的扩展属性字段,用来存放项目特定的属性
    ExAttr18 = 0    #(DWORD ExAttr18)//预留的扩展属性字段,用来存放项目特定的属性
    ExAttr19 = 0    #(DWORD ExAttr19)//预留的扩展属性字段,用来存放项目特定的属性
    ExAttr20 = 0    #(DWORD ExAttr20)//预留的扩展属性字段,用来存放项目特定的属性
    IPLen = 0    #(BYTE IPLen)
    IP = ""    #(String IP)// 跨服IP
    Port = 0    #(WORD Port)// 跨服端口
    CrossState = 0    #(BYTE CrossState)// 跨服状态0-非跨服状态,1-跨服状态,2-跨服状态异常
    data = None
    def __init__(self):
@@ -7040,6 +7170,16 @@
            _pos = temEquipInfo.ReadData(_lpData, _pos)
            self.EquipInfo.append(temEquipInfo)
        self.EquipShowSwitch,_pos = CommFunc.ReadDWORD(_lpData, _pos)
        self.ExAttr15,_pos = CommFunc.ReadDWORD(_lpData, _pos)
        self.ExAttr16,_pos = CommFunc.ReadDWORD(_lpData, _pos)
        self.ExAttr17,_pos = CommFunc.ReadDWORD(_lpData, _pos)
        self.ExAttr18,_pos = CommFunc.ReadDWORD(_lpData, _pos)
        self.ExAttr19,_pos = CommFunc.ReadDWORD(_lpData, _pos)
        self.ExAttr20,_pos = CommFunc.ReadDWORD(_lpData, _pos)
        self.IPLen,_pos = CommFunc.ReadBYTE(_lpData, _pos)
        self.IP,_pos = CommFunc.ReadString(_lpData, _pos,self.IPLen)
        self.Port,_pos = CommFunc.ReadWORD(_lpData, _pos)
        self.CrossState,_pos = CommFunc.ReadBYTE(_lpData, _pos)
        return _pos
    def Clear(self):
@@ -7056,6 +7196,16 @@
        self.EquipCount = 0
        self.EquipInfo = list()
        self.EquipShowSwitch = 0
        self.ExAttr15 = 0
        self.ExAttr16 = 0
        self.ExAttr17 = 0
        self.ExAttr18 = 0
        self.ExAttr19 = 0
        self.ExAttr20 = 0
        self.IPLen = 0
        self.IP = ""
        self.Port = 0
        self.CrossState = 0
        return
    def GetLength(self):
@@ -7071,6 +7221,16 @@
        for i in range(self.EquipCount):
            length += self.EquipInfo[i].GetLength()
        length += 4
        length += 4
        length += 4
        length += 4
        length += 4
        length += 4
        length += 4
        length += 1
        length += len(self.IP)
        length += 2
        length += 1
        return length
@@ -7087,6 +7247,16 @@
        for i in range(self.EquipCount):
            data = CommFunc.WriteString(data, self.EquipInfo[i].GetLength(), self.EquipInfo[i].GetBuffer())
        data = CommFunc.WriteDWORD(data, self.EquipShowSwitch)
        data = CommFunc.WriteDWORD(data, self.ExAttr15)
        data = CommFunc.WriteDWORD(data, self.ExAttr16)
        data = CommFunc.WriteDWORD(data, self.ExAttr17)
        data = CommFunc.WriteDWORD(data, self.ExAttr18)
        data = CommFunc.WriteDWORD(data, self.ExAttr19)
        data = CommFunc.WriteDWORD(data, self.ExAttr20)
        data = CommFunc.WriteBYTE(data, self.IPLen)
        data = CommFunc.WriteString(data, self.IPLen, self.IP)
        data = CommFunc.WriteWORD(data, self.Port)
        data = CommFunc.WriteBYTE(data, self.CrossState)
        return data
    def OutputString(self):
@@ -7100,7 +7270,17 @@
                                HavePswLV2:%d,
                                EquipCount:%d,
                                EquipInfo:%s,
                                EquipShowSwitch:%d
                                EquipShowSwitch:%d,
                                ExAttr15:%d,
                                ExAttr16:%d,
                                ExAttr17:%d,
                                ExAttr18:%d,
                                ExAttr19:%d,
                                ExAttr20:%d,
                                IPLen:%d,
                                IP:%s,
                                Port:%d,
                                CrossState:%d
                                '''\
                                %(
                                self.Head.OutputString(),
@@ -7112,7 +7292,17 @@
                                self.HavePswLV2,
                                self.EquipCount,
                                "...",
                                self.EquipShowSwitch
                                self.EquipShowSwitch,
                                self.ExAttr15,
                                self.ExAttr16,
                                self.ExAttr17,
                                self.ExAttr18,
                                self.ExAttr19,
                                self.ExAttr20,
                                self.IPLen,
                                self.IP,
                                self.Port,
                                self.CrossState
                                )
        return DumpString
@@ -8561,6 +8751,12 @@
    ExAttr5 = 0    #(DWORD ExAttr5)//预留的扩展属性字段,用来存放项目特定的属性
    ServerID = 0    #(DWORD ServerID)//所属区服ID
    State = 0    #(BYTE State)// 0.正常在线1.脱机挂在线 2脱机挂死亡
    ExAttr15 = 0    #(DWORD ExAttr15)//预留的扩展属性字段,用来存放项目特定的属性
    ExAttr16 = 0    #(DWORD ExAttr16)//预留的扩展属性字段,用来存放项目特定的属性
    ExAttr17 = 0    #(DWORD ExAttr17)//预留的扩展属性字段,用来存放项目特定的属性
    ExAttr18 = 0    #(DWORD ExAttr18)//预留的扩展属性字段,用来存放项目特定的属性
    ExAttr19 = 0    #(DWORD ExAttr19)//预留的扩展属性字段,用来存放项目特定的属性
    ExAttr20 = 0    #(DWORD ExAttr20)//预留的扩展属性字段,用来存放项目特定的属性
    data = None
    def __init__(self):
@@ -8618,6 +8814,12 @@
        self.ExAttr5,_pos = CommFunc.ReadDWORD(_lpData, _pos)
        self.ServerID,_pos = CommFunc.ReadDWORD(_lpData, _pos)
        self.State,_pos = CommFunc.ReadBYTE(_lpData, _pos)
        self.ExAttr15,_pos = CommFunc.ReadDWORD(_lpData, _pos)
        self.ExAttr16,_pos = CommFunc.ReadDWORD(_lpData, _pos)
        self.ExAttr17,_pos = CommFunc.ReadDWORD(_lpData, _pos)
        self.ExAttr18,_pos = CommFunc.ReadDWORD(_lpData, _pos)
        self.ExAttr19,_pos = CommFunc.ReadDWORD(_lpData, _pos)
        self.ExAttr20,_pos = CommFunc.ReadDWORD(_lpData, _pos)
        return _pos
    def Clear(self):
@@ -8665,6 +8867,12 @@
        self.ExAttr5 = 0
        self.ServerID = 0
        self.State = 0
        self.ExAttr15 = 0
        self.ExAttr16 = 0
        self.ExAttr17 = 0
        self.ExAttr18 = 0
        self.ExAttr19 = 0
        self.ExAttr20 = 0
        return
    def GetLength(self):
@@ -8712,6 +8920,12 @@
        length += 4
        length += 4
        length += 1
        length += 4
        length += 4
        length += 4
        length += 4
        length += 4
        length += 4
        return length
@@ -8760,6 +8974,12 @@
        data = CommFunc.WriteDWORD(data, self.ExAttr5)
        data = CommFunc.WriteDWORD(data, self.ServerID)
        data = CommFunc.WriteBYTE(data, self.State)
        data = CommFunc.WriteDWORD(data, self.ExAttr15)
        data = CommFunc.WriteDWORD(data, self.ExAttr16)
        data = CommFunc.WriteDWORD(data, self.ExAttr17)
        data = CommFunc.WriteDWORD(data, self.ExAttr18)
        data = CommFunc.WriteDWORD(data, self.ExAttr19)
        data = CommFunc.WriteDWORD(data, self.ExAttr20)
        return data
    def OutputString(self):
@@ -8804,7 +9024,13 @@
                                ExAttr4:%d,
                                ExAttr5:%d,
                                ServerID:%d,
                                State:%d
                                State:%d,
                                ExAttr15:%d,
                                ExAttr16:%d,
                                ExAttr17:%d,
                                ExAttr18:%d,
                                ExAttr19:%d,
                                ExAttr20:%d
                                '''\
                                %(
                                self.Head.OutputString(),
@@ -8847,7 +9073,13 @@
                                self.ExAttr4,
                                self.ExAttr5,
                                self.ServerID,
                                self.State
                                self.State,
                                self.ExAttr15,
                                self.ExAttr16,
                                self.ExAttr17,
                                self.ExAttr18,
                                self.ExAttr19,
                                self.ExAttr20
                                )
        return DumpString
@@ -12428,6 +12660,8 @@
                  ("Cmd", c_ubyte),
                  ("SubCmd", c_ubyte),
                  ("PlayerID", c_int),    
                  ("KillerID", c_int),
                  ("KillerType", c_ubyte),
                  ]
    def __init__(self):
@@ -12445,6 +12679,8 @@
        self.Cmd = 0x06
        self.SubCmd = 0x09
        self.PlayerID = 0
        self.KillerID = 0
        self.KillerType = 0
        return
    def GetLength(self):
@@ -12457,12 +12693,16 @@
        DumpString = '''//06 09 玩家死亡//tagPlayerDie:
                                Cmd:%s,
                                SubCmd:%s,
                                PlayerID:%d
                                PlayerID:%d,
                                KillerID:%d,
                                KillerType:%d
                                '''\
                                %(
                                self.Cmd,
                                self.SubCmd,
                                self.PlayerID
                                self.PlayerID,
                                self.KillerID,
                                self.KillerType
                                )
        return DumpString
Tool/RobotTest/Protocol/PacketsReceivedPY.py
Diff too large
Tool/RobotTest/Protocol/PacketsSend.py
@@ -3516,7 +3516,7 @@
class  tagCGameServerGeneralPack(Structure):
    Head = tagHead()
    DataLen = 0    #(BYTE DataLen)//GameServer通用包长度
    DataLen = 0    #(WORD DataLen)//GameServer通用包长度
    Data = ""    #(String Data)//GameServer统用包数据
    data = None
@@ -3529,7 +3529,7 @@
    def ReadData(self, _lpData, _pos=0, _Len=0):
        self.Clear()
        _pos = self.Head.ReadData(_lpData, _pos)
        self.DataLen,_pos = CommFunc.ReadBYTE(_lpData, _pos)
        self.DataLen,_pos = CommFunc.ReadWORD(_lpData, _pos)
        self.Data,_pos = CommFunc.ReadString(_lpData, _pos,self.DataLen)
        return _pos
@@ -3545,7 +3545,7 @@
    def GetLength(self):
        length = 0
        length += self.Head.GetLength()
        length += 1
        length += 2
        length += len(self.Data)
        return length
@@ -3553,7 +3553,7 @@
    def GetBuffer(self):
        data = ''
        data = CommFunc.WriteString(data, self.Head.GetLength(), self.Head.GetBuffer())
        data = CommFunc.WriteBYTE(data, self.DataLen)
        data = CommFunc.WriteWORD(data, self.DataLen)
        data = CommFunc.WriteString(data, self.DataLen, self.Data)
        return data
@@ -5204,6 +5204,8 @@
    Phone = 0    #(BYTE Phone)//是否绑定手机
    ServerID = 0    #(DWORD ServerID)//服务器ID
    Adult = 0    #(BYTE Adult)//是否成年 0未成年 1成年
    ExtraLen = 0    #(BYTE ExtraLen)//扩展长度
    Extra = ""    #(String Extra)//扩展内容,根据不同平台而定
    data = None
    def __init__(self):
@@ -5227,6 +5229,8 @@
        self.Phone,_pos = CommFunc.ReadBYTE(_lpData, _pos)
        self.ServerID,_pos = CommFunc.ReadDWORD(_lpData, _pos)
        self.Adult,_pos = CommFunc.ReadBYTE(_lpData, _pos)
        self.ExtraLen,_pos = CommFunc.ReadBYTE(_lpData, _pos)
        self.Extra,_pos = CommFunc.ReadString(_lpData, _pos,self.ExtraLen)
        return _pos
    def Clear(self):
@@ -5246,6 +5250,8 @@
        self.Phone = 0
        self.ServerID = 0
        self.Adult = 0
        self.ExtraLen = 0
        self.Extra = ""
        return
    def GetLength(self):
@@ -5263,6 +5269,8 @@
        length += 1
        length += 4
        length += 1
        length += 1
        length += len(self.Extra)
        return length
@@ -5281,6 +5289,8 @@
        data = CommFunc.WriteBYTE(data, self.Phone)
        data = CommFunc.WriteDWORD(data, self.ServerID)
        data = CommFunc.WriteBYTE(data, self.Adult)
        data = CommFunc.WriteBYTE(data, self.ExtraLen)
        data = CommFunc.WriteString(data, self.ExtraLen, self.Extra)
        return data
    def OutputString(self):
@@ -5297,7 +5307,9 @@
                                TokenExpire:%s,
                                Phone:%d,
                                ServerID:%d,
                                Adult:%d
                                Adult:%d,
                                ExtraLen:%d,
                                Extra:%s
                                '''\
                                %(
                                self.Head.OutputString(),
@@ -5312,7 +5324,9 @@
                                self.TokenExpire,
                                self.Phone,
                                self.ServerID,
                                self.Adult
                                self.Adult,
                                self.ExtraLen,
                                self.Extra
                                )
        return DumpString
@@ -7900,7 +7914,7 @@
class  tagCFakePack(Structure):
    Head = tagHead()
    MsgLen = 0    #(BYTE MsgLen)
    MsgLen = 0    #(WORD MsgLen)
    Msg = ""    #(String Msg)//size = MsgLen
    data = None
@@ -7913,7 +7927,7 @@
    def ReadData(self, _lpData, _pos=0, _Len=0):
        self.Clear()
        _pos = self.Head.ReadData(_lpData, _pos)
        self.MsgLen,_pos = CommFunc.ReadBYTE(_lpData, _pos)
        self.MsgLen,_pos = CommFunc.ReadWORD(_lpData, _pos)
        self.Msg,_pos = CommFunc.ReadString(_lpData, _pos,self.MsgLen)
        return _pos
@@ -7929,7 +7943,7 @@
    def GetLength(self):
        length = 0
        length += self.Head.GetLength()
        length += 1
        length += 2
        length += len(self.Msg)
        return length
@@ -7937,7 +7951,7 @@
    def GetBuffer(self):
        data = ''
        data = CommFunc.WriteString(data, self.Head.GetLength(), self.Head.GetBuffer())
        data = CommFunc.WriteBYTE(data, self.MsgLen)
        data = CommFunc.WriteWORD(data, self.MsgLen)
        data = CommFunc.WriteString(data, self.MsgLen, self.Msg)
        return data
Tool/RobotTest/Protocol/PacketsSendPY.py
Diff too large