hzr
3 天以前 c999bc50d37b5371f92ba71b3ab70f6eeb0e5076
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
1dgc@sÝddlZddlZddlZddlZddlZddlZddlZddlZddlZddl    Z    gZ
d„Z e dƒd„Z d„Z d„Zd„Zd„Zd    „Zd
„Zd „ZdS( iÿÿÿÿNc    Csûtjƒd}xätjd||fƒD]É\}}}x·|D]¯}tjj||ƒ}|j|dƒ}|dt|ƒ!}|jdƒdkr›q@n|j    dƒ}|d}|d}|tj
krÓq@n|jddƒ}t |ƒq@Wq*WdS(    Ns    Script\GMs%s\%stit__init__is.s\( tChConfigt
GetAppPathtostwalktpathtjointreplacetlentfindtsplittTYPE_Load_Module_Extt
__import__(    t    importDirtcurPathtroottdirstfilestfiletfileNamet curFileListtext((sNE:\SnxxServerCode\ServerPython\CoreServerGroup\GameServer\Script\GM\GMShell.pytImportCommandAll#s) 
 
tCommandscCstjtƒ||ƒdS(N(t    GameWorldt GetPsycoFunct__Func_MapServer_RecvGMCMD(tindexttick((sNE:\SnxxServerCode\ServerPython\CoreServerGroup\GameServer\Script\GM\GMShell.pytMapServer_RecvGMCMD=sc Cs0yÛtjƒ}|jƒ}|jƒ}t|ƒdkr=dStjƒj|ƒ}|d}|jdƒr‚d|dj    ƒ}n0|j
ƒdkr²tj d||j ƒƒdSxat dt|ƒƒD]J}|dkràqÈntj||dƒ}|dkrqÈn|||<qÈWtjƒsstjtd|dfƒ}    |    dkrs|    |ƒ}
tjtj||
ƒqsntjtd|dfƒ}    |    dkrÉtj d    ||j ƒƒtj|d
ƒdS|    ||dƒWnNtk
r+tj|d ƒttjƒƒ} tjd | |j ƒƒdSXdS( Nis@sGMS_%sis!###ʹÓÃGMÃüÁî = %s´íÎó,Íæ¼Ò²»ÊÇGMs%s.%stOnGetMergeParamtOnExecs###ʹÓÃGMÃüÁî = %s, Ã»ÓиÃÃüÁî!s
no cmd !!!s%Ö´ÐÐGMÃüÁî´íÎó, Çë²é¿´GameServerÈÕÖ¾!sGMÃüÁî´íÎó - > %s(tIPY_GameServert
IPY_GGMCmdtGetMsgR R    RtGetPlayerManagertGetPlayerByIndext
startswitht
capitalizet
GetGMLeveltLogt GetPlayerIDtrangetToIntDeftNonet IsCrossServert GetExecFuncRt CrossRealmMsgtSendMsgToCrossServert ShareDefinetClientServerMsg_GMCMDt DebugAnswert BaseExceptiontstrt    tracebackt
format_exctErrLog( RRtgmCmdtinputStrtalistt    curPlayert callFunNametitvaluetcallFunctextendParamListterrorMsg((sNE:\SnxxServerCode\ServerPython\CoreServerGroup\GameServer\Script\GM\GMShell.pyRFsH   
       cCsdS(N((t
dBGMCommon((sNE:\SnxxServerCode\ServerPython\CoreServerGroup\GameServer\Script\GM\GMShell.pytDoLogic_DBGMCommonŠsc    Cs6tjƒ}|jƒ}|jƒ}yÌt|ƒ}|jtjdƒ}|dkrntj    ||tj
ƒdSt j t d|dfƒ}|dkr°tj    ||tj
ƒdSt|ƒ}|ikrâtj    ||tjƒdS|||ƒWn?tk
r1tj    ||tjƒt jdtjƒƒdSXdS(NRs%s.%sR sGMÃüÁî´íÎó
%s(R!tIPY_GGMToolCommandtGetCmdt
GetOrderIdtevaltgettGMCommontDef_GMKey_TypeR-tGMCommandResultt Def_GMCmdNoneRR/RtChangeEncodIngtDef_EncodeFailR5tDef_GMGSEntranceFailtRaiseExceptionR7R8(    RRt    gmToolCMDtcmdtorderIdt    gmCmdDicttgmTypeRAtcmdDict((sNE:\SnxxServerCode\ServerPython\CoreServerGroup\GameServer\Script\GM\GMShell.pytGMTool_RecvCMD±s.         cCsÑi}|jddƒ}|dkr(|Sx¢|jƒD]”\}}t|tƒsVq5nyG|jddƒ}|jddƒ}td|ƒ}|j|ƒ}Wntjdt    |ƒƒiSX|||<q5W|S(    NtcodingRs
s`rs's\'su'%s's translateStr error! srcStr = %s (
RJtitemst
isinstanceR6RRItencodeRR)trepr(RVRXRZtkeyR@t translateStr((sNE:\SnxxServerCode\ServerPython\CoreServerGroup\GameServer\Script\GM\GMShell.pyROÙs" cCs‰t|ƒdkrdSd|ddf}tjt|ƒ}|dkr]tjd|ƒdStjdt|ƒƒ||d|ƒdS(Nis%s.%stOnMergeServerExecsÕÒ²»µ½´ËGMÃüÁî´¦Àíº¯Êý%ssÖ´ÐÐ×Ó·þÇëÇóµÄGMÃüÁ%si(R    RR/RR-R9R)R6(t
cmdMsgListRtcallNameRA((sNE:\SnxxServerCode\ServerPython\CoreServerGroup\GameServer\Script\GM\GMShell.pyR3ôs cCsr||f}tjj|gƒ}|j|ƒ|tj|<tjdttjƒƒtj||tj    dƒdS(Ns*ÀëÏßÍæ¼ÒÌí¼ÓGMT: g_gmtOfflinePlayerInfo=%ssÍæ¼Ò²»ÔÚÏߣ¬½«ÔÚÉÏÏߺó×Ô¶¯´¦Àí(
t
PyGameDatatg_gmtOfflinePlayerInfoRJtappendRR)R6RKRMt Def_Success(RUt    queryTypet
playerFindRVR_t ctgInfoList((sNE:\SnxxServerCode\ServerPython\CoreServerGroup\GameServer\Script\GM\GMShell.pytAddOfflinePlayerGMTInfos   cCsHg}tj|jƒf}|tjkrC|tjj|ƒ7}ntj|jƒf}|tjkr€|tjj|ƒ7}n|sŠdS|jƒ}t    j
d||f|j ƒƒ|sÀdSx|D]y}|j dƒ}|sèqÇnt    j td|dfƒ}|rÇt    j
d|||f|j ƒƒ||||ƒqÇqÇWdS(Ns ÀëÏßÍæ¼ÒÉÏÏßGMT: tagMapID=%s, %st    pack_types%s.%stOnOfflineGMTInfos$Íæ¼ÒÉÏÏßÖ´ÐÐGMT: %s, tagMapID=%s, %s(RtqueryType_sqtPlayerByNametGetNameRdRetpoptqueryType_sqtPlayerByAccIDtGetAccIDt GetRealMapIDRR)R*RJR/R(R=tgmtListtnameKeytaccIDKeyttagMapIDRVRlRA((sNE:\SnxxServerCode\ServerPython\CoreServerGroup\GameServer\Script\GM\GMShell.pyt OnPlayerLogin s,   #(RRRR!R0RdR7RKR2Rtg_broadCastListRRRRERYROR3RkRx(((sNE:\SnxxServerCode\ServerPython\CoreServerGroup\GameServer\Script\GM\GMShell.pyt<module>s(              
            D    '    (