From 01a0e539b786ae0f1c46646874502367f5410aca Mon Sep 17 00:00:00 2001
From: hxp <ale99527@vip.qq.com>
Date: 星期三, 04 二月 2026 18:18:51 +0800
Subject: [PATCH] 66 【公会】基础主体-服务端(优化游戏服及跨服启动、通讯逻辑;服务器类型增加跨服中心、跨服事件、时间管理;跨服玩家在线状态、基础信息、玩家资源增减管理、发送跨服个人邮件等;跨服公会初版,修复公会成员审核、成员战力刷新等bug,增加公会名次同步;跨服公会暂未测试;)

---
 ServerPython/ZoneServerGroup/map1_8G/MapServer/MapServerData/Script/GM/GMShell.py |   80 +++++++++++++++++++++-------------------
 1 files changed, 42 insertions(+), 38 deletions(-)

diff --git a/ServerPython/ZoneServerGroup/map1_8G/MapServer/MapServerData/Script/GM/GMShell.py b/ServerPython/ZoneServerGroup/map1_8G/MapServer/MapServerData/Script/GM/GMShell.py
index c3ca851..c2d6f9b 100644
--- a/ServerPython/ZoneServerGroup/map1_8G/MapServer/MapServerData/Script/GM/GMShell.py
+++ b/ServerPython/ZoneServerGroup/map1_8G/MapServer/MapServerData/Script/GM/GMShell.py
@@ -30,6 +30,9 @@
 import traceback
 import FBLogic
 import GameObj
+import CrossMsg
+import ShareDefine
+import CrossPlayer
 #---------------------------------------------------------------------
 
 #---------------------------------------------------------------------
@@ -94,24 +97,29 @@
             
         #验证权限失败
         elif not CheckGMLV(curPlayer , callFunName):
+            GameWorld.DebugAnswer(curPlayer, 'GM等级不足!')
             return
+        
+        #把剩余参数转换为整型
+        for i in range(1, len(inputList)):
+            value = GameWorld.ToNumDef(inputList[i], None)
+            if value == None:
+                #GameWorld.DebugAnswer(curPlayer, "参数错误, 必须为纯数字!")
+                continue
+            inputList[i] = value
             
+        if GameWorld.IsMainServer():
+            callFunc = GameWorld.GetExecFunc(Commands, "%s.%s"%(callFunName, "GetGMServerIDList"))
+            if callFunc != None:
+                gmServerIDList = callFunc(curPlayer)
+                if gmServerIDList:
+                    CrossMsg.SendToCrossServer(ShareDefine.S2C_GMCMD, {"CMD":inputList}, gmServerIDList, curPlayer.GetPlayerID())
+                    
         callFunc = GameWorld.GetExecFunc(Commands, "%s.%s"%(callFunName, "OnExec"))
         if callFunc:
-            #删除命令,只将参数传入
-            del inputList[0]
-            #把剩余参数转换为整型
-            for i in range(0, len(inputList)):
-                value = GameWorld.ToNumDef(inputList[i], None)
-                if value == None:
-                    #GameWorld.DebugAnswer(curPlayer, "参数错误, 必须为纯数字!")
-                    continue
-                inputList[i] = value
-                
-            isSendGameServer = callFunc(curPlayer, inputList)
+            #删除命令,只将参数传入            
+            callFunc(curPlayer, inputList[1:])
             DR_UseGMCMD(curPlayer, inputStr)
-            if isSendGameServer:
-                curPlayer.GameServer_GMCmd(inputStr)
             return
         
         # GameObj 的 Get、Set函数
@@ -186,13 +194,33 @@
             DR_UseGMCMD(curPlayer, inputStr)
             return
         
-        curPlayer.GameServer_GMCmd(inputStr)
+        #没有此命令
+        GameWorld.Log("###使用GM命令 = %s, 没有该命令!" % callFunName, curPlayer.GetPlayerID())
+        GameWorld.DebugAnswer(curPlayer, 'no cmd !!!')
     except BaseException:
         GameWorld.DebugAnswer(curPlayer, "执行GM命令错误, 请查看所在地图日志!")
         errorMsg = str(traceback.format_exc())
         GameWorld.ErrLog('GM命令错误 - > %s' % errorMsg, curPlayer.GetPlayerID())
         #if GameWorld.GetGameWorld().GetDebugLevel():
         #    raise Exception(errorMsg)
+    return
+
+def S2C_GMCMD(dataMsg, fromServerID, playerID):
+    cmdList = dataMsg["CMD"]
+    
+    callName = "%s.%s" % (cmdList[0], "OnExecCross")
+    callFunc = GameWorld.GetExecFunc(Commands, callName)
+    if callFunc == None:
+        GameWorld.ErrLog("找不到此GM命令处理函数%s" % callName)
+        return
+    GameWorld.Log("跨服执行GM命令:%s" % cmdList)
+    
+    crossPlayer = CrossPlayer.GetCrossPlayerMgr().FindCrossPlayer(playerID)
+    if not crossPlayer:
+        crossPlayer = CrossPlayer.GetCrossPlayerMgr().RegistPlayer(playerID)
+        
+    #只将实际参数传入
+    callFunc(crossPlayer, cmdList[1:])
     return
 
 ## 使用GM命令流向
@@ -223,30 +251,6 @@
     if curPlayer_GMLV == 90:
         #内部测试人员,不限制
         return True
-    
-    GMLVPowerDict = ReadChConfig.GetEvalChConfig("GMLVPower")
-    if curPlayer_GMLV in GMLVPowerDict:
-        powerList = GMLVPowerDict[curPlayer_GMLV]
-        if not powerList or callFunName in powerList:
-            return True
-    
-    #验证权限
-    if callFunName in ChConfig.Def_GMPower_Disc:
-        gmPowerList = ChConfig.Def_GMPower_Disc[callFunName]
-        
-        if curPlayer_GMLV not in gmPowerList:
-            #GM等级异常
-            GameWorld.Log("###使用GM命令 = %s,GM等级 = %s异常"%(callFunName , curPlayer_GMLV) , curPlayer.GetPlayerID())
-            return
-        
-        if not gmPowerList[curPlayer_GMLV]:
-            GameWorld.Log("###使用GM命令 = %s,权限 = %s不足"%(callFunName , curPlayer_GMLV) , curPlayer.GetPlayerID())
-            return
-        
-    #内部测试用GM命令
-    else:
-        GameWorld.Log("###非内部人员, 使用调试GM命令 = %s,权限 = %s不足"%(callFunName , curPlayer_GMLV) , curPlayer.GetPlayerID())
-        return
     
     return True
             

--
Gitblit v1.8.0