xdh
2018-11-22 cecebcc3370139c937b6a72be5d3a151ddd5be9f
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
Ôõ[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ãtjd|jƒ|jƒƒ|jtj|jƒƒt||ƒt||ƒt    j
||ƒt j ||ƒt j||ƒtj|ƒtj|ƒsÕtj||ƒtj|ƒtj|ƒtj|ƒt||ƒtj|ƒtj|ƒtj|ƒtj|ƒtj |ƒt!j|ƒt"j|ƒt#j|ƒt$j%|ƒt&j|ƒt'j%|ƒt(j)|ƒt*j+|j,ƒƒt-j|ƒ|j.ƒt/j0|j,ƒ<t1j|ƒt2j|ƒn|j3ƒdS(Ns__Func_PlayerLogin mapID=%s(4RtLogtGetMapIDt GetPlayerIDtSetDicttChConfigtDef_PDict_LoginMapIDtInitPlayerOnLineTimetInitPlayerOnLineReplytGameDataRecordtPlayerLoginRecordt 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.pyRbsB                      
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
GetFuncCfgR>tGetPlayerLeaveServerSecondtGetFuncEvalCfgt
isinstancetintt ShareDefinetBillboardTypeListtDef_BT_HighLaddert GetBillboardt FindBillboardtGetCounttmaxtrangetAtR<R!t 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(NREt0iii<(t GetLogoffTimeRtGetDateTimeByStrtGetCurrentDataTimeStrtdaystseconds(Rt logoffTimeStrt
logoffTimet    loginTimet    diff_Time((sSE:\SnxxServerCode\ServerPython\CoreServerGroup\GameServer\Script\Player\ChPlayer.pyRIös 
cCs„tjƒ}|jdƒ}|jdƒ}|s4dStjƒ}t|ƒ|_||_||_t    j
ƒ|_
t j ||ƒdS(Nt MergeServerIPtMergeServerPort( t
GameConfigt    GetConfigtgettChPyNetSendPackttagMergeServerInfotlent ServerIPLentServerIPtPortRRFt 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_LoginUserData s   cCsv|jƒ}|s|Syt|ƒ}Wntjd|ƒ|SXt|tƒsftjd|ƒ|S|j||ƒS(Nsdata error UserData = %sstype error UserData = %s(RtevalRRRKtdictRr(RtkeytdefaulttplayerUserDataStrR„((sSE:\SnxxServerCode\ServerPython\CoreServerGroup\GameServer\Script\Player\ChPlayer.pytGetUserDataByKey2s 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(!NtagentREtxunleitisvipit    XunLeiVIPtviplevelt    isgoldvipt    goldlevelt
clienttypet channel_codetpidRdtpftplatformtqidtypetqzonetpengyoutqplust    is_yellowtis_year_yellowtis_high_yellowt yellow_leveltqqgamet3366tis_bluet is_year_bluet is_high_bluet
blue_levelt    LoginData(R™RšR›(R R¡( RrRLRRtToIntDefRtDef_PlayerKey_PlayerFromPIDtextendtstrtMapServer_QueryPlayerResultRu(RtuserDictRŽtresultR•R—t account_type((sSE:\SnxxServerCode\ServerPython\CoreServerGroup\GameServer\Script\Player\ChPlayer.pyRƒNs,03* 04 04 cCsF|jdƒsdSt|dƒ}|jddd|t|ƒƒdS(Nt activateTypeit ActivateAward(thas_keyRªR«Ru(RR¬tmsg((sSE:\SnxxServerCode\ServerPython\CoreServerGroup\GameServer\Script\Player\ChPlayer.pyR‚uscCs!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†RRttypeRLt BaseExceptionRRfttimetmktimetstrptime(RRŠR„t curPlayerAgetendTime((sSE:\SnxxServerCode\ServerPython\CoreServerGroup\GameServer\Script\Player\ChPlayer.pytNotifyGameWallowInfos2    $    c    CsÛ|jƒ}|sdS|jƒ}|j|ƒ}|sLtjd|ƒdStj|ƒ}|svtjd|ƒdSd}|jƒtjkršd}nd}tj    ƒj
|t j ||||t |ƒ|jƒƒdS(Ns'ˢмÒ×åÊôÐÔʧ°Ü, ¼Ò×å³ÉÔ±²éÕÒÒì³£ = %ss0ˢмÒ×åÊôÐÔʧ°Ü, ¼Ò×å³ÉÔ±²éÕÒÒì³£ tagMapID = %sRdt1tRefresh_Family_Info(t    GetFamilyRt
FindMemberRRtGetQueryPlayerMapIDt GetFamilyLVtIPY_GameServert    fmlLeaderRtMapServer_QueryPlayerRt queryType_sqtRefresh_Family_InfoRutGetRouteServerIndex(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(    RtDoPlayerLogOffTeamLogicRtPlayerLogoffRefreshFamilyR#tOnPlayerDisconnectR:tNewGuyCallBackGeTuitSetPlayerOfflineTime(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(R!R"RRÀRÁRRgR¸RºRtTYPE_Time_FormatRLR¹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_GRefreshPlayerNametSetNameRW(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(9RRRtNoneRRÄtIPY_GRefreshPlayerPropertytGetValuetGetTypeRMtCDBPlayerRefresh_ForbidenTalkR!tSetGMForbidenTalktCDBPlayerRefresh_StatetSetIsTJGtCDBPlayerRefresh_HappyPointt
SetTJGTimet"CDBPlayerRefresh_FamilyActiveValueRtReFreshPlayerFamilyActiveValuetCDBPlayerRefresh_FightPowert SetFightPowertCDBPlayerRefresh_ExAttr2RtSetTeamCheckStatetCDBPlayerRefresh_LVtSetLVt PlayerSocialtUpdateSocialInfoR<R?R@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 RefreshStateGsr         cCs†|jƒsdStjd|jƒ|jƒ|jƒf|jƒƒtj||ƒt    j|ƒt
j||ƒt j||ƒdS(NsÍæ¼Ò : %s,%s,FBID=%s Çл»µØÍ¼( t    GetInitOKRRRWt GetRealMapIDtGetFBIDRRtOnPlayerChangeMapR3RR-(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ÎscCsvtjd|jƒ|jƒ|jƒ|jƒf|jƒƒtj||ƒt    j
|ƒ|j t ƒt |ƒdS(Ns(%s µÇ¼, accID = %s, IP = %s, MapID = %s(RRRWtGetAccIDtGetIPRRRtOnPlayerReadMapOKtPlayerEventCountertUpdatePlayerLoginTimet    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_GameServerRefreshOKtFalseR%tDoLogic_GMForbidIPRR(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_GWorldNotifyCodeR!tNotifyCodeListtClearRTt GetParCounttGetParstGetLentAddIntt    GetMsgInttAddStrtGetMsgt GetFamilyIDRRtFamilyNotifyCodet    GetLineIDtCountryNotifyCodet
GetCountrytLineNotifyCodet GetRouteIndex(R RR-tnotifyCodeListtit    notifyMsgtfamilyID((sSE:\SnxxServerCode\ServerPython\CoreServerGroup\GameServer\Script\Player\ChPlayer.pyRVEs"     
  %%c        Cs‰tjƒj|ƒ}|j}|j}|j}tjƒ}t|||gƒ}|j|jƒdd|d|t    |ƒ|j
ƒƒdS(NitFBLinePlayerCnt( RRRtMapIDtFBLineIDt    IsAllLineRªRÆRRuRÈ(    R t
clientDataRRt
queryMapIDtfbLineIDt    isAllLinet playerManagerRÍ((sSE:\SnxxServerCode\ServerPython\CoreServerGroup\GameServer\Script\Player\ChPlayer.pytClinetQueryFBLinePlayerCntxs             cCsÏ|s
dS|sdSt|ƒdkr*dS|\}}tjƒ}||_g|_xR|jƒD]D\}}tjƒ}|jƒ||_||_    |jj
|ƒqaWt|jƒ|_ t j ||ƒdS(Ni(RuRsttagGCFBLinePlayerCntREtFBLineInfoListtitemsttagGCFBLineInfoR1RFt    PlayerCnttappendtCountRyRz(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("RRRRERGRJR
tGetMapServerStateManagertGetZoneServerCnttxrangetGetZoneServerByIndext GetMapCounttGetMapServerStateByIndexRt GetLineCounttminRrtGetLineByIndextGetCurPlayerCnttGetMaxPlayerCntRSRsttagGCPyServerMapStateR1t MapStateListRPttagGCPyServerMapLineStatetLineCurPlayerCntListtLineMaxPlayerCntListRutLineCnttMapCountRyRz(R RHRRRIt mapLineDictt mapPlayerDicttmapServerStateManagerR^t    zoneIndextZoneServerStatetmapCntRAtMapServerStatetmapIDtlineCnttcurPlayerCntListtmaxPlayerCntListt    lineIndextMapServerLineStatet curPlayerCntt maxPlayerCntt mapStatePackt playerCntListRZ((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 GetDictByKeyRtDef_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 GetTickByTypeRtTYPE_ImpeachTicktTYPE_Tick_TimeR!t
NotifyCodet SetTickByTypeRÄt IPY_CImpeachtFindPlayerByIDRt ImpeachPlayerRªtGetTalk(R RRLRt    gameWorldR-t    tagPlayer((sSE:\SnxxServerCode\ServerPython\CoreServerGroup\GameServer\Script\Player\ChPlayer.pytImpeach(s  & cCs&tjƒj|ƒ}t||ƒdS(N(RRRtSync_PyServerDataTimeToClient(R RHRR((sSE:\SnxxServerCode\ServerPython\CoreServerGroup\GameServer\Script\Player\ChPlayer.pytClientRequestServerTimeGs cCs°tj|tj|ƒsdStjƒ}|s2dStjƒ}|jƒ|j|_    |j
|_ |j |_ |j|_|j|_|j|_|j|_tj||ƒdS(N(RtRefurbishPlayerTickRtTYPE_Player_Tick_SyncClientTickt GetServerTimeRsttagServerDateTimeR1tyeartYeartmonthtMonthtdaytDaythourtHourtminutetMinutetsecondtSecondt microsecondt    MicSecondRyRz(RRt
serverTimetserverDateTime((sSE:\SnxxServerCode\ServerPython\CoreServerGroup\GameServer\Script\Player\ChPlayer.pyR•Qs   
       cCsžtjt_it_tjƒ}xvt|jƒƒD]b}|j|ƒ}|dks4|j    ƒ rhq4nt
j |ƒr}q4n|j ƒtj|j ƒ<q4WdS(N(R?R@tg_yesterdayPlayerLVDictRRR_tGetActivePlayerCounttGetActivePlayerAtRæRR!R"R>R<(RLRAR((sSE:\SnxxServerCode\ServerPython\CoreServerGroup\GameServer\Script\Player\ChPlayer.pytUpdataPlayerLVInfojs      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 GetTypeListRMt*Def_UniversalGameRecType_TodayPlayerLVInfoRTR_RUt    GetValue2R?R@t    GetValue1t.Def_UniversalGameRecType_YesterdayPlayerLVInfoR«tDebugLog(tuniversalRecMgrt recDataListtallCntR trecData((sSE:\SnxxServerCode\ServerPython\CoreServerGroup\GameServer\Script\Player\ChPlayer.pytLoadPlayerLVDataxs   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¯tDeleteRMR±R´R°R?R@RPtAddRect    SetValue1t    SetValue2R«(R¶R·RÊtlvR¹((sSE:\SnxxServerCode\ServerPython\CoreServerGroup\GameServer\Script\Player\ChPlayer.pytSavePlayerLVDataŠs     (YRRÄRRR!RR R#R%RMtPlayerDataCollectR¸RsRyRRpt ReadChConfigR'R3R4R)tGameWorldActionTeHuiR/tGameWorldMergePKtGameWorldShopItemt MergeChildMsgR'tPlayerMergeEventt
HighLaddert EventReportt MergePlayerRR+R,t PyDataManagerRøR-R.RR1R6R7RGR8R:R2R=RBR?RARRRR*RIRR€R…RæR‹RƒR‚R½RÏRRRÕRÓRÚRáRåRRRRR#R.RVRMR[R€RR‚R”R–R•R®RºRÀ(((sSE:\SnxxServerCode\ServerPython\CoreServerGroup\GameServer\Script\Player\ChPlayer.pyt<module>s®                                                               U    ?                     '         4    &            
                         e            .        *    3             7    0