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
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
þíÛ[c@s¸ddlZddlZddlZddlZddlZddlZddlZddlZddlZddl    Z    ddl
Z
ddl Z ddl Z ddl Z ddlZddlZddlZddlZddlZddlZddlZddlZddlZddlZddlZddlZddlZddlZddlZddlZddlZddlZddl Z ddl!Z!ddl"Z"ddl#Z#ddl$Z$ddl%Z%ddl&Z&ddl'Z'ddl(Z(ddl)Z)ddl*Z*ddl+Z+ddl,Z,ddl-Z-ddl.Z.ddl/Z/ddl0Z0ddl1Z1ddl2Z2d„Z3d„Z4d„Z5d„Z6d„Z7d„Z8d„Z9dd    „Z;d
„Z<d „Z=d „Z>d „Z?d„Z@d„ZAd„ZBd„ZCd„ZDd„ZEd„ZFd„ZGd„ZHd„ZId„ZJd„ZKd„ZLd„ZMd„ZNd„ZOd„ZPd„ZQd „ZRd!„ZSd"„ZTd#„ZUd$„ZVd%„ZWd&„ZXdS('iÿÿÿÿNcCs’tjƒj|ƒ}yt||ƒWne|jtjƒddl}tjd|j    ƒƒtj
ƒj ƒrŽt d|j    ƒƒ‚qŽnXdS(NiÿÿÿÿsÍæ¼ÒÉÏÏßÂß¼­´íÎó~~~~~
%ssÍæ¼ÒÉÏÏßÂß¼­´íÎó~~~~
%s( t    GameWorldtGetPlayerManagertGetPlayerByIndext__Func_PlayerLogintKicktIPY_PlayerDefinetdisWaitForPlayerLoinErrort    tracebacktErrLogt
format_exct GetGameWorldt GetDebugLevelt    Exception(tindexttickt    curPlayerR((sSE:\SnxxServerCode\ServerPython\CoreServerGroup\GameServer\Script\Player\ChPlayer.pyt PlayerLoginPs cCsªt||ƒt||ƒtj||ƒtj||ƒtj||ƒtj    |ƒt
j |ƒsœt j ||ƒtj|ƒtj|ƒtj |ƒt||ƒtj |ƒtj |ƒtj |ƒtj |ƒtj|ƒtj |ƒtj |ƒtj |ƒtj|ƒtj |ƒt j|ƒt!j"|ƒt#j$|j%ƒƒt&j |ƒ|j'ƒt(j)|j%ƒ<t*j |ƒt+j |ƒn|j,ƒdS(N(-tInitPlayerOnLineTimetInitPlayerOnLineReplytGameDataRecordtPlayerLoginRecordt PlayerFamilytPlayerLoginRefreshFamilyt
PlayerTeamtOnPlayerLoginRefreshTeamtPlayerCompensationtNotifyPlayerCompensationt PlayerControltGetIsTJGt PlayerFriendt OnPlayerLogintGMCommontSendBroadCastToClientt PlayerTrucktSyncPlayerTruckStartTimet PlayerBourset__CheckWorldNotifyOnLogintPlayerFamilyRedPackettPlayerFamilyStoretPlayerFamilyPartytPlayerSealDemont
PlayerXMZZt OnXMZZOnLogint PlayerLVAwardt PlayerStoret GameWorldBosstPlayerFamilyBosstOnLogint PlayerDuJietPlayerFamilySWRHt
PlayerTalkt LoginChatMit PlayerGeTuitCleanNewGuyCallBackGeTuitGetIDtGameWorldActionControltGetLVt
PyGameDatatg_todayPlayerLVDicttGMShelltGMT_CTGtMapServer_InitOK(RR((sSE:\SnxxServerCode\ServerPython\CoreServerGroup\GameServer\Script\Player\ChPlayer.pyRbs>                     
cCsÃtjƒrdStjddƒ}|jƒ|kr8dStjddƒ}t|ƒ}|rl||krldStjdƒ}d}x;|D]3\}}t|tƒr•|t    j
kr¸qˆn|t    j gkrÐqˆntj ƒj |ƒ}    |    sñqˆn|    jƒ}
t|ƒ} x‰td| ƒD]u} | dks| |
kr=qn| d} | |krYqn|    j| ƒ}|jƒ|jƒkr|| }PqqWn|rˆtjd||jƒgƒPqˆqˆWdS(NtBillBoardPlayerLoginNotifyiitii(Rt IsMergeServert IpyGameDataPYt
GetFuncCfgR8tGetPlayerLeaveServerSecondtGetFuncEvalCfgt
isinstancetintt ShareDefinetBillboardTypeListtDef_BT_HighLaddert GetBillboardt FindBillboardtGetCounttmaxtrangetAtR6Rt WorldNotifytGetName(RRtlimitLVtnotifyCDt
LogoffTimetnotifyCheckListtmsgMarkt    checkMarkt
notifyDictt    billboardt billboardCnttmaxOrderR tordert objBillboard((sSE:\SnxxServerCode\ServerPython\CoreServerGroup\GameServer\Script\Player\ChPlayer.pyR$µsH    
 
 cCsp|jƒ}|dks$|dkr(dStj|ƒ}tjtjƒƒ}||}|jddd|jS(NR?t0iii<(t GetLogoffTimeRtGetDateTimeByStrtGetCurrentDataTimeStrtdaystseconds(Rt logoffTimeStrt
logoffTimet    loginTimet    diff_Time((sSE:\SnxxServerCode\ServerPython\CoreServerGroup\GameServer\Script\Player\ChPlayer.pyRCôs 
cCs„tjƒ}|jdƒ}|jdƒ}|s4dStjƒ}t|ƒ|_||_||_t    j
ƒ|_
t j ||ƒdS(Nt MergeServerIPtMergeServerPort( t
GameConfigt    GetConfigtgettChPyNetSendPackttagMergeServerInfotlent ServerIPLentServerIPtPortRR@t NetPackCommont SendFakePack(Rt    mapConfigt mergeServerIPtmergeServerPorttmergeServerInfo((sSE:\SnxxServerCode\ServerPython\CoreServerGroup\GameServer\Script\Player\ChPlayer.pytSendMergeWarOpens          cCsdS(N((R((sSE:\SnxxServerCode\ServerPython\CoreServerGroup\GameServer\Script\Player\ChPlayer.pyt MSGetRewardscCs7tj|ƒ}|sdSt||ƒt||ƒdS(N(Rt GetUserDatatActivateAccountAwardtSyncOPPlayerLoginInfo(RtcurPlayerUserData((sSE:\SnxxServerCode\ServerPython\CoreServerGroup\GameServer\Script\Player\ChPlayer.pytDoLogic_LoginUserDatas   cCsv|jƒ}|s|Syt|ƒ}Wntjd|ƒ|SXt|tƒsftjd|ƒ|S|j||ƒS(Nsdata error UserData = %sstype error UserData = %s(R{tevalRRREtdictRl(RtkeytdefaulttplayerUserDataStrR~((sSE:\SnxxServerCode\ServerPython\CoreServerGroup\GameServer\Script\Player\ChPlayer.pytGetUserDataByKey0s c    Csh|jddƒdkr£t|jddƒƒ}|jd|ƒd|t|jddƒƒt|jddƒƒt|jd    dƒƒt|jd
dƒƒg}n*t|jd
dƒƒ|jd dƒg}tj|jd d ƒƒ}|jtj|ƒ|jddƒ}|s(|jddƒ}ntj|jdd ƒƒ}|j|||gƒ|dkrÉ|jt|jddƒƒt|jddƒƒt|jddƒƒt|jddƒƒgƒnp|d kr9|jt|jddƒƒt|jddƒƒt|jddƒƒt|jddƒƒgƒnt|ƒ}|j    ddd|t
|ƒƒdS(!NtagentR?txunleitisvipit    XunLeiVIPtviplevelt    isgoldvipt    goldlevelt
clienttypet channel_codetpidR^tpftplatformtqidtypetqzonetpengyoutqplust    is_yellowtis_year_yellowtis_high_yellowt yellow_leveltqqgamet3366tis_bluet is_year_bluet is_high_bluet
blue_levelt    LoginData(R“R”R•(RšR›( RlRFtSetDictRtToIntDeftChConfigtDef_PlayerKey_PlayerFromPIDtextendtstrtMapServer_QueryPlayerResultRo(RtuserDictRˆtresultRR‘t account_type((sSE:\SnxxServerCode\ServerPython\CoreServerGroup\GameServer\Script\Player\ChPlayer.pyR}Ls,03* 04 04 cCsF|jdƒsdSt|dƒ}|jddd|t|ƒƒdS(Nt activateTypeit ActivateAward(thas_keyR¦R§Ro(RR¨tmsg((sSE:\SnxxServerCode\ServerPython\CoreServerGroup\GameServer\Script\Player\ChPlayer.pyR|sscCs!dS|jƒ}|sdSt|ƒ}tjdt|ƒ|fƒ|s^tjd|ƒdSy.t|dddƒ}|ddd}Wntk
r­tjdƒdSX|sÉtjd|ƒdS|rtj|ƒsótjd    |ƒdStt    j
t    j |d
ƒƒƒ}nd }dS( Nstype=%s, curPlayerUserData=%ssnot curPlayerUserData=%stdataR©tagetendtimes curPlayerAge or endTime ##Error!scurPlayerAge:%s not ##Error!sendTime:%s Format ##Error!s%Y-%m-%d %H:%M:%Si( R{R€RtLogttypeRFt BaseExceptionRR`ttimetmktimetstrptime(RR„R~t curPlayerAgetendTime((sSE:\SnxxServerCode\ServerPython\CoreServerGroup\GameServer\Script\Player\ChPlayer.pytNotifyGameWallowInfos2    $    c    CsÛ|jƒ}|sdS|jƒ}|j|ƒ}|sLtjd|ƒdStj|ƒ}|svtjd|ƒdSd}|jƒtjkršd}nd}tj    ƒj
|t j ||||t |ƒ|jƒƒdS(Ns'ˢмÒ×åÊôÐÔʧ°Ü, ¼Ò×å³ÉÔ±²éÕÒÒì³£ = %ss0ˢмÒ×åÊôÐÔʧ°Ü, ¼Ò×å³ÉÔ±²éÕÒÒì³£ tagMapID = %sR^t1tRefresh_Family_Info(t    GetFamilyt GetPlayerIDt
FindMemberRRtGetQueryPlayerMapIDt GetFamilyLVtIPY_GameServert    fmlLeaderRtMapServer_QueryPlayerR£t queryType_sqtRefresh_Family_InfoRotGetRouteServerIndex(Rt    curFamilytplayerIDt    curMemberttagMapIDtsendCMDt queryCallName((sSE:\SnxxServerCode\ServerPython\CoreServerGroup\GameServer\Script\Player\ChPlayer.pyt__RefreshFamilyToMapServer³s&      "cCs|j|ƒdS(N(t SetLoginTick(RR((sSE:\SnxxServerCode\ServerPython\CoreServerGroup\GameServer\Script\Player\ChPlayer.pyRÙs cCs|jdƒ|jdƒdS(Ni(tSetOnlineReplyErrorCounttSetOnlineReplyTick(RR((sSE:\SnxxServerCode\ServerPython\CoreServerGroup\GameServer\Script\Player\ChPlayer.pyRâs  cCsŒtjƒj|ƒ}yt||ƒWnUddl}tjd|jƒƒtjƒjƒr~t    d|jƒƒ‚q~nX|j
ƒdS(NiÿÿÿÿsÍæ¼ÒÏÂÏßÂß¼­´íÎó~~~~~
%ssÍæ¼ÒÏÂÏßÂß¼­´íÎó~~~~
%s( RRRt__Func_PlayerDisconnectRRR    R
R R t DoDisconnect(R RRR((sSE:\SnxxServerCode\ServerPython\CoreServerGroup\GameServer\Script\Player\ChPlayer.pytPlayerDisconnectìs 
cCsNtj||ƒtj||ƒtj||ƒtj||ƒt|ƒdS(N(    RtDoPlayerLogOffTeamLogicRtPlayerLogoffRefreshFamilyRtOnPlayerDisconnectR4tNewGuyCallBackGeTuitSetPlayerOfflineTime(RR((sSE:\SnxxServerCode\ServerPython\CoreServerGroup\GameServer\Script\Player\ChPlayer.pyRÑþs 
cCs‹tj|ƒrdS|jƒ}|jƒ}|s5dS|j|ƒ}tjƒ}tj|t    j
ƒ}t tj |ƒƒ}|j |ƒdS(N(RRR¾R½R¿RRaRµR·R£tTYPE_Time_FormatRFR¶t
SetExattr2(Rt curPlayerIDRÇRÉt
curTimeStrt curTimeTuplet
curTimeNum((sSE:\SnxxServerCode\ServerPython\CoreServerGroup\GameServer\Script\Player\ChPlayer.pyRØs   cCsdS(N((RR((sSE:\SnxxServerCode\ServerPython\CoreServerGroup\GameServer\Script\Player\ChPlayer.pytTruckPlayerDisconnectProcess*s    cCs8tjƒj|ƒ}tjƒ}|j|jƒƒdS(N(RRRRÂtIPY_GRefreshPlayerNametSetNameRQ(R RRtplayerNamePack((sSE:\SnxxServerCode\ServerPython\CoreServerGroup\GameServer\Script\Player\ChPlayer.pyt RefreshName:s cCstjƒj|ƒ}|dkr6tjd|ƒdStjƒ}|jƒ}|jƒ}|t    j
kr}t j ||ƒdS|tj kr t j||ƒdS|tjkrÃt j||ƒdS|tjkrætj||ƒdS|tjkr|j|ƒdS|tjkr)tj||ƒdS|tjkr†|j|ƒtj|||ƒ|jƒ}|tjkrò|tj|<qònl|tj kr¥|j!|ƒnM|tj"krÇt j#||ƒn+|tj$kræ|j%|ƒn |tj&kr|j'|ƒt(||ƒnà|tj)kr1|j*|ƒnÁ|tj+krP|j,|ƒn¢|tj-krrt j.||ƒn€|tj/kr”t j0||ƒn^|tj1kr³|j2|ƒn?|tj3krò|j4|ƒtj|||ƒt5j6|ƒntj7||||ƒtj8||ƒdS(Ns'RefreshState, index = %d, player = None(9RRRtNoneR²RÂtIPY_GRefreshPlayerPropertytGetValuetGetTypeRGtCDBPlayerRefresh_ForbidenTalkRtSetGMForbidenTalktCDBPlayerRefresh_StatetSetIsTJGtCDBPlayerRefresh_HappyPointt
SetTJGTimet"CDBPlayerRefresh_FamilyActiveValueRtReFreshPlayerFamilyActiveValuetCDBPlayerRefresh_FightPowert SetFightPowertCDBPlayerRefresh_ExAttr2RtSetTeamCheckStatetCDBPlayerRefresh_LVtSetLVt PlayerSocialtUpdateSocialInfoR6R9R:tCDBPlayerRefresh_JobtSetJobtCDBPlayerRefresh_ExAttr1t
SetJobRanktCDBPlayerRefresh_MapIDtSetMapIDtCDBPlayerRefresh_RealMapIDt SetRealMapIDtOnPlayerChangeRealMaptCDBPlayerRefresh_FBIDtSetFBIDtCDBPlayerRefresh_VIPLvtSetVIPLvtCDBPlayerRefresh_ExAttr9tSetVIPExpireTimetCDBPlayerRefresh_ExAttr10tSetChatBubbleBoxtCDBPlayerRefresh_OperateInfotSetOperateInfotCDBPlayerRefresh_OfficialRanktSetOfficialRanktPlayerBillboardtUpdateBillboardRealmtPlayerTeamMemberRefresht PlayerRefresh(R RRtplayerStatePackt    packValuetpackTypeRÈ((sSE:\SnxxServerCode\ServerPython\CoreServerGroup\GameServer\Script\Player\ChPlayer.pyt RefreshStateEsr         cCs†|jƒsdStjd|jƒ|jƒ|jƒf|jƒƒtj||ƒt    j|ƒt
j||ƒt j||ƒdS(NsÍæ¼Ò : %s,%s,FBID=%s Çл»µØÍ¼( t    GetInitOKRR²RQt GetRealMapIDtGetFBIDR¾RtOnPlayerChangeMapR-RR'(RR((sSE:\SnxxServerCode\ServerPython\CoreServerGroup\GameServer\Script\Player\ChPlayer.pyRªs 5 cCst||ƒdS(N(R(RR((sSE:\SnxxServerCode\ServerPython\CoreServerGroup\GameServer\Script\Player\ChPlayer.pyR¼s cCstS(N(tTrue(R R((sSE:\SnxxServerCode\ServerPython\CoreServerGroup\GameServer\Script\Player\ChPlayer.pytPlayerOnlineReplyÌscCsftjd|jƒ|jƒ|jƒ|jƒf|jƒƒtj|ƒ|j    t
ƒt |ƒdS(Ns(%s µÇ¼, accID = %s, IP = %s, MapID = %s( RR²RQtGetAccIDtGetIPRR¾tPlayerEventCountertUpdatePlayerLoginTimet    SetInitOKRRÍ(RR((sSE:\SnxxServerCode\ServerPython\CoreServerGroup\GameServer\Script\Player\ChPlayer.pytPlayerLoginLoadMapOKús
>          
cCsÀtjƒj|ƒ}tjƒ}|jƒdkrD|jtƒdS|jƒspt    ||ƒt
j ||ƒn|j ƒr‰|j ƒn|jtƒtj||ƒtjd|jƒƒdS(NisÍæ¼Ò¿ªÊ¼µØÍ¼³õʼ»¯¶¯×÷(RRRRÂtIPY_GPlayerLoadMapt GetLoadStatet SetIsLoadMapRRR tUpdatePlayerNamet$PlayerLoadMapRedressUpdatePlayerNamet GetIsLoadMaptMapServer_GameServerRefreshOKtFalseRtDoLogic_GMForbidIPR²R¾(R RRtpack((sSE:\SnxxServerCode\ServerPython\CoreServerGroup\GameServer\Script\Player\ChPlayer.pytPlayerLoadMapStates       cCs%tjƒ}tj}|jƒxdt|jƒƒD]P}|j|ƒ}|jƒdkro|j    |j
ƒƒq2|j |j ƒƒq2W|j ƒ}|dkrÁtjƒj||j ƒ|ƒdS|jƒdkrütjƒj|jƒ|j ƒ|ƒdStjƒj|jƒ|j ƒ|ƒdS(Ni(RÂtIPY_GWorldNotifyCodeRtNotifyCodeListtClearRNt GetParCounttGetParstGetLentAddIntt    GetMsgInttAddStrtGetMsgt GetFamilyIDRRtFamilyNotifyCodet    GetLineIDtCountryNotifyCodet
GetCountrytLineNotifyCodet GetRouteIndex(R RR*tnotifyCodeListtit    notifyMsgtfamilyID((sSE:\SnxxServerCode\ServerPython\CoreServerGroup\GameServer\Script\Player\ChPlayer.pyRPCs"     
  %%c        Cs‰tjƒj|ƒ}|j}|j}|j}tjƒ}t|||gƒ}|j|jƒdd|d|t    |ƒ|j
ƒƒdS(NitFBLinePlayerCnt( RRRtMapIDtFBLineIDt    IsAllLineR¦RÄR¾RoRÆ(    R t
clientDataRRt
queryMapIDtfbLineIDt    isAllLinet playerManagerRË((sSE:\SnxxServerCode\ServerPython\CoreServerGroup\GameServer\Script\Player\ChPlayer.pytClinetQueryFBLinePlayerCntvs             cCsÏ|s
dS|sdSt|ƒdkr*dS|\}}tjƒ}||_g|_xR|jƒD]D\}}tjƒ}|jƒ||_||_    |jj
|ƒqaWt|jƒ|_ t j ||ƒdS(Ni(RoRmttagGCFBLinePlayerCntRBtFBLineInfoListtitemsttagGCFBLineInfoR.RCt    PlayerCnttappendtCountRsRt(Rt
resultInfoRÊtfbLinePlayerCntDictt
fblinePacktlineIDt    playerCntt mapLineState((sSE:\SnxxServerCode\ServerPython\CoreServerGroup\GameServer\Script\Player\ChPlayer.pytQueryFBLinePlayerCntResult‚s&           
        cCsWtjƒj|ƒ}|j}tjddƒ}i}tjƒjƒ}|jƒ}xCt    |ƒD]5}    |j
|    ƒ}
|
j ƒ} xt    | ƒD]} |
j | ƒ} | j ƒ}|dkrÎ||krÎqn| jƒ}||krüt|||ƒ}n|j|gggƒ\}}xUt    |ƒD]G}| j|ƒ}|jƒ}|jƒ}|j|ƒ|j|ƒq'W||g||<|dkrPqqWqaWtjƒ}|jƒg|_xu|jƒD]g\}}tjƒ}|jƒ||_|d|_|d|_t|jƒ|_|jj|ƒqÆWt|jƒ|_t j!||ƒdS(NtMapLineii("RRRRBRARDR
tGetMapServerStateManagertGetZoneServerCnttxrangetGetZoneServerByIndext GetMapCounttGetMapServerStateByIndextGetMapIDt GetLineCounttminRltGetLineByIndextGetCurPlayerCnttGetMaxPlayerCntRPRmttagGCPyServerMapStateR.t MapStateListRMttagGCPyServerMapLineStatetLineCurPlayerCntListtLineMaxPlayerCntListRotLineCnttMapCountRsRt(R RERRRFt mapLineDictt mapPlayerDicttmapServerStateManagerR[t    zoneIndextZoneServerStatetmapCntR>tMapServerStatetmapIDtlineCnttcurPlayerCntListtmaxPlayerCntListt    lineIndextMapServerLineStatet curPlayerCntt maxPlayerCntt mapStatePackt playerCntListRW((sSE:\SnxxServerCode\ServerPython\CoreServerGroup\GameServer\Script\Player\ChPlayer.pytClientQueryLineStateŸsR               
     
      cCsdS(N((R R((sSE:\SnxxServerCode\ServerPython\CoreServerGroup\GameServer\Script\Player\ChPlayer.pytMapServer_GetLineStateÖs)cCsStjƒj|ƒ}||jdƒtjkr5dS|jƒ|jd|ƒdS(Nt ShowFbEvent(RRRt GetDictByKeyR£tDef_Show_Fb_Event_TicktSync_GameFbEventR¡(R RR((sSE:\SnxxServerCode\ServerPython\CoreServerGroup\GameServer\Script\Player\ChPlayer.pyR€s
 
cCsßtjƒ}|j|ƒ}tjƒ}||jtjƒtjtjkratj    |dƒdS|j
tj|ƒt j ƒ}|j |jƒƒ}|s¯tj    |dƒdS|j|t|jƒƒƒtj    |dƒdS(NtSpeech_Lost_FrequentlytSpeech_Lost_NoLinetSpeech_Success(RRRR
t GetTickByTypeR£tTYPE_ImpeachTicktTYPE_Tick_TimeRt
NotifyCodet SetTickByTypeRÂt IPY_CImpeachtFindPlayerByIDR¾t ImpeachPlayerR¦tGetTalk(R RRIRt    gameWorldR*t    tagPlayer((sSE:\SnxxServerCode\ServerPython\CoreServerGroup\GameServer\Script\Player\ChPlayer.pytImpeach&s  & cCs&tjƒj|ƒ}t||ƒdS(N(RRRtSync_PyServerDataTimeToClient(R RERR((sSE:\SnxxServerCode\ServerPython\CoreServerGroup\GameServer\Script\Player\ChPlayer.pytClientRequestServerTimeEs cCs°tj|tj|ƒsdStjƒ}|s2dStjƒ}|jƒ|j|_    |j
|_ |j |_ |j|_|j|_|j|_|j|_tj||ƒdS(N(RtRefurbishPlayerTickR£tTYPE_Player_Tick_SyncClientTickt GetServerTimeRmttagServerDateTimeR.tyeartYeartmonthtMonthtdaytDaythourtHourtminutetMinutetsecondtSecondt microsecondt    MicSecondRsRt(RRt
serverTimetserverDateTime((sSE:\SnxxServerCode\ServerPython\CoreServerGroup\GameServer\Script\Player\ChPlayer.pyR“Os   
       cCsžtjt_it_tjƒ}xvt|jƒƒD]b}|j|ƒ}|dks4|j    ƒ rhq4nt
j |ƒr}q4n|j ƒtj|j ƒ<q4WdS(N(R9R:tg_yesterdayPlayerLVDictRRR\tGetActivePlayerCounttGetActivePlayerAtRäRRRR8R6(RIR>R((sSE:\SnxxServerCode\ServerPython\CoreServerGroup\GameServer\Script\Player\ChPlayer.pytUpdataPlayerLVInfohs      cCsçtjƒ}|jtjƒ}|jƒ}x<t|ƒD].}|j|ƒ}|jƒt    j
|j ƒ<q7W|jtj ƒ}|jƒ}x<t|ƒD].}|j|ƒ}|jƒt    j |j ƒ<q”Wtjdt    j
t    j fƒdS(NsV    ·þÎñÆ÷¿ªÆôʱ¼ÓÔØ»îÔ¾Íæ¼ÒµÈ¼¶ÐÅÏ¢g_todayPlayerLVDict=%s, g_yesterdayPlayerLVDict=%s(RtGetUniversalRecMgrt GetTypeListRGt*Def_UniversalGameRecType_TodayPlayerLVInfoRQR\ROt    GetValue2R9R:t    GetValue1t.Def_UniversalGameRecType_YesterdayPlayerLVInfoR©tDebugLog(tuniversalRecMgrt recDataListtallCntR trecData((sSE:\SnxxServerCode\ServerPython\CoreServerGroup\GameServer\Script\Player\ChPlayer.pytLoadPlayerLVDatavs   cCsìtjƒjtjƒtjƒjtjƒtjƒ}|jtjƒ}xCtjj    ƒD]2\}}|j
ƒ}|j |ƒ|j |ƒqZW|jtjƒ}xCtj j    ƒD]2\}}|j
ƒ}|j |ƒ|j |ƒq²WdS(N(RR­tDeleteRGR¯R²R®R9R:RMtAddRect    SetValue1t    SetValue2R©(R´RµRÈtlvR·((sSE:\SnxxServerCode\ServerPython\CoreServerGroup\GameServer\Script\Player\ChPlayer.pytSavePlayerLVDataˆs     (YRRÂRR£RRRRRRGtPlayerDataCollectRµRmRsRRjt ReadChConfigR$R-R.R#tGameWorldActionTeHuiR)tGameWorldMergePKtGameWorldShopItemt MergeChildMsgR!tPlayerMergeEventt
HighLaddert EventReportt MergePlayerRR%R&t PyDataManagerRöR'R(R R+R0R1RAR2R4R,R7R<R9R;RRRR$RCRyRzRRäR…R}R|RºRÍRRRÓRÑRØRßRãRRRRR R+RPRJRXR~RR€R’R”R“R¬R¸R¾(((sSE:\SnxxServerCode\ServerPython\CoreServerGroup\GameServer\Script\Player\ChPlayer.pyt<module>s®                                                               S    ?                     '         4    &            
                         e            .        *    3             7    0