|  |  | 
 |  |  | import Commands
 | 
 |  |  | import IPY_GameServer
 | 
 |  |  | import MergeChildMsg
 | 
 |  |  | import PyGameData
 | 
 |  |  | import traceback
 | 
 |  |  | import GMCommon
 | 
 |  |  | import os
 | 
 |  |  | 
 |  |  |     try:
 | 
 |  |  |         gmCmd = IPY_GameServer.IPY_GGMCmd()
 | 
 |  |  |         inputStr = gmCmd.GetMsg()
 | 
 |  |  |         list = inputStr.split()
 | 
 |  |  |         if len(list) == 0:
 | 
 |  |  |         alist = inputStr.split()
 | 
 |  |  |         if len(alist) == 0:
 | 
 |  |  |             return 
 | 
 |  |  |         
 | 
 |  |  |         curPlayer = GameWorld.GetPlayerManager().GetPlayerByIndex(index)
 | 
 |  |  |         
 | 
 |  |  |         callFunName = list[0]
 | 
 |  |  |         callFunName = alist[0]
 | 
 |  |  |         # 特殊的命令不验证GM等级,在MapServer已验证账号
 | 
 |  |  |         if callFunName.startswith("@"):
 | 
 |  |  |             callFunName = "GMS_%s" % (callFunName[1:].capitalize())
 | 
 |  |  | 
 |  |  |             callFunc = GameWorld.GetExecFunc(Commands, "%s.%s"%(callFunName, "OnGetMergeParam"))
 | 
 |  |  |             if callFunc != None:
 | 
 |  |  |                 extendParamList = callFunc(curPlayer)
 | 
 |  |  |                 list.extend(extendParamList)
 | 
 |  |  |                 MergeChildMsg.SendMergerChildToCenterStringData(ChConfig.Def_SendGMCMD, list)
 | 
 |  |  |                 alist.extend(extendParamList)
 | 
 |  |  |                 MergeChildMsg.SendMergerChildToCenterStringData(ChConfig.Def_SendGMCMD, alist)
 | 
 |  |  |                 return
 | 
 |  |  |             
 | 
 |  |  |         callFunc = GameWorld.GetExecFunc(Commands, "%s.%s"%(callFunName, "OnExec"))
 | 
 |  |  | 
 |  |  |             return
 | 
 |  |  |         
 | 
 |  |  |         #删除命令,只将参数传入
 | 
 |  |  |         del list[0]
 | 
 |  |  |         del alist[0]
 | 
 |  |  |         #把剩余参数转换为整型
 | 
 |  |  |         for i in range(0, len(list)):
 | 
 |  |  |             if i == 0 and callFunName in ["testMail", "SetPlayerDBGSEvent"]:
 | 
 |  |  |                 continue
 | 
 |  |  |             value = GameWorld.ToIntDef(list[i], None)
 | 
 |  |  |         for i in range(0, len(alist)):
 | 
 |  |  |             value = GameWorld.ToIntDef(alist[i], None)
 | 
 |  |  |             if value == None:
 | 
 |  |  |                 GameWorld.DebugAnswer(curPlayer, "参数错误, 参数%s必须为纯数字!" % (i + 1))
 | 
 |  |  |                 return
 | 
 |  |  |             list[i] = value
 | 
 |  |  |                 #GameWorld.DebugAnswer(curPlayer, "参数错误, 参数%s必须为纯数字!" % (i + 1))
 | 
 |  |  |                 continue
 | 
 |  |  |             alist[i] = value
 | 
 |  |  |             
 | 
 |  |  |         callFunc(curPlayer,list)
 | 
 |  |  |         callFunc(curPlayer,alist)
 | 
 |  |  |         
 | 
 |  |  |     except BaseException:
 | 
 |  |  |         GameWorld.DebugAnswer(curPlayer, "执行GM命令错误, 请查看GameServer日志!")
 | 
 |  |  |         errorMsg = str(traceback.format_exc())
 | 
 |  |  |         GameWorld.ErrLog('GM命令错误 - > %s'%(errorMsg) , curPlayer.GetPlayerID())
 | 
 |  |  |         if GameWorld.GetGameWorld().GetDebugLevel():
 | 
 |  |  |             raise BaseException(errorMsg)
 | 
 |  |  |         #=======================================================================
 | 
 |  |  |         # if GameWorld.GetGameWorld().GetDebugLevel():
 | 
 |  |  |         #    raise BaseException(errorMsg)
 | 
 |  |  |         #=======================================================================
 | 
 |  |  |         return
 | 
 |  |  | #---------------------------------------------------------------------
 | 
 |  |  | #===============================================================================
 | 
 |  |  | 
 |  |  |     #只将实际参数传入
 | 
 |  |  |     callFunc(cmdMsgList[1:], tick)
 | 
 |  |  |     return
 | 
 |  |  | 
 | 
 |  |  | def AddOfflinePlayerGMTInfo(orderId, queryType, playerFind, gmCmdDict):
 | 
 |  |  |     # 玩家不在线,先记录,等玩家上线后处理,开关服后无效
 | 
 |  |  |     key = (queryType, playerFind)
 | 
 |  |  |     ctgInfoList = PyGameData.g_gmtOfflinePlayerInfo.get(key, [])
 | 
 |  |  |     ctgInfoList.append(gmCmdDict)
 | 
 |  |  |     PyGameData.g_gmtOfflinePlayerInfo[key] = ctgInfoList
 | 
 |  |  |     GameWorld.Log("离线玩家添加GMT: g_gmtOfflinePlayerInfo=%s" % str(PyGameData.g_gmtOfflinePlayerInfo))
 | 
 |  |  |     GMCommon.GMCommandResult(orderId, gmCmdDict, GMCommon.Def_Success, "Player is off line.")
 | 
 |  |  |     return
 | 
 |  |  | 
 | 
 |  |  | def OnPlayerLogin(curPlayer):
 | 
 |  |  |     gmtList = []
 | 
 |  |  |     nameKey = (ChConfig.queryType_sqtPlayerByName, curPlayer.GetName())
 | 
 |  |  |     if nameKey in PyGameData.g_gmtOfflinePlayerInfo:
 | 
 |  |  |         gmtList += PyGameData.g_gmtOfflinePlayerInfo.pop(nameKey)
 | 
 |  |  |          | 
 |  |  |     accIDKey = (ChConfig.queryType_sqtPlayerByAccID, curPlayer.GetAccID())
 | 
 |  |  |     if accIDKey in PyGameData.g_gmtOfflinePlayerInfo:
 | 
 |  |  |         gmtList += PyGameData.g_gmtOfflinePlayerInfo.pop(accIDKey)
 | 
 |  |  |          | 
 |  |  |     if not gmtList:
 | 
 |  |  |         return
 | 
 |  |  |      | 
 |  |  |     tagMapID = curPlayer.GetRealMapID()
 | 
 |  |  |     GameWorld.Log("离线玩家上线GMT: tagMapID=%s, %s" % (tagMapID, gmtList), curPlayer.GetPlayerID())
 | 
 |  |  |     if not tagMapID:
 | 
 |  |  |         return
 | 
 |  |  |      | 
 |  |  |     for gmCmdDict in gmtList:
 | 
 |  |  |         pack_type = gmCmdDict.get("pack_type")
 | 
 |  |  |         if not pack_type:
 | 
 |  |  |             continue
 | 
 |  |  |          | 
 |  |  |         callFunc = GameWorld.GetExecFunc(Commands, "%s.%s"%(pack_type, "OnOfflineCTGInfo"))
 | 
 |  |  |         if callFunc:
 | 
 |  |  |             GameWorld.Log("玩家上线执行GMT: %s, tagMapID=%s, %s" % (pack_type, tagMapID, gmCmdDict), curPlayer.GetPlayerID())
 | 
 |  |  |             callFunc(curPlayer, tagMapID, gmCmdDict)
 | 
 |  |  |              | 
 |  |  |     return
 | 
 |  |  | 
 |