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
92
93
94
95
96
97
98
99
100
101
102
103
104
105
106
107
108
109
110
111
112
113
114
115
116
117
118
119
120
121
122
123
124
125
126
127
128
129
130
131
132
133
134
135
136
137
138
139
140
141
142
143
144
145
146
147
148
149
150
151
152
153
154
155
156
157
158
159
160
161
162
163
164
165
166
167
168
169
170
171
172
173
174
175
176
177
178
179
180
181
182
183
184
185
186
187
188
189
190
191
192
193
194
195
196
197
198
199
200
201
202
203
204
205
206
207
208
209
210
211
212
213
214
215
216
217
218
219
220
221
222
223
224
225
226
227
228
229
230
231
232
233
234
235
236
237
238
239
240
241
242
243
244
245
246
247
248
249
250
251
252
253
254
255
256
257
258
259
260
261
262
263
264
265
266
267
268
269
270
271
272
273
274
275
276
277
278
279
280
281
282
283
284
285
286
287
288
289
290
291
292
293
294
295
296
297
298
299
300
301
302
303
304
305
306
307
308
309
310
311
312
313
314
315
316
317
318
319
320
321
322
323
324
325
326
327
328
329
330
331
332
333
334
335
336
337
338
339
340
341
342
343
344
345
346
347
348
349
350
351
352
353
354
355
356
357
358
359
360
361
362
363
364
365
366
367
368
369
370
371
372
373
374
375
376
377
378
379
380
381
382
383
384
385
386
387
388
389
390
391
392
393
394
395
396
397
398
399
400
401
402
403
404
405
406
407
408
409
410
411
412
413
414
415
416
417
418
419
420
421
422
423
424
425
426
427
428
429
430
431
û<jc@sS    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/ddl0Z0ddl1Z1ddl2Z2ddl3Z3ddl4Z4ddl5Z5ddl6Z6ddl7Z7ddl8Z8ddl9Z9ddl:Z:ddl;Z;ddl<Z<ddl=Z=ddl>Z>ddl?Z?ddl@Z@ddlAZAddlBZBddlCZCddlDZDddlEZEddlFZFddlGZGddlHZHddlIZIddlJmKZKddlLZLddlMZMddlNZNddlOZOddlPZPddlQZQddlRZRddlSZSddlTZTddlUZUddlVZVddlWZWddlXZXddlYZYddlZZZddl[Z[ddl\Z\ddl]Z]ddl^Z^ddl_Z_ddl`Z`ddlaZaddlbZbd„Zcd„Zdd„Zed„Zfd„Zgd„Zhd    „Zid
„Zjd „Zkd d „Zld„Zmd„Zndd„Zpeqd d„Zrd„Zsd„Ztd„Zud„Zvd„Zwd„Zxd„Zyd„Zzd„Z{d„Z|d„Z}d„Z~d„Zd„Z€d „Zd!„Z‚d"„Zƒd#„Z„d$„Z…d%„Z†d&„Z‡d'„Zˆd(„Z‰d)„ZŠd*„Z‹gd+„ZŒd,„Zd-„ZŽd.„Zd/„Zd0„Z‘eqd1„Z’d2„Z“d3„Z”d4„Z•d5„Z–d6„Z—d7„Z˜d8„Z™d9„Zšd:„Z›d;„Zœd<„Zd=d>„Zžd?„ZŸd@„Z dA„Z¡dB„Z¢dC„Z£dD„Z¤dE„Z¥dF„Z¦dG„Z§dH„Z¨dI„Z©dJ„ZªdK„Z«dL„Z¬dM„Z­dN„Z®dO„Z¯dP„Z°dQ„Z±dR„Z²dS„Z³deqdT„Z´dU„Zµd eqdV„Z¶dW„Z·d eqdX„Z¸dY„Z¹dZ„Zºd[„Z»d\„Z¼d]„Z½dd d^„Z¾dd=eqd d_„Z¿d`„ZÀda„ZÁdb„ZÂdc„ZÃdd„ZÄde„ZÅdf„ZÆdg„ZÇdh„ZÈddi„ZÉdj„ZÊdk„ZËdl„ZÌdm„ZÍdn„ZÎd=do„ZÏdp„ZÐdq„ZÑdr„ZÒds„ZÓdt„ZÔdu„ZÕdv„ZÖddw„Z×dx„ZØdy„ZÙdzZÚd{ZÛd|„ZÜd}„ZÝd d~„ZÞd„Zßd€„Zàd„Zád d d‚„ZâdS(ƒiÿÿÿÿN(tRecvPackToMapDBcCsdS(N((ttick((sgD:\SG_ServerCode\ServerPython\ZoneServerGroup\map1_8G\MapServer\MapServerData\Script\Player\ChPlayer.pyt
InitPlayeryscCs6tj|ƒ|jƒdkr2|jtjƒndS(Ni(t PlayerOnlinet OnPlayerLogintGetTickTypeCounttSetTickTypeCounttChConfigtTYPE_Player_Tick_Count(t    curPlayerR((sgD:\SG_ServerCode\ServerPython\ZoneServerGroup\map1_8G\MapServer\MapServerData\Script\Player\ChPlayer.pytInitLoginPlayer‚s cCstj||ƒrdSdS(N(tFBLogictPlayerLoginInFBCheck(R    R((sgD:\SG_ServerCode\ServerPython\ZoneServerGroup\map1_8G\MapServer\MapServerData\Script\Player\ChPlayer.pytOnAllServerInitOKŽscCsÊ|jtjdƒtjƒj|jƒƒt|ƒt|ƒ|j    ƒt
|ƒt j ƒrp|j tƒntj|ƒt||ƒt j ƒr¼|j tƒtj||jƒƒn|jƒdS(Ni(tSetDictRtDef_PlayerKey_LoadMapIsLogint CrossPlayertGetCrossPlayerMgrt RegistPlayert GetPlayerIDtSync_PyServerDataTimeToClienttSync_OpenServerDaytSync_ClientPlayerLogintSyncSettingDatat    GameWorldt IsCrossServertSetForbiddenSyncClientStatetTruetPlayerEventCountertUpdatePlayerLoginTimet__DoPlayerLoginServertFalset PlayerControlt SetCrossMapIDtGetMapIDtBalanceServer_PlayerLoginInitOK(R    R((sgD:\SG_ServerCode\ServerPython\ZoneServerGroup\map1_8G\MapServer\MapServerData\Script\Player\ChPlayer.pyt DoPlayerLogin´s
 
 
 
 
cCsÞ|jtjƒƒt|ƒtjƒrTt||ƒtj|ƒtj    |ƒdSt
j |ƒ}|t j dkrÝt
j|t jdƒt
j|t jdƒt
j|t jdƒt
j|ƒrÝt
j|dƒqÝnt|ƒtj|ƒt|ƒtj|ƒt||ƒt
j|ƒt
j|ƒtj|ƒtj    |ƒtj|ƒt|ƒt j|ƒt!j|ƒt"j#|ƒt$j%|ƒt&j'|ƒt(j)|ƒt*j+|ƒt,j|ƒt-j.|ƒt
j/|ƒt
j0|ƒt1j|ƒt2j|ƒt3j4|ƒt5j6|ƒt7j|ƒt8j|ƒt9j|ƒt:|ƒt"j;|ƒt<|ƒt=j|ƒt>|ƒt?j|ƒ|j@t jAƒ}|rÀtB|t jC|ƒn|j@t jDƒ}|rîtB|t jE|ƒn|j@t jFƒ}|rtB|t jG|ƒn|j@t jHƒ}|rJtB|t jI|ƒn|j@t jJƒ}|rxtB|t jK|ƒn|j@t jLƒ}|r¦tB|t jM|ƒn|jNdƒ|jOdƒt
j|ƒtj|ƒdS(s2 Íæ¼ÒµÇ¼ÐèÒª´¦ÀíµÄÄÚÈÝ£¬±¾·þ¼°¿ç·þ·þÎñÆ÷·Ö¿ª
    Nièi(Pt SetLoginTimeRtGetCurrentDataTimeStrtInitPlayerPackRtDoPlayerLoginInMaptDataRecordPacktDR_PlayerLogint EventReporttWriteEvent_loginR tGetPlayerLeaveServerSecondRtDef_PlayerOfflineProtectTimetNomalDictSetPropertyt Def_Player_Dict_PlayChangeLineIDt Def_Player_Dict_FuncChangeLineIDt Def_Player_Dict_HighChangeLineIDt GetCrossMapIDR!t__FirstLoginOnEntert
TurnAttackRtSyncGuideStatet ItemControlertSyncOnLineTimeTotaltSyncTrainRealmLVtPlayerPrestigeSystOnLogintPlayerBillboardtBillboardOnLogint__SyncPlayerInfoExt
PlayerCointPlayerGoldGiftt GameFuncCommtSync_FuncOpenStatet PlayerSignDaytSignDayOnLogint PlayerHorsetPlayerHorseLogintPlayerTreasuretOnTreasureLogintFBCommont    FBOnLogintPlayerGoldInvestt PlayerSuccesst SuccOnLogintNotifyPlayerAllCurrencytNotifyUseMoneyTotaltPlayerActBuyOnetPlayerActCollectWordstChItemtSync_ItemDayUseCnttFunctionNPCCommontShopItemOnLogintPlayerActBuyCountGifttPlayerActManyDayRechargetPlayerActSingleRechargetSyncPackDownloadAwardtDoFuncOpenLogictSyncLittleHelpertPlayerFBtSync_CreateRoleAwardInfotPlayerCustomAwardtNomalDictGetPropertytDef_PDict_GameNoticeAwardStatetSync_RewardGetRecordInfotDef_RewardType_GameNoticetDef_PDict_ShareGameAwardStatetDef_RewardType_ShareGametDef_PDict_GoodGameAwardStatetDef_RewardType_GoodGametDef_PDict_LikeGameAwardStatetDef_RewardType_LikeGametDef_PDict_OpenSererDailyAwardt#Def_RewardType_OpenServerDailyAwardtDef_PDict_RechargeDayAwardtDef_RewardType_RechargeDayAwardtSetStatetSetCountryLastWeekHornor(R    RtleaveServerSecondtgameNoticeAwardStatetshareGameAwardStatetgoodGameAwardStatetlikeGameAwardStatet
awardState((sgD:\SG_ServerCode\ServerPython\ZoneServerGroup\map1_8G\MapServer\MapServerData\Script\Player\ChPlayer.pyRÔs
 
 
 
 
 
 
     cCsHtjd|jƒƒtjƒr%n½tjƒj|ƒtj|ƒtj|ƒt    j||ƒt
j|ƒt j|ƒt j|ƒt j|ƒtj|ƒtj|ƒtj|ƒtj|ƒtj|ƒt|ƒtj|ƒtj|ƒtj|ƒtj|ƒtj|ƒtj|ƒtj|ƒtj|ƒtj|ƒtj|ƒtj|ƒtj|ƒt j|ƒt!j|ƒt"j|ƒt#j|ƒt$j|ƒt%j|ƒt&|ƒt'|dƒ|j(t)j*ƒ}t+|gƒ}tj,ƒj-|j.ƒddd|t/|ƒƒ|j0t)j1dƒdS(s     Íæ¼Ò×îÖյǼ³É¹¦´¦Àí£¬ ÓÉ  GameServerRefresh GameSever_PlayerInitOK  µ÷ÓÃ
        ¸Ãº¯ÊýΪµØÍ¼×îÖյǼ³É¹¦²Å»áÖ´Ðе½£¬ÒÔºóһЩ¹¦ÄÜÀàµÄµÇ¼´¦Àí½¨Òé¾ùдµ½ÕâÀï
        ¾ÉµÄ¹¦ÄÜÏȲ»¶¯( __DoPlayerLoginServer º¯ÊýÖеŦÄÜ)£¬Èç¹ûÓеǼÏà¹ØµÄbugÔÙ¿¼ÂÇÊÇ·ñÒÆ¶¯µ½´Ëº¯Êý
    sMapServer->DoPlayerRealLoginOKiitPlayerRealLoginOKiN(2RtLogRRt PyMongoMaint GetUserCtrlDBRRt GMT_BroadCastt PlayerFamilyt
PlayerHerot
PlayerMailt    PlayerHJGt PlayerGubaotPlayerZhanlingt
PlayerTaskt
PlayerTreetPlayerGoldRusht
PlayerTalkt SyncADCntInfotUpdatePlayerNametPlayerActivityt
PlayerLLMJt PlayerBeautyt PlayerTravelt PlayerMinggetOpenServerActivityt PlayerPresettPlayerActLunhuidiantPlayerActHeroAppeartPlayerActTotalRechargetPlayerActTotDayRechargetPlayerActSpecialSalet PlayerActSignt PlayerActTasktPlayerActFamilyGCZtPlayerActLianqit PlayerBeastt__OnFixVersiontSyncOnlineStateToCrosst GetDictByKeyRt!Def_PlayerKey_MixServerFirstLogintstrtGetPlayerManagertGameServer_QueryPlayerResulttGetIDtlenRR(R    RtisMixServerFirstLogintmsg((sgD:\SG_ServerCode\ServerPython\ZoneServerGroup\map1_8G\MapServer\MapServerData\Script\Player\ChPlayer.pytDoPlayerRealLoginOKxsT            
 
 .cCs |jƒ}d}|jtjƒ}|s…|jƒ}|jdƒd}tjd|jddƒƒ}tj    d||f|ƒn||kr©tj    d||ƒd    Stj
d
||f|ƒd }||krt j ƒrtj
d ƒt j|ƒqnd }||krvtj||tjtjtjgƒtj||tjtjtjgƒtj|tj|ƒnd}||kr®tj|ƒtj|tj|ƒnd}||krótj|tj|ƒtj|ƒtj|ƒntj|tj|ƒd    S(sº ÐÞÕýÏßÉÏÍæ¼ÒÊý¾ÝÄÚÈÝ
    Ã¿´ÎÓÐÐèÒªÐÞÕýʱ£¬Ö»Òª¶¨ÒåÒ»¸öеÄϵͳÄÚÈݰ汾ºÅ  sysFixVersion , È»ºóÍæ¼Ò¸ù¾Ý×ÔÉí°æ±¾ºÅ½øÐÐÖð²½ÐÞÕý¼´¿É
    ÕâÑùÖ»Óõ½Ò»¸ökey¼´¿É£¬²»ÐèҪÿ´Î¶¼¶¨ÒåеÄkey
    iXóÂxs is%s00s-tsĬÈÏÊý¾Ý°æ±¾Îª´´½ÇÈÕÆÚ: %s, %ss0Íæ¼Òµ±Ç°Êý¾Ý°æ±¾ºÅÒÑÊÇ×îа汾! playerVersion=%sNsDÍæ¼Òµ±Ç°Êý¾Ý°æ±¾ºÅ²»µÈÓÚϵͳ°æ±¾ºÅ£¬¿ªÊ¼ÐÞÕý! playerVersion=%s != %si´¡Âxs¿ç·þ¹«»áÍæ¼ÒµÇ¼²¹¹ýÌìiìëÂxiñÂx(RR_RtDef_Player_Dict_FixVersiontGetCreateRoleTimetsplitRtToIntDeftreplacetDebugLogRvtDBFamilyt IsFamilyCrossRzt__doPlayerOnDaytChEquipt FixRoleEquipt
AttrID_Atkt
AttrID_Deft AttrID_MaxHPRŠt FixRoleMinggeR R/RtFixZhanlingStateKeyRtFixOSATotalRechargeRtFixOSATotDayRecharge(R    tplayerIDt sysFixVersiont playerVersiontcreateRoleTimetymdt
fixVersion((sgD:\SG_ServerCode\ServerPython\ZoneServerGroup\map1_8G\MapServer\MapServerData\Script\Player\ChPlayer.pyR—¹sB   
    %%    cCsqi}g}tj|ƒ}tjƒrqtjƒjƒ}|dkrq||d<||krn|j|ƒqnqqntj    ƒ}|dkr¨||kr¨|j|ƒq¨nt
j ƒ}|dkrß||krß|j|ƒqßnt j |ƒ}|dkr#||d<||kr#|j|ƒq#ntjtj|ƒd}|dkrg||krg|j|ƒqgn||fS(NitcrossFamilyServerIDtgczCrossServerID(RtGetPlayerServerIDRªR«t    DBDataMgrt GetFamilyMgrtGetCurCrossServerIDtappendtGameLogic_QunyingtGetQunyingCrossServerIDtGameLogic_ArenatGetArenaCrossServerIDR”tGetGCZCrossServerIDtCrossMgrtGetCrossActServerZoneInfot ShareDefinetActionName_Lianqi(R    tdataExt serverIDListtplayerServerIDR¼t crossServerID((sgD:\SG_ServerCode\ServerPython\ZoneServerGroup\map1_8G\MapServer\MapServerData\Script\Player\ChPlayer.pytGetSyncCrossServerIDAndFuncInfoøs6  
 
   cCst|ƒdS(N(tSyncOnlinePlayerToCross(t connServerID((sgD:\SG_ServerCode\ServerPython\ZoneServerGroup\map1_8G\MapServer\MapServerData\Script\Player\ChPlayer.pytOnMainServer_Conn_CrossServer!s
icCsç|jƒ}tjƒ}|j|ƒ}|s1dStj|ƒ|tjkr]tj    |ƒn|tj
kr…|j ƒdkr…dSnt |ƒd}|sŸdS|jƒ}t j||ƒ}i|d6}tjtj|||ƒdS(sˆÍæ¼Ò»ù´¡ÐÅÏ¢±ä¸üͬ²½¸üÐÂÆäËû¹¦ÄÜ£¬¿ÉÒÔÊÓΪͬ²½µ½ÒÔǰµÄGameServer
    ³ýÁËÏà¹Ø»ù´¡Öµ±ä»¯Í¬²½Í⣬ÉÏÏÂÏß״̬±ä¸üÒ²»á¸½´ø»ù´¡ÐÅÏ¢µÄͬ²½
    NiitbaseInfo(RRRtFindCrossPlayerRztRefreshFamilyMembertIPY_PlayerDefinetCDBPlayerRefresh_PlayerNameR<tUpdatePlayerBillboardNametCDBPlayerRefresh_LVtGetLVRÐtPlayerViewCachetGetPlayerBaseViewInfotCrossMsgtSendToCrossServerRÊtS2C_PlayerBaseInfo(R    t refreshTypeR¶tcrossPlayerMgrt crossPlayerRÍRÔtdataMsg((sgD:\SG_ServerCode\ServerPython\ZoneServerGroup\map1_8G\MapServer\MapServerData\Script\Player\ChPlayer.pytOnPlayerBaseInfoChange&s&     cCs't}|d}t||||ƒdS(NRÔ(RtUpdCrossPlayerFromMainServer(Rät fromServerIDR¶tisOnlineRÔ((sgD:\SG_ServerCode\ServerPython\ZoneServerGroup\map1_8G\MapServer\MapServerData\Script\Player\ChPlayer.pyRàWs
cCs¥t}tjƒ}|j|ƒ}|s?t}|j|ƒ}ntj||| ƒ}|j||ƒt    j
|ƒ|s›t}tj |ƒ|j |ƒn||fS(N( RRRRÕRRRÜtUpdPlayerBaseViewInfotUpdByViewCacheRzRÖtOnCrossPlayerLogoutt DeletePlayer(RçR¶RÔRètisNewRâRãtcurCache((sgD:\SG_ServerCode\ServerPython\ZoneServerGroup\map1_8G\MapServer\MapServerData\Script\Player\ChPlayer.pyRæ]s   cCs‘|dkrdS|r-t|dt|ƒdStjƒ}xQt|jƒƒD]=}|j|ƒ}tj|ƒsvqLnt|dt|ƒqLWdS(Nii(R˜RRRœtxranget OnlineCounttOnlineAttIsNormalPlayer(ttoCrossServerIDR    t playerManagerti((sgD:\SG_ServerCode\ServerPython\ZoneServerGroup\map1_8G\MapServer\MapServerData\Script\Player\ChPlayer.pyRÑvs  c
CsÀ|jƒ}tjƒ}|s.|j|ƒnt|ƒ\}}|sJdS|rl||kr`dS|g}ntj|ƒ}i|d6|d6|d6}    |    j|ƒtj    t
j |    ||ƒdS(NRèt
isLoginoutRÔ( RRRRìRÐRÜRÝtupdateRÞRßRÊtS2C_OnlineState(
R    RèRöRóR¶RâRÍRÌRÔRä((sgD:\SG_ServerCode\ServerPython\ZoneServerGroup\map1_8G\MapServer\MapServerData\Script\Player\ChPlayer.pyR˜…s      c
Cs0|d}|d}|d}t||||ƒ\}}|sE|oH|}|oU| }    tjd|||||    f|ƒtjƒjƒ}
d|krá|d} |
| krá|rÅtj|ƒqÞ|    rÞtj|ƒqÞqánd|kr,|d} |
| kr,|rtj|ƒntj    |ƒq,ndS(sbÊÕµ½ÓÎÏ··þÍæ¼ÒÔÚÏß״̬ͬ²½
    ¿ç·þÊÕµ½ÔÚÏß״̬ͬ²½Ê±¶¼ÊÓΪÔÚ¿ç·þÉÏÏߣ¬ÐèÒª´¦Àí¿ç·þÔÚÏß/ÉÏÏßµÄÂß¼­
    ²»È»ÔÚ¿ç·þά»¤ÓÎÏ··þ²»Î¬»¤µÄÇé¿öÏ£¬µÈ¿ç·þÖØ¿ªºó£¬ÓÎÏ··þÖØÐÂͬ²½ÔÚÏßÍæ¼Ò£¬´ËʱÈç¹û¿ç·þ²»´¦ÀíµÇ¼Âß¼­£¬»áÉÙͬ²½·â°ü
    È繫»á£¬¿ç·þά»¤Ö®ºóµÇ¼µÄÍæ¼Ò»áÈ¡²»µ½¹«»áÊý¾Ý£¬µÈ¿ç·þÖØ¿ªºó£¬ÐèÊÓΪµÇÂ¼ÖØÐÂͬ²½
    Óë¿ç·þÖØÁ¬Ò»ÑùµÄµÀÀí£¬¶¼ÊÇÖØÐÂͬ²½ËùÓÐÐÅÏ¢
    RèRöRÔsWÓÎÏ··þÔÚÏß״̬ͬ²½: isOnline=%s,isLoginout=%s,isNew=%s,isCrossLogin=%s,isCrossLogout=%sR¼R½N(
RæRR©t GetGameWorldt GetServerIDRztOnCrossPlayerLoginRëR”tOnCrossJoinFamilyMemberUpd( RäRçR¶RèRöRÔRãRít isCrossLogint isCrossLogoutt curServerIDR¼R½((sgD:\SG_ServerCode\ServerPython\ZoneServerGroup\map1_8G\MapServer\MapServerData\Script\Player\ChPlayer.pyRø¡s.
 
 
      
 
 
cCsHtjƒ}|jƒ|jƒ|_|jƒ|_tj||ƒdS(N(tChPyNetSendPackttagMCPlayerInfotCleartIsAdultR¥tCreateRoleTimet NetPackCommont SendFakePack(R    t playerInfoEx((sgD:\SG_ServerCode\ServerPython\ZoneServerGroup\map1_8G\MapServer\MapServerData\Script\Player\ChPlayer.pyR>Ós  
cCs…|jƒ}|jtjƒr"dStjd|ƒtj|dƒ|jdƒt    j
|t    j |ƒƒ|j ƒdkrŠt j|ƒntj|jƒ|jƒ|ƒtjddƒ}x'|D]\}}tj|||ƒqÂWtj|jƒƒ}tjddiƒ}|j|iƒ}x-|jƒD]\}}tj|||ƒq.Wtj|ƒtj|ƒtj|tjdƒdS(NsÍæ¼ÒÊǵÚÒ»´Î½øÈëÓÎÏ·iit MailLVAwardii( RžR_RtDef_Player_Dict_FirstLoginRRvR+tWriteEvent_Entryt SetFightPointtGameObjtSetHPtGetMaxHPRÛRARZR)t DR_FirstLogintGetAccIDtGetIPt IpyGameDataPYtGetFuncEvalCfgR|t SendMailByKeytGetAppIDByAccIDtgettitemsR{tOnPlayerFirstLoginR‚tInitGoldEnergyR R/(R    R¶tmailListt mailTypeKeyt mailItemListtappIDt appIDMailDicttmailDict((sgD:\SG_ServerCode\ServerPython\ZoneServerGroup\map1_8G\MapServer\MapServerData\Script\Player\ChPlayer.pyR4Üs,     c
Csštjƒjtjƒ}|s"dS|jƒ}tjƒjtjƒ}|jtj    ƒ}||kr|tj
d||ƒdStjƒjtj ƒ}tj d||f|ƒt j|tj    |ƒ|jƒdkrêtj d|ƒdS|jtjdƒtj|ƒtj|dƒtjddƒ}tjddƒ}tjddƒ}tjdd    ƒ}    td
||    ƒ}
|\} } g} x¥|D]\}}}tjƒj|ƒ}|s¾qŽn|jd ƒ}|jƒ}|tjkrîqŽn|jdƒ}|s    qŽn||
kr*|||gg} qŽPqŽWi|d 6|d 6|
d6}|| }tj d|
|f|ƒt j d|g|d| d| d|ƒdS(Ns'±¾´ÎºÏ·þÒѾ­µÇ¼¹ý. lastMixServerDay=%ss9Íæ¼ÒºÏ·þÊ׵Ǵ¦Àí! lastMixServerDay=%s,mixServerWorldLV=%sis    ÐºŲ»¸øºÏ·þ½±Àø!t    MixServert MixServerMailiiii–itMixServerWorldLVtLastMixServerDayt ItemWorldLVs3    ·¢ËͺϷþ²¹³¥Óʼþ: itemWorldLV=%s,addItemList=%st
MixServer1tgoldtsilvertdetail(!RRùtGetGameWorldDictByKeyRÊtDef_Notify_WorldKey_IsMixServerRt$Def_Notify_WorldKey_LastMixServerDayR_RtDef_PDict_MixLoginDayR©t(Def_Notify_WorldKey_LastMixServerWorldLVRvR R/RÛRRšRCt ResetDaySignR?tDoResetCTGCountRRt
GetFuncCfgtmaxt GetGameDatatGetItemByTypeIDtGetEffectByIndext GetEffectIDtDef_Effect_ItemAddLVtGetEffectValueR(R    t isMixServerR¶tlastMixServerDayt    playerDaytmixServerWorldLVRtworldLVMailItemListt mailMoneyListt worldLVDownt itemWorldLVR&R'tworldLVItemListtitemIDt    itemCounttisBindtitemDatatcurEfftcurEffIDtlvLimitt
detailDictt addItemList((sgD:\SG_ServerCode\ServerPython\ZoneServerGroup\map1_8G\MapServer\MapServerData\Script\Player\ChPlayer.pyt__DoMixServerFirstLoginsX      
(cCs0tj|tjdƒtj|tjdƒdS(Ni(R R/RtDef_Player_Dict_PlayerDeadCnttDef_Player_Dict_DeadTime(R    ((sgD:\SG_ServerCode\ServerPython\ZoneServerGroup\map1_8G\MapServer\MapServerData\Script\Player\ChPlayer.pytClearPlayerDeadInfoQscCsg|jƒ}x*tjD]}|j|ƒ}|jƒqWx'tjjƒD]}tj||ƒqIWdS(N(    tGetItemManagerRt Def_PlayerLoginInitPackIndexListtGetPackt Sync_RefreshtDef_VPackCnt_DicttkeysR7tSync_VPackItem_Refresh(R    t itemManagert    packIndextrolePack((sgD:\SG_ServerCode\ServerPython\ZoneServerGroup\map1_8G\MapServer\MapServerData\Script\Player\ChPlayer.pyt__Sync_PackDetel\s cCsÆtjƒ}|jƒg|_|jƒ}xrt|jƒƒD]^}|j|ƒ}tjƒ}|j    ƒ|_
|j ƒ|_ |j ƒ|_|jj|ƒq>Wt|jƒ|_tj||ƒdS(N(RttagMCPlayerSkillsRtSkillstGetSkillManagertranget GetSkillCounttGetSkillByIndexttagPlayerSkillt
GetSkillIDtSkillIDt GetRemainTimet
RemainTimetGetProficiencyt ProficiencyRÂRŸtCountRR(R    tsendPackt skillManagerRõtcurSkillt    skillInfo((sgD:\SG_ServerCode\ServerPython\ZoneServerGroup\map1_8G\MapServer\MapServerData\Script\Player\ChPlayer.pyt__Sync_ClientSkillˆs 
      cCsnt|ƒ|jƒjƒ|jƒjƒ|jƒjƒ|jƒjƒ|jƒjƒ|jƒjƒdS(N(t__SyncClearBufft GetBuffStatet    Sync_BufftGetDeBuffStatetGetAurat
GetIncBufftGetProcessBuffStatetGetProcessDeBuffState(R    ((sgD:\SG_ServerCode\ServerPython\ZoneServerGroup\map1_8G\MapServer\MapServerData\Script\Player\ChPlayer.pyt__Sync_ClientBuff s
cCsQtjƒ}|jƒ|jƒ|_|jƒ|_d|_tj    ||ƒdS(Nic(
t ChNetSendPackttagClearObjBuffRtGetGameObjTypetObjTypeRžtObjIDtBuffTypeRR(R    t
clientPack((sgD:\SG_ServerCode\ServerPython\ZoneServerGroup\map1_8G\MapServer\MapServerData\Script\Player\ChPlayer.pyRlªs 
    cCs­|jtƒ|jtƒ|jtƒ|jtƒ|jtƒtj|dƒtj|tƒt    ||ƒt
j ƒj ƒt jkr¢tj|tj|ƒn|jƒ|jƒkrÓtj||jƒƒn|jƒdkrøtj|dƒntj||ƒt
jƒr$|jtƒntj|ƒ}|jƒt
jƒrY|jt ƒn|j!|ƒ|j"|ƒ|j#tj$|ƒtj%||ƒt&|ƒt t'_(dS(Ni'i()t
SetCanMoveRt    SetInitOKt SetMapLoadOKt
SetVisiblet SetCanAttackR tSetMaxHPt    SetHPFullt__CheckClearBuffOnMapChangeRtGetMapt GetMapFBTypet IPY_GameWorldtfbtNullt SkillCommontAddBuffBySkillType_NoRefurbishRtDef_SkillID_LimitSuperBufft GetSightLevelRžR tSetPlayerSightLeveltGetSighttSetSightt PlayerStatetChangePlayerSighRRRtGetOnlinePlayert ReCalcAllAttrRtSetProcessEquipDurgTickt SetLoginTickRtDef_PlayerKey_CalcOLTimeTicktRefreshRebornPointtSavePlayerMessionInDataServert
PyGameDatatg_needRefreshMapServerState(R    RtolPlayer((sgD:\SG_ServerCode\ServerPython\ZoneServerGroup\map1_8G\MapServer\MapServerData\Script\Player\ChPlayer.pyR(¹s8       
 
    cCs»tjƒjƒ}tjdƒ}g}xf|jƒD]X\}}| sS||kr4tj|||ƒrŒtjd|ƒ|j    |ƒqŒq4q4Wx$t
j D]}tj|||ƒqšWdS(NtFBBuffsÇеØÍ¼É¾³ý¶àÓàbuff: %s( RR„R"t ReadChConfigtGetEvalChConfigRt    BuffSkilltDelBuffBySkillIDR©RÂRtClearBuffOnMapChangeList(R    RtcurMapIDt
fbBuffDictt
buffIDListtbuffIDt    mapIDList((sgD:\SG_ServerCode\ServerPython\ZoneServerGroup\map1_8G\MapServer\MapServerData\Script\Player\ChPlayer.pyRƒõscCsdS(N((R    ((sgD:\SG_ServerCode\ServerPython\ZoneServerGroup\map1_8G\MapServer\MapServerData\Script\Player\ChPlayer.pyR— scCstjtƒ||ƒdS(N(Rt GetPsycoFunct__Func_PlayerLogin(tindexR((sgD:\SG_ServerCode\ServerPython\ZoneServerGroup\map1_8G\MapServer\MapServerData\Script\Player\ChPlayer.pyt PlayerLoginscCs²tjƒj|ƒ}y\t||ƒt||ƒ|jtƒ|jƒt||ƒt    ||ƒt
||ƒWn:|j t j ƒddl}tjd|jƒƒnXdS(NiÿÿÿÿsÍæ¼ÒÉÏÏßÂß¼­´íÎó
%s(RRœtGetPlayerByIndexR
R$R|RtSendToBServerServerInitOKR t__Func_LoadMapOKR¢tKickR†tdisWaitForPlayerLoinErrort    tracebacktRaiseExceptiont
format_exc(R¨RR    R¯((sgD:\SG_ServerCode\ServerPython\ZoneServerGroup\map1_8G\MapServer\MapServerData\Script\Player\ChPlayer.pyR§#s   
   cCstjtƒ||ƒdS(N(RR¦t__Func_ChangeMapInit(R¨R((sgD:\SG_ServerCode\ServerPython\ZoneServerGroup\map1_8G\MapServer\MapServerData\Script\Player\ChPlayer.pyt ChangeMapInitCscCs¦tjƒj|ƒ}t||ƒtj||ƒt|ƒt||ƒ|jƒtj    ƒj
ƒt j kr~|j dƒn |j dƒ|jƒ|jtƒdS(Nii(RRœRªR
RˆtPlayerChangeMapUpdateSkillCDR'R(tInitChangeMapPlayerSummonInfoR„R…R†tfbtTeamtGameServer_TeamEnterFBt#BalanceServer_PlayerChangeMapInitOKR|R(R¨RR    ((sgD:\SG_ServerCode\ServerPython\ZoneServerGroup\map1_8G\MapServer\MapServerData\Script\Player\ChPlayer.pyR²Ms
 
     
 
cCs(tj|tjdtdtƒtj|tjƒtj|tjdtƒtj|tj    ƒtj|tj
ƒtj|tj dtdtƒtj|tj dtdtƒtj|tj dtdtƒtj|tjdtdtƒtj|tjƒtj|ƒt|ƒtj|ƒdS(Nt
defaultMaxtisSync(R tInit_PackCountR†trptEquipRRtrptItemt rptIdentifyRÊtrptHerotrptBeastt
rptMGGuayut rptMGTuiyant rptTempSwapt rptTempItemt rptTreasuret
ItemCommontSyncPackBuyCntRXR7tCheckGiveBindMoneyTypeItem(R    ((sgD:\SG_ServerCode\ServerPython\ZoneServerGroup\map1_8G\MapServer\MapServerData\Script\Player\ChPlayer.pyR'Œs 
 cCstj}t||ƒS(N(RRŠtCheckHasBuffBySkillID(R    tskillID((sgD:\SG_ServerCode\ServerPython\ZoneServerGroup\map1_8G\MapServer\MapServerData\Script\Player\ChPlayer.pyt__CheckLimitSuperBuffÍs    cCstjƒj|ƒ}|s9tjd||jƒƒtStj|ƒ}tj||ƒ}|dkrjtS|d}|j    ƒ}|j
|ƒ}|s™tSt S(Ns,Íæ¼ÒÈ¡Ïûbuffʧ°Ü,Êý¾Ý¿âÎÞ´Ëbuff,buffid = %s i(( RR2tGetSkillBySkillIDRvRRRˆt GetBuffTypetGetBuffManagerByBuffTypetGetSkillTypeIDtFindBuffR(R    RÊt    buffSkilltbuffTypet    buffTuplet    buffStatetbuffSkillTypeIDtcurBuff((sgD:\SG_ServerCode\ServerPython\ZoneServerGroup\map1_8G\MapServer\MapServerData\Script\Player\ChPlayer.pyRÉ×s 
 cCs²tjƒj|ƒ}|jƒrÎ|jtjƒ}|jtjƒ}|rÊ|rÊtjd|j    ƒƒ|j
tjdƒ|j
tjdƒ|j t ƒt j|tjƒ|jƒtj||ƒndSt|ƒsÞdStjd|j    ƒƒ|jt ƒ|j|jƒ|jƒƒ|jƒ|jƒkrNt j||jƒƒn|jƒdkrst j|dƒn|jƒ|j t ƒtj|ƒdkr²|jtj ƒn|j!t ƒ|j"t ƒt j#|t ƒt$j%||ƒtj&||ƒtj'ƒ}|jƒ}|jƒ}|j(tj)ƒr§|j(tj)ƒdkr`t j |ƒj*ƒn.t+j,||tj-ƒ\}}|j.||ƒt j/|tj)dƒntj|ƒdksÑ|j0ƒtj kr&|jtj1ƒ}|ròtj2ntj3}    tj4ƒrtj3}    nt5||    |ƒn½|j6||ƒt krãt+j,||tj-ƒ\}
} |
dkr°| dkr°tjd||f|j    ƒƒt j |ƒ} | j*ƒqã|j.|
| ƒtjd|
| f|j    ƒƒn|j7ƒtj8kr[t9j:tj'ƒj;ƒƒtj<kr[|j=tj8ƒt>j?|tj@|ƒt>j?|tjA|ƒn|jBƒ} |jCƒ| kr¤|jD| ƒtE|ƒtjFd| ƒn|jGƒt S(Ns'Íæ¼Ò¸±±¾Öбä¸ü¹¦ÄÜÏß·ÐéÄâÇеØÍ¼³É¹¦!!!is µØÍ¼¶ÁÈ¡³É¹¦is:Íæ¼ÒµÇÂ¼ÖØÖÃλÖÃʧ°Ü, °ÑÍæ¼Ò´ò»ØÖØÉúµã posX = %s posY = %ss<Íæ¼ÒµÇÂ¼ÖØÖÃλÖÃʧ°Ü, ÉèÖø½½üµã nearPosX = %s nearPosY = %ss½øÈëµØÍ¼Ç¿ÖÆÇл»PKģʽ: %s(HRRœRªt GetMapLoadOKR™RtDef_PlayerKey_ResetFBLinePosXtDef_PlayerKey_ResetFBLinePosYRvRRRRR RŽtDef_PlayerSight_Defaultt RefreshViewR t    DoEnterFBt__CheckForbidLoginR~tInitPostGetPosXtGetPosYR‹RžRŒRR tGetHPtSetPlayerActionR†tpaDieR}R|tSetIsNeedProcesst PlayerGMOpert DoGMOperLogictDoEnterFBLogicR„R_tDef_PDict_IsReBorntSetToBornPlacetGameMaptGetNearbyPosByDistDef_RebornPos_Area_RangetResetPosR/tGetPlayerActionRtrebornType_CitytrebornType_SystemRtPlayerRebornByTypetCanMovet
GetFactiontCampType_NeutralRItGetRecordMapIDR"tDef_MapID_NeedCampt
SetFactionRžRŸtDef_SkillID_JusticetDef_SkillID_EviltGetInitAttackModelt GetAttackModet SetAttackModet SyncPKModelR©t
EndLoadMap(R¨RR    tresetFBLinePosXtresetFBLinePosYtcurMaptposXtposYtisLogint
rebornTypetnearPosXtnearPosYt playerControltinitAttackModel((sgD:\SG_ServerCode\ServerPython\ZoneServerGroup\map1_8G\MapServer\MapServerData\Script\Player\ChPlayer.pyR¬õs„   
 
      *    #$  
 
cCs9tjƒ}|jƒ|jƒ|_tj||ƒdS(N(RttagMCAttackModeRRûtModeRR(R    Rg((sgD:\SG_ServerCode\ServerPython\ZoneServerGroup\map1_8G\MapServer\MapServerData\Script\Player\ChPlayer.pyRýƒs
 
cCstS(N(R(R    ((sgD:\SG_ServerCode\ServerPython\ZoneServerGroup\map1_8G\MapServer\MapServerData\Script\Player\ChPlayer.pyt__CheckGMCanLoadMapOKscCsP|jƒtdtjƒ@dkr&tStjd|jƒƒ|jt    j
ƒdS(NiisÍæ¼Ò±»·âºÅ½ûÖ¹µÇ¼( t GetAccStatetpowRtDef_PysForbidByPyRRRvRR­R†t    disGMKick(R    ((sgD:\SG_ServerCode\ServerPython\ZoneServerGroup\map1_8G\MapServer\MapServerData\Script\Player\ChPlayer.pyRݨs
"c    Cs„tjƒj|ƒ}|j}|j}| sM| sMt|ƒt|ƒkrQdSd}x>t|ƒD]0\}}tjd|ƒs†dS|||7}qdW|j    ƒ}    ||    krËtj
d|    |fƒdS|j |    |ƒx{t|ƒD]m\}}||}
|j t j|ƒ} | |
} tj|t j|| ƒtj
d|| |
| fƒqéWt||ƒtj|ƒ} | jƒdS(Nit    RolePoints3Ê£ÓàµãÊý²»×ã! curFreePoint(%s) < needTotalPoint(%s)s7Íæ¼Ò¼Óµã: attrID=%s,curPoint=%s,addPoint=%s,updPoint=%s(RRœRªtPointAttrIDListtPointValueListRŸt    enumerateRtGetIpyGameDatat GetFreePointR©t SetFreePointR_RtDef_PDict_AddPointValueR R/tNotifyPlayerBasePointtRefreshPlayerAttrState(R¨t
clientDataRR    tpointAttrIDListtpointValueListtneedTotalPointRõtattrIDt curFreePointtaddPointtcurPointtupdPointR((sgD:\SG_ServerCode\ServerPython\ZoneServerGroup\map1_8G\MapServer\MapServerData\Script\Player\ChPlayer.pyt
OnAddPointºs2        &  
 
! 
cCstjƒj|ƒ}tjƒ}gt|jƒƒD]}|j|ƒjƒ^q4}t    }x4|D],}|j
t j |ƒ}|rbt }PqbqbW|s©tjdƒdS|jƒtjddƒk}    |    stjddƒ}
|jƒjtjƒ} d} d} xÓ|
D]Ë}tj|| dƒ\}}|s7q
nx‹|D]ƒ}| j|ƒ}tj|ƒshq>ntj|ƒ\}}|rº|dkr•q>n| s¨|| krÁ|} |} qÁq>|} Pq>W| dkr
Pq
q
W| dkrédStj|| | gdt    t jƒndS(    NsÖØÖüӵã Ã»ÓеãÊýÐèÒªÖØÖÃt LVUPAddPointiiiÿÿÿÿii
i(RRœRªRtIPY_DataRïtGetRolePointCounttGetRolePointByIndext    GetAttrIDRR_RRRR©RÛR0RRNRPR†R½RÆtGetItem_FromPack_ByIDtGetAttCheckItemCanUsetGetItemRemainingTimet
ReduceItemtItemDel_ResetAttrPoint(R¨RRR    t
ipyDataMgrtcanResetIDListtcanResetRR"tisFreetneedItemIDListtitemPacktdelIndext
expireTimeRAt    hasEnought itemIndexListt    itemIndextcurItemt isExpireItemt remainingTime((sgD:\SG_ServerCode\ServerPython\ZoneServerGroup\map1_8G\MapServer\MapServerData\Script\Player\ChPlayer.pytOnResetAttrPointßsR 4        %c    Cs×|sItjƒ}gt|jƒƒD]}|j|ƒjƒ^q%}ng}g}x>|D]6}|jtj|ƒ}|j    |ƒ|j    |ƒq\Wt
j ƒ}||_ ||_ t|ƒ|_tj||ƒdS(N(RR&RïR'R(R)R_RRRÂRttagMCRolePointInfoRRRŸtPointAttrIDCountRR(    R    tsyncAttrIDListR0R¨RRRR"t    pointInfo((sgD:\SG_ServerCode\ServerPython\ZoneServerGroup\map1_8G\MapServer\MapServerData\Script\Player\ChPlayer.pyRs 7           cCsÙtjƒj|ƒ}t|ƒs%dStjƒj|j|jƒsGdS|jƒ|j    |j|jƒt
j ƒ}|j ƒ|j ƒ|_|jƒ|_|j|_|j|_|j|_tj||tdƒdS(Niÿÿÿÿ(RRœRªt__CheckPlayerCanMoveR„RòtPosXtPosYtStopMovet    ChangePosRttagMCMoveByTypeRRžtIDRwRxtMoveTypeR t PyNotifyAllR(R¨RRR    Rg((sgD:\SG_ServerCode\ServerPython\ZoneServerGroup\map1_8G\MapServer\MapServerData\Script\Player\ChPlayer.pyt OnMoveByType2s  
 
   cCs
tjƒj|ƒ}||jtjƒtjtjkr?dS|jtj|ƒt|ƒsbdStj    ƒj
|j |j ƒs„dS|j ƒ|j|j |j ƒtjƒ}|jƒ|jƒ|_|jƒ|_|j |_ |j |_ tj||tdƒdS(Niÿÿÿÿ(RRœRªt GetTickByTypeRtTYPE_Player_Tick_RushtTYPE_Player_Tick_Timet SetTickByTypeRCR„RòRDRERFRGRt    tagMCRushRRžRIRwRxR RKR(R¨RRR    Rg((sgD:\SG_ServerCode\ServerPython\ZoneServerGroup\map1_8G\MapServer\MapServerData\Script\Player\ChPlayer.pyt OnPlayerRushVs$& 
 
  c     Csªtjƒj|ƒ}tj|tjtjƒs4t    St
|ƒsDdS|j }|j }|j }|j}|j}||kr||krdStjƒj||ƒsÅ|j|jƒ|jƒƒdS||jdƒdkrâdS|jd|ƒ|jƒ}    |    tjtjgkrdStjƒ}
t|||
||||ƒsHdStj||||ƒdkr†|j|jƒ|jƒƒdStj||ƒ|j||ƒdS(Nt FightMoveTicki2i(RRœRªtOperControlManagertIsObjCanDoActionRtDef_Obj_ActState_ServerActR†toalMoveRRCtStartXtStartYtDestXtDestYt    WorldTickR„RòRíRßRàR™RtGetPlayerVehicletpvNulltpvHorset CheckMovePostGetDistR tDelLimitSuperBuffRG( R¨RRR    tsendPack_StartXtsendPack_StartYtsendPack_DestXtsendPack_DestYtsendPack_WorldTicktvehicleR((sgD:\SG_ServerCode\ServerPython\ZoneServerGroup\map1_8G\MapServer\MapServerData\Script\Player\ChPlayer.pytPlayerFightMovesB                            cCso|jƒstS|jƒs tStj|ƒdkr9tStj|tjt    j
ƒsXtSt j |ƒsktSt S(Ni(R×Rt
GetCanMoveR RáRTRURRVR†RWR tPlayerCanStateTransferR(R    ((sgD:\SG_ServerCode\ServerPython\ZoneServerGroup\map1_8G\MapServer\MapServerData\Script\Player\ChPlayer.pyRCÛs   cCsdStjƒ}tj||||ƒs6|jƒdSt|||||||ƒsXdStj|tjƒ|j    ||ƒdS(N(
RR„R tPlayerMoveCheckClientWorldTicktSync_ClientTickR`tChangePlayerActionR†tpaNulltMove(R    t client_StartXt client_StartYt client_DestXt client_DestYtclientWorldTickRR((sgD:\SG_ServerCode\ServerPython\ZoneServerGroup\map1_8G\MapServer\MapServerData\Script\Player\ChPlayer.pytPlayerNormalMoves 
c CsÜtj||||ƒsY|rU|jƒ|jƒkrU|j|jƒ|jƒƒntS|jƒ}|jƒ}    |j||ƒsš|r–|jƒntSt    j
||    ||ƒ}
|
t j krØ|rÔ|jƒntSt S(N(R tPlayerRefreshPosRžRíRßRàRRòtMoveFailRRaRtDef_PlayerMaxMoveDistR( R    tcheckObjRtstartXtstartYtdestXtdestYtsendPlayerMoveFailtobjPosXtobjPosYtmoveDist((sgD:\SG_ServerCode\ServerPython\ZoneServerGroup\map1_8G\MapServer\MapServerData\Script\Player\ChPlayer.pyR`*s     cCsÓtjƒj|ƒ}tjƒ}|jƒ}tjd||jƒƒtjƒrdtjdƒdSt    j
|ƒr„t ||ƒdSt j ||ƒrªt    j|dƒdSt|||ƒrÏt|||ƒndS(NsÍæ¼Òµã»÷¸´»î: rebornType=%ss¿ç·þ·þÎñÆ÷²»½ÓÊܸ´»îÇëÇó!tReborn_lhs_31379(RRœRªR†tIPY_CCliectReborntGetTypeR©RRR R3tOnReqCrossServerRebornR tDoFBForbidRebornt
NotifyCodeRñtPlayerReborn_InFB(R¨RR    RgR((sgD:\SG_ServerCode\ServerPython\ZoneServerGroup\map1_8G\MapServer\MapServerData\Script\Player\ChPlayer.pytPlayerClickReborn`s      cCstj|ƒ}|s&tjdƒdSt||dtƒs?dSi|jƒd6|d6}tjtj    |ƒtjd||f|jƒƒdS(Nsµ±Ç°ÎÞ¿ç·þµØÍ¼!t checkHPStatetPlayerIDt
RebornTypes(¿ç·þÖÐÇëÇó¸´»î, crossMapID=%s,msgDict=%s(
R R3RR©t__CheckCanRebornRRtSendMsgToCrossServerRÊtClientServerMsg_Reborn(R    Rt
crossMapIDtmsgDict((sgD:\SG_ServerCode\ServerPython\ZoneServerGroup\map1_8G\MapServer\MapServerData\Script\Player\ChPlayer.pyR†~s  cCsŒ|d}tjƒ}t|||ƒs,dS|jtjƒ}t|||ƒidd6|d6}|j|ƒtjt    j
||gƒdS(NRitResultt ReviveTired( RR„RŽR_RtDef_PDict_IsAddReviveTiredt__DoPlayerRebornR÷tSendMsgToClientServerRÊtCrossServerMsg_RebornRet(R    tmsgDatat serverGroupIDRRtgameMaptisAddReviveTiredtmsgInfo((sgD:\SG_ServerCode\ServerPython\ZoneServerGroup\map1_8G\MapServer\MapServerData\Script\Player\ChPlayer.pyRŽs
  cCsX|d}|dkrdS|d}|d}t||tƒ|rTt||ƒndS(NR“iRR”(t __RebornCostRt__AddReviveTired(R    R™RtresultRRœ((sgD:\SG_ServerCode\ServerPython\ZoneServerGroup\map1_8G\MapServer\MapServerData\Script\Player\ChPlayer.pyR˜ s
 
 
cCs`tjƒ}|jƒ|jƒ|_||_|jƒ|_|jƒ|_    t
j ||ƒdS(N( RuttagPlayerRebornRRRŒtTypeRßRDRàRERR(R    Rt
rebornInfo((sgD:\SG_ServerCode\ServerPython\ZoneServerGroup\map1_8G\MapServer\MapServerData\Script\Player\ChPlayer.pytSyncPlayerReborn°s 
    cCs&tjƒj|ƒ}t||ƒdS(N(RRœRªtPlayerDisconnectEx(R¨RR    ((sgD:\SG_ServerCode\ServerPython\ZoneServerGroup\map1_8G\MapServer\MapServerData\Script\Player\ChPlayer.pytPlayerDisconnectÀs cCsbyt||ƒWn*ddl}tjd|jƒƒnXtjt|ƒƒ|j|ƒdS(NiÿÿÿÿsÍæ¼ÒÏÂÏßÂß¼­´íÎó
%s(    tDoPlayerDisconnectR¯RR°R±Rt    MapCallDBtGetPackSaveDatat DoDisconnect(R    RR¯((sgD:\SG_ServerCode\ServerPython\ZoneServerGroup\map1_8G\MapServer\MapServerData\Script\Player\ChPlayer.pyR¥Ês cCsOtj|jƒƒ}d}tj|tjƒ}tj|t|ƒ|ƒ}|S(NR£(    tbase64t    b64decodet GetPackDatatCommFunct    WriteBYTEtIPY_ServerDefinet    gstUpdatet WriteStringRŸ(R    t roleSaveDatatallData((sgD:\SG_ServerCode\ServerPython\ZoneServerGroup\map1_8G\MapServer\MapServerData\Script\Player\ChPlayer.pyR©Ös
cCstjd|jƒƒtj||ƒ|jtjƒƒtj|ƒtj    |t
j dƒtj    |t
j dƒt j|ƒt|dƒtj|ƒdS(NsPlayerDisconnect!i(RRvRR tPlayerLeaveServert SetLogoffTimeR&R)tDR_PlayerDisconnectR/Rt!Def_Player_Dict_RouteServerInitOKtDef_PlayerKey_CrossRegisterMapR+tWriteEvent_sessionR˜RtOnPlayerLogoff(R    R((sgD:\SG_ServerCode\ServerPython\ZoneServerGroup\map1_8G\MapServer\MapServerData\Script\Player\ChPlayer.pyR§ãs    cCsƒtjƒj|ƒ}tjƒ}|jƒ}tj|ƒs\d}tjd|jƒƒdSt    |ƒdkrrdS|j
|ƒdS(NR£sSetShutCutData Encoding Errid( RRœRªR†tIPY_CSetShutCutDatat
GetSettingtEncodingToUnicodetErrLogRžRŸt
SetSetting(R¨RR    Rgtsetting((sgD:\SG_ServerCode\ServerPython\ZoneServerGroup\map1_8G\MapServer\MapServerData\Script\Player\ChPlayer.pytSetShutcutSettingHVs   c Cstjƒj|ƒ}|jƒ}|j}|j}|jddƒ}t|ƒ}tj    ƒ}|j
t j |ƒ}    |    j tƒ}
|
s‹dS|
jƒ} |s°| j|dƒnFd} || krìt| ƒ| krìtjd| ƒdSn|| |<t||ƒdS(Ns R£ids´æ´¢¸öÊý´ïµ½ÉÏÏÞ! keyMax=%s(RRœRªRtKeyNumtSetDataR¨R›R¿t GetGameRecMgrtGetRecTypeIDMgrRÊtDef_GameRecType_Settingt GetOneRecDataRt GetUserDicttpoptNoneRŸR¿R( R¨RRR    R¶tkeyNumtsetDatatkeyStrt
gameRecMgrt preSetRecMgrtrecDatatdataDicttkeyMax((sgD:\SG_ServerCode\ServerPython\ZoneServerGroup\map1_8G\MapServer\MapServerData\Script\Player\ChPlayer.pyt OnSettingData-s,             
 R£c CsF|jƒ}tjƒ}|jtj|ƒ}|jƒ}|sCdS|jƒ}g}|rd|gn    |jƒ}xŽ|D]†}||kr–||}    nd}    t    j
|dƒ}
|
dkrÀqwnt j ƒ} |
| _|    | _t| jƒ| _|j| ƒqwW|s dSt jƒ} || _t| jƒ| _tj|| ƒdS(NR£(RR¿RÅRÆRÊRÇRÈRÉRSRR§RËRttagSCSettingDataRÃRÄRŸtDataLenRÂttagSCSettingDataInfotSettingDataListtDataCntRR( R    RÎR¶RÏRÐRÑRÒtsettingDataListt syncKeyListRÍRÌtsDataR{((sgD:\SG_ServerCode\ServerPython\ZoneServerGroup\map1_8G\MapServer\MapServerData\Script\Player\ChPlayer.pyRJs8                      cCsÿtjƒj|ƒ}|j}|tjkrKtjd||jƒƒdSx­tdtj    dƒD]•}t
|d|ƒs¡tjd||f|jƒƒqbnt |d|ƒ}t j |tj||f|ƒtjd|||f|jƒƒqbWdS(Ns!СÖúÊÖ²»Ö§³Ö¸ÃÉèÖñàºÅ! setNum=%sisValue%ss+СÖúÊÖ²»Ö§³Ö¸ÃÖµ±àºÅÉèÖÃ! setNum=%s,value%ss"СÖúÊÖÖµÉèÖÃ: setNum=%s,value%s=%s(RRœRªtSetNumRtLittleHelperSetNumCountR¿RRïtLittleHelperValueCountthasattrtgetattrR R/t!Def_Player_Dict_LittleHelperValueR©(R¨RRR    tsetNumRõtvalue((sgD:\SG_ServerCode\ServerPython\ZoneServerGroup\map1_8G\MapServer\MapServerData\Script\Player\ChPlayer.pytOnSetLittleHelperws      'cCsg}xÈttjdƒD]³}d}xŽtdtjdƒD]v}|jtj||fƒ}|skq=n|s‰tjƒ}||_    nt
|d|ƒr=t |d||ƒq=q=W|r|j |ƒqqW|sÛdStj ƒ}||_t|jƒ|_tj||ƒdS(NisValue%s(RïRRÞRËRßR_RâRttagMCLittleHelperFuncSetRÝRàtsetattrRÂttagMCLittleHelperSett FuncSetListRŸt FuncSetCountRR(R    t funcSetListRãtfuncSetRõRätsetPack((sgD:\SG_ServerCode\ServerPython\ZoneServerGroup\map1_8G\MapServer\MapServerData\Script\Player\ChPlayer.pyR[†s*       cCstjƒj|ƒ}|j}|j}|dkr |s?dntddƒd}x1ttjƒD] }t    j
|tj ||ƒqbWtj d||fƒnj|dtjkrÈtj d|ƒdStj d||fƒ|rëdnd}tj|tj ||ƒdS(    Niÿiiiis"ÉèÖÃÈ«²¿Òýµ¼×´Ì¬: isOK=%s,value=%ss0ÉèÖÃÒýµ¼Ê§°Ü, ³¬¹ý×î´óÖ§³Ö¼Ç¼λ£¡ guideIndex=%ss"ÉèÖÃÒýµ¼³É¹¦ guideIndex=%s,isOK=%s(RRœRªt
GuideIndextIsOKRRïRtDef_GuideStateKeyCountR R/tDef_Player_Dict_GuideStateR©R¿tSetDictValueByBit(R¨RRR    t
guideIndextisOKRäRõ((sgD:\SG_ServerCode\ServerPython\ZoneServerGroup\map1_8G\MapServer\MapServerData\Script\Player\ChPlayer.pyt OnSetGuideOK¨s         cCsutjƒ}g|_x7ttjƒD]&}|jj|jtj|ƒƒq%Wt    |jƒ|_
t j ||ƒdS(N( RttagMCGuideStatet
GuideStateRïRRðRÂR_RñRŸRfRR(R    tguideStatePackRõ((sgD:\SG_ServerCode\ServerPython\ZoneServerGroup\map1_8G\MapServer\MapServerData\Script\Player\ChPlayer.pyR6½s     $cCs)tjƒ}||_tj||ƒdS(N(RttagMCShowGuidetGuideIDRR(R    tguideIDt    showGuide((sgD:\SG_ServerCode\ServerPython\ZoneServerGroup\map1_8G\MapServer\MapServerData\Script\Player\ChPlayer.pyt    ShowGuideÇs     cCsKtjƒj|ƒ}|sdS|jƒ}|jƒ}||krGdSdS(N(RRœRªtGetPlayerLastActionRî(R¨RR    t
lastActiont    curAction((sgD:\SG_ServerCode\ServerPython\ZoneServerGroup\map1_8G\MapServer\MapServerData\Script\Player\ChPlayer.pytOnPlayerChangeActionÒs   cCs‚tjƒj|ƒ}tjƒ}|jƒ}|dksE|dkrIdS|j|ƒtj|ƒdkr~t    j
||ƒndS(Niid( RRœRªR†tIPY_CSetHPRestoretGetValuetSetHPRestoreSettingR RáR tPlayerAutoRestoreHP(R¨RR    RgtcurValue((sgD:\SG_ServerCode\ServerPython\ZoneServerGroup\map1_8G\MapServer\MapServerData\Script\Player\ChPlayer.pytHPRestoreSettingðs   cCs‚tjƒj|ƒ}tjƒ}|jƒ}|dksE|dkrIdS|j|ƒtj|ƒdkr~t    j
||ƒndS(Niid( RRœRªR†tIPY_CSetMPRestoreRtSetMPRestoreSettingR RáR tPlayerAutoRestoreMP(R¨RR    RgR((sgD:\SG_ServerCode\ServerPython\ZoneServerGroup\map1_8G\MapServer\MapServerData\Script\Player\ChPlayer.pytMPRestoreSetting    s   cCsÔ|tjks|tjkr3tjd|ƒdS|jƒ|krZtjd|ƒdStjƒjƒ}|td|ƒ@sštjd||fƒdS|tjkr¹t    j
|ƒn|j |ƒt |ƒdS(Ns*±ä¸üPKģʽÒì³££¬²»´æÔÚ¸Ãģʽ!attackMode=%ss PKģʽÏàͬ£¬²»±ä¸ü!attackMode=%sis3±¾µØÍ¼½ûÖ¹Çл»¸Ãģʽ£¡attackModels=%s,changeMode=%s( R†tamPeacetamMaxRR©RûR„tGetAttackModelsRt    NPCCommontClearSummonAngry_PlayerRüRý(R    t
attackModet attackModels((sgD:\SG_ServerCode\ServerPython\ZoneServerGroup\map1_8G\MapServer\MapServerData\Script\Player\ChPlayer.pytChangeAttackMode#    s 
cCs;tjƒj|ƒ}|jr$dnd}|j|ƒdS(Nii(RRœRªtAdultt ChangeAdult(R¨RRR    tadult((sgD:\SG_ServerCode\ServerPython\ZoneServerGroup\map1_8G\MapServer\MapServerData\Script\Player\ChPlayer.pyt
PySetAdultE    s cCs\|jƒsdStj|ƒdkr)dStj|ƒtkrBdS|jƒtkrXdStS(Ni(R×R RáR RkRRj(R    ((sgD:\SG_ServerCode\ServerPython\ZoneServerGroup\map1_8G\MapServer\MapServerData\Script\Player\ChPlayer.pytCheckPlayerStopMoveP    s cCstjtƒ||ƒdS(N(RR¦t__Func_PlayerCanResetWorldPos(R¨R((sgD:\SG_ServerCode\ServerPython\ZoneServerGroup\map1_8G\MapServer\MapServerData\Script\Player\ChPlayer.pytPlayerCanResetWorldPosl    scCs)tjƒj|ƒ}tj||ƒdS(N(RRœRªR tDoPlayerResetWorldPos(R¨RR    ((sgD:\SG_ServerCode\ServerPython\ZoneServerGroup\map1_8G\MapServer\MapServerData\Script\Player\ChPlayer.pyRu    scCs-tjƒj|ƒ}|jƒt|ƒdS(N(RRœRªt    ExitEventtNotifyChangeMapFail(R¨RR    ((sgD:\SG_ServerCode\ServerPython\ZoneServerGroup\map1_8G\MapServer\MapServerData\Script\Player\ChPlayer.pytPlayerChangeMapFailCallback€    s
 
cCsM|jtƒtjƒ}|jƒtj||ƒtjd|j    ƒƒdS(Ns µØÍ¼Çл»Ê§°Ü(
RRRttagMCChangeMapFailRRRRRvRž(R    Rg((sgD:\SG_ServerCode\ServerPython\ZoneServerGroup\map1_8G\MapServer\MapServerData\Script\Player\ChPlayer.pyR‰    s   
cCs&tjƒj|ƒ}t||ƒdS(N(RRœRªt __Func_ExitFB(R¨RR    ((sgD:\SG_ServerCode\ServerPython\ZoneServerGroup\map1_8G\MapServer\MapServerData\Script\Player\ChPlayer.pytExitFB¤    s cCs‘tjƒjƒtjkr=|jƒtjddƒkr=dStjd|j    ƒ|j
ƒƒt j |ƒspdSt j ||ƒtj|ƒdS(NtMapLineisÍæ¼Ò = %s , Ö÷¶¯À뿪¸±±¾(RR„R…R†R‡R"RRRvtGetNameRžR tCanPlayerLeaveFBtDoPlayerLeaveFBR t PlayerLeaveFB(R    R((sgD:\SG_ServerCode\ServerPython\ZoneServerGroup\map1_8G\MapServer\MapServerData\Script\Player\ChPlayer.pyR ®    s9  c    Cs@tjƒj|ƒ}tjƒ}|jƒ}|dkrWtjd||jƒƒdStjƒrgdS|j    ƒ}d}t
j ddiƒ}||kr´t d||dƒ}nt
j ddƒ}||kr||kr|||krtjd||||f|jƒƒdSt ||ƒs,dStj||ƒdS(Nis%ChangeLine -> ·â°ü´íÎó, ÎÞ´ËÏß· = %sR"iisF¸ÃµØÍ¼Ã»Óпª·Å´ËÏß·£¬ÎÞ·¨ÊÖ¶¯Çл»£¡mapID=%s,changLineID=%s,maxLine=%s(RRœRªR†tIPY_CChangeLinetGetLineR¿RžRR"RRR1t__CheckCanChangLineR tPlayerChangeLine(    R¨RR    Rgt changLineIDtmapIDtactivityLineIDtactivityMapLineDictt mapLineDict((sgD:\SG_ServerCode\ServerPython\ZoneServerGroup\map1_8G\MapServer\MapServerData\Script\Player\ChPlayer.pyt
ChangeLineÏ    s,      (    cCsË||jƒtjkr-tj|dƒtS|jƒ}|tjkrXtj    |ƒn#|tj
kr{tj|dƒtStj |ƒržtj|dƒtS|j ƒtj krÇtj|dƒtStS(NtPK_liubo_500807tGeRen_liubo_71563tGeRen_liubo_850801tGeRen_liubo_760310(t GetLoginTickRtDef_PlayerChangLine_TickR RˆRRîR†tpaSitt DoPlayerStandtDef_PlayerChangLine_StatetIsPlayerInFightR]tDef_PlayerChangLine_VehicleR(R    Rt playerAction((sgD:\SG_ServerCode\ServerPython\ZoneServerGroup\map1_8G\MapServer\MapServerData\Script\Player\ChPlayer.pyR)ø    s  cCs/tj|ƒdkr.|jƒtjkr.dS|tjtjgkrJdStj    ƒj
ƒ}|tj kr¼t j ddƒ}tjtj    ƒjƒƒ}||kr¬||S|jddƒS|jtjƒr+tj|tjƒd}|r+|jƒjƒ|jƒjƒkr(t j ddƒdSq+ndS(s ËÀÍö״̬²ÅÑé֤ʱ¼ä£¬±¾·þ¿ç·þͨÓÃ
            ¿ç·þ·þÎñÆ÷ËÀÍöµÄ¸´»îÒ²ÊÇÏÈ·¢µ½±¾·þ£¬Õý³£Çé¿öϱ¾·þÊÇ»î×ŵģ¬ÎÞ·¨ÑéÖ¤
            ËùÒÔ¿É·ñ¸´»îÓÉ¿ç·þ·þÎñÆ÷ËÀÍö״̬ϵÄÍæ¼ÒʵÀýÅжϣ¬¼òµ¥½²¾ÍÊÇÄĸö·þÎñÆ÷ËÀÍöµÄÄĸö·þÎñÆ÷ÅжÏ
            ËùÒԸú¯Êý¿ÉÒÔÖ±½ÓʹÓÃÍæ¼ÒËùÔڵĵØÍ¼ÅжÏ
    itDuplicatesRebornTimeitRebornArguments(R RáRîR†RãRRïtrebornType_MainCityRR„R…R‡RRRIRõR"RR_R•Rˆt FindBuffByIDtDef_SkillID_ReviveTiredtGetSkillt
GetSkillLVt GetSkillMaxLV(R    RtmapTypetfbRebornTimeDictR¡tfindBuff((sgD:\SG_ServerCode\ServerPython\ZoneServerGroup\map1_8G\MapServer\MapServerData\Script\Player\ChPlayer.pyt GetRebronTime
s"* $cCs_|jtjƒ}ttjƒƒ}tjd|td||ƒfƒtd||ƒ|kS(Ns¸´»îÀäȴʱ¼ä=%s,passTime=%si(R_RRLtintttimeRR©R1(R    t
rebornTimetplayerDeadTimeTicktcurGameWorldTick((sgD:\SG_ServerCode\ServerPython\ZoneServerGroup\map1_8G\MapServer\MapServerData\Script\Player\ChPlayer.pytCanRebornByTimeOver=
s$cCst|rAtj|ƒdkrA|jƒtjkrAt||ƒdS|tjkrTdS|r¸|jƒ}|tj    tj
gkr¸|j ƒ r¸t j d|jƒ|f|jƒƒdSnt||ƒ}|r5ttjƒƒ}|jtjƒ}|||kr5tj|dƒt jd|||f|ƒdSnt jƒsZt||tƒsZdSntj||ƒspdStS(sÇ ¼ì²é¿É·ñ¸´»î£¬ÎªÁËÂß¼­Í³Ò»£¬ÕâÀï²»ÊÊÓÃÍæ¼ÒËùÔڵĵØÍ¼£¬Ö§³Ö¿ç·þ״̬ÏÂÅжϿç·þµØÍ¼
                ±¾º¯Êý²»ÑéÖ¤Íæ¼ÒËÀÍö״̬µÈ£¬ÒòΪÓпÉÄÜǰºó¶Ë¸´»î״̬²»Ò»Ö£¬Èç¹ûÕâÀïÀ¹×¡¿ÉÄܵ¼ÖÂǰ¶ËÌÉʬ¸´»î²»ÁË
    iNs*¸ÃµØÍ¼²»¿ÉÔ­µØ¸´»î! mapID=%s,rebornType=%stRebornCDsC¸´»îÀäȴʱ¼äÖУ¬ÎÞ·¨¸´»î! curTime(%s) - deadTime(%s) < rebornCD(%s)(R RáRîR†RãR¤RtDef_RebornTypeListRtrebornType_HealthtrebornType_UseItemtGetLocalRebornRR¿R"RHRIRJR_RLR RˆRvRRžRR t OnCanFBRebornR(R    RR›R‹R¶trebornCDtcurTimetdeadTime((sgD:\SG_ServerCode\ServerPython\ZoneServerGroup\map1_8G\MapServer\MapServerData\Script\Player\ChPlayer.pyRŽH
s00  %& c Cs%tj|ƒ}|jƒ}|tjkr¾tjddƒ}|d}tj|tj    |ƒ}|s|t
j d||ƒdS|r!x6|D]+\}}    tj |||    tj ƒs‰dSq‰Wq!nc|tjkr!tj|tjƒ}
|
süt
j d|ƒdS|r!tj||
dtdƒq!ntS(NR>iis%»õ±Ò²»×㣬ÎÞ·¨Ô­µØ¸´»î! moneyPrice=%ss¸´»îµÀ¾ß²»×㣬ÎÞ·¨Ô­µØ¸´»î! tReborn(R R3RRRQRRt HaveMoneyExRÊtTYPE_Price_Gold_Paper_MoneyRR¿tPayMoneytDef_Cost_ReviveRRRÆtFindItemInPackByEffectExtDef_Effect_ReborntDelItemR( R    RtisDoCostR‘R¶t    rebornCfgt
moneyPricet costMoneyListt    moneyTypetmoneyCntt
rebornItem((sgD:\SG_ServerCode\ServerPython\ZoneServerGroup\map1_8G\MapServer\MapServerData\Script\Player\ChPlayer.pyRžs
s* 
c
    CsYtj}t}|tjkrLtjƒr3t}qttj|tj    dƒn(|tj
krttj|tj    dƒn|j |ƒ|rtj |||ƒn|r¼t j|tj|ƒn|jtjƒrÞt||ƒntjddƒd}tj|ƒrtj|||ƒntj|ƒr@tj|||ƒntj|ƒ}|jƒtj|tj|ƒ|tjƒtj||ƒtj ƒ}    |tjkr¯| sûtj ƒj!|j"ƒ|j#ƒƒ sû|tj
kr|    j$ƒ|j%ƒkr|j&ƒn:|tj
krBtj'||    j$ƒ|    j(ƒ|    j)ƒƒntj*|t+j,ƒdS(NiitPKConfigiiè(-RtDef_MaxRateValueRRïR tOnPlayerRebornRR R/RèR?RXtOnResetFBRebornPlacePosRˆR‰RŠR_R•RŸRR0Rt IsInPKStatetSetPKStateTickt IsInBossStatetSetBossStateTicktRefreshAllStateR R RtOnPlayerRebornOverRR„RòRßRàtGetRebornMapIDR"RétPlayerResetWorldPost GetRebornMapXt GetRebornMapYRnR†Ro(
R    RRt mapBornPlacetisAddSuperBufftresetHpPercentt
isFBRebornt    validTimeRR›((sgD:\SG_ServerCode\ServerPython\ZoneServerGroup\map1_8G\MapServer\MapServerData\Script\Player\ChPlayer.pyR–
sB          
$ %' +cCs£tj|tjƒd}|rY|jƒjƒ}|jƒjƒ|kr_|d}q_nd}tj|tj||ƒtj    d|ƒt
j |tj dƒdS(Niis    ¸´»îÆ£ÀÍBUff buffSkillLV=%s( RˆR@RRARBRCRDR‰RR©R R/R•(R    RRGt buffSkillLV((sgD:\SG_ServerCode\ServerPython\ZoneServerGroup\map1_8G\MapServer\MapServerData\Script\Player\ChPlayer.pyRŸÏ
scCsatjƒ}t|||ƒs"dStjƒsGt||tƒsGdSnt|||||ƒtS(s Íæ¼Ò¸´»î
    N(RR„RŽRRžRR–(R    RRRuRvR›((sgD:\SG_ServerCode\ServerPython\ZoneServerGroup\map1_8G\MapServer\MapServerData\Script\Player\ChPlayer.pyRñÝ
s  cCs<tjƒjƒ}|tjkr%dStj|||ƒdS(N(RR„R…R†R‡R t DoFBOnReborn(R    RRRE((sgD:\SG_ServerCode\ServerPython\ZoneServerGroup\map1_8G\MapServer\MapServerData\Script\Player\ChPlayer.pyR‰ò
s
cCsdS(N((R¨RR((sgD:\SG_ServerCode\ServerPython\ZoneServerGroup\map1_8G\MapServer\MapServerData\Script\Player\ChPlayer.pytOnEnterCrossServer scCstjtƒ||ƒdS(N(RR¦t__Func_EnterFbGameEvent(R¨R((sgD:\SG_ServerCode\ServerPython\ZoneServerGroup\map1_8G\MapServer\MapServerData\Script\Player\ChPlayer.pytEnterFbGameEvent scCsPtjƒj|ƒ}tjƒ}|jƒ}|jƒ}tj|||ƒdS(N(    RRœRªR†tIPY_CEnterFbGameEventR"t    GetLineIDR t PlayerEnterFB(R¨RR    RgR,tclientSendLineID((sgD:\SG_ServerCode\ServerPython\ZoneServerGroup\map1_8G\MapServer\MapServerData\Script\Player\ChPlayer.pyR}# s    c
    Csntjƒj|ƒ}|j}|j}|j}|j}|j}|j}    t    ||||||||    ƒdS(N(
RRœRªR¢tMapIDtLineIDRDREtExData1t__Func_WorldTransPort(
R¨R{RR    tpackTransportTypeR,tlineIDRRtexData1((sgD:\SG_ServerCode\ServerPython\ZoneServerGroup\map1_8G\MapServer\MapServerData\Script\Player\ChPlayer.pytPYWorldTransPort8 s                        c
CsÖ|jƒ|krR||jtjƒtjtjkr<dS|jtj|ƒn|jƒ}tjd||||f|ƒ|dkrdn|}tj    ƒrÁ|jƒ|kr¸dSd}n|tj
j ƒkrîtj d||ƒdStj
j |ƒ}    tj|ƒsdStj||ƒs)dSt|||||ƒ\}}||fd    krmtj|dƒdS|    tjkr t||    ƒ r t||    ƒ r dS|jtj|    ƒt||||d|d|ƒdS(
NsAWorldTransPort packTransportType=%s,mapID=%s,lineID=%s,exData1=%siÿiÿÿÿÿs-WorldTransPort packTransportType = %s, NoFindis#04BBF813-7A30-47A8-927DE1ACCC4F378ERˆR‰(ii(R"RMRtTYPE_Player_Tick_WorldTransportRORPRRR©RtDef_PackType_TransportTypeRSR¿RR tCheckPlayerTransporttCheckTagCountrytGetTransportPosRˆtDef_Transport_Type_MissiontTransportVipLvRestricttPayForTransportRtDef_PlayerKey_TransTypet
BeginTrans(
R    R‡R,RRRRˆR‰R¶t transportType((sgD:\SG_ServerCode\ServerPython\ZoneServerGroup\map1_8G\MapServer\MapServerData\Script\Player\ChPlayer.pyR†C s>&          c    Cs&tj||||||||ƒtS(N(R RrR(R    R,RRRˆR¡tcanLockR‰((sgD:\SG_ServerCode\ServerPython\ZoneServerGroup\map1_8G\MapServer\MapServerData\Script\Player\ChPlayer.pyR”„ s"cCsX|jƒ|krNtjƒj||ƒsNtj||tjƒ\}}qNn||fS(N(R"RR„RòRêRëRRì(R    R•ttransportMapIDt transportPosXt transportPosY((sgD:\SG_ServerCode\ServerPython\ZoneServerGroup\map1_8G\MapServer\MapServerData\Script\Player\ChPlayer.pyRŸ s$cCs½tjdƒ}|stSd}|jƒjtjƒ}tj|||ƒ\}}|s tjddƒ}t    |tj
||ƒs¹t j d||fƒt Sntj||||t ƒtS(Nt TransportPayiis=    ´«ËÍÏûºÄ´¦Àí ´«Ë͵À¾ß²»×ã itemID=%s, Ç®Ò²²»¹»costMoney=%s(RR0RRNRPR†R½RÆR*tTransportPayMoneytTYPE_Price_Gold_PaperRR©RR.(R    R•RAtuseCountR5R8titemListt    costMoney((sgD:\SG_ServerCode\ServerPython\ZoneServerGroup\map1_8G\MapServer\MapServerData\Script\Player\ChPlayer.pyR’» scCsdS(Ni((R    R•((sgD:\SG_ServerCode\ServerPython\ZoneServerGroup\map1_8G\MapServer\MapServerData\Script\Player\ChPlayer.pyR‘Ñ sc    CsŽtj|||ƒ}|gkr%tSxb|D]Z\}}|dkr,tj|||tji|d6ƒtj||dd||ƒq,q,WtS(Nit TransportType(    R RYRR[RtDef_Cost_TransportRtLogin_Interface_GoldRecR(R    RdtmoneyR•t    moneyList((sgD:\SG_ServerCode\ServerPython\ZoneServerGroup\map1_8G\MapServer\MapServerData\Script\Player\ChPlayer.pyR›ß s  c    Cs*tjƒrdStjdƒ}tjƒj|ƒ}|j}|j}|jt    |ƒƒ}|svtj
d|ƒdS|d}|j ƒ}    |}
|j ƒ} |    |krÅtj
d|    |fƒdS|
| krìtj
d|
| fƒdSt j|ƒ} |jƒ} d}t    t|dƒƒ}|d}t    |dƒ}t    t|dƒƒ}t j |ƒ}t j|||ƒ}|sdSxe|D]]\}}t j|||tji|
d6|d    6|tj6ƒsˆtj
d
t |fƒdSqˆW|j|ƒt    t| |
dƒƒ}|j|ƒ|jƒdS( NtOfflineSys_ExpChangesÀëÏß¾­Ñé¶Ò»»Ë÷Òý´íÎóindex=%sis=ÀëÏß¹Ò»ú·â°ü¶Ò»»¾­ÑéÒì³££¬Íæ¼ÒvipµÈ¼¶ %s, ÏÔʾµÄvipµÈ¼¶ %s £¬s5ÀëÏß¹Ò»ú·â°ü¶Ò»»¾­ÑéÒì³££¬¶Ò»»Ê±¼ä %s, ÀÛ»ýʱ¼ä %s £¬iit
ChangeTimetIndexs3¸ßЧÁ·¹¦£¬£¬½ðÇ®²»×ã##PlayerControl=%s,,moneyCnt=%s(RRRœRRœRªR§t ExchangeTimeRRIR¿tGetVIPLvtGetOfflineMinutesR tGetPlayerReExpRÛtevalRYR[RtDef_Cost_OffLineExptDef_Cost_Reason_SonKeytAddExpR1tSetOfflineMinutestSyn_OfflineTimeQueryResult(R¨t curPackDataRtOfflineExpChangeDictR    tmulIndext exchangeTimetrecListtminVIPLvtVIPLvt
useMinutest haveMinutestrExptreLVtworldLvExpRatet    redeemExpt moneyInfoListRdRŸRt haveMoneyListRet offlineTime((sgD:\SG_ServerCode\ServerPython\ZoneServerGroup\map1_8G\MapServer\MapServerData\Script\Player\ChPlayer.pytPlayerExpExchangeô sR         
 
!  
cCs|jtjƒ}|rDtj|tjdƒt|tjdƒn|jtjƒ}|rˆtj|tjdƒt|tjdƒn|jtj    ƒ}|rÌtj|tj    dƒt|tj
dƒn|jtj ƒ}|rtj|tj dƒt|tj dƒnt |ƒdS(Ni(R_RR`R R/RaRbRcRdRiRjRkRlt
ADCntOnDay(R    RpRqRt((sgD:\SG_ServerCode\ServerPython\ZoneServerGroup\map1_8G\MapServer\MapServerData\Script\Player\ChPlayer.pyt PlayerOnDay> s$
c
Cs„tjƒ}|j|ƒ}|j}|j}|j}tjd|||fƒ|tjkrrt    j
||ƒn|tj kr”t    j ||ƒnì|tj kr¶tj||ƒnÊ|tjkrØtj||ƒn¨|tjkr÷t||ƒn‰|tjkrtj|ƒnj|tjkr5tj|ƒnK|tjkrZtj|||ƒn&|tjkr|tj ||ƒn|tj!kržt"j#||ƒnâ|tj$kr½t%||ƒnÃ|tj&krßt'j(||ƒn¡|tj)krt*j+|||ƒn||tj,kr&t-j.||ƒnZ|tj/krKt0j1|||ƒn5|tj2krpt3j4|||ƒn|tj5kr•t6j7|||ƒnë|tj8kr´t9j:|ƒnÌ|tj;krÙt<j=|||ƒn§|tj>krþt?j@|||ƒn‚|tjAkr#tBjC|||ƒn]|tjDkrHtEjF|||ƒn8|tjGkrmtHjI|||ƒn|tjJkr’tKjL|||ƒnî|tjMkr·tNjO|||ƒnÉ|tjPkrÜtQjR|||ƒn¤|tjSkrtTjU|||ƒn|tjVkr&tWjX|||ƒnZ|tjYkrHtHjZ||ƒn8|tj[krdt\|ƒn|tj]kr†t^j_||ƒnú|tj`kr¨tajb||ƒnØ|tjckrÊtHjd||ƒn¶|tjekrìtfjg||ƒn”|tjhkrtijj|||ƒno|tjkkrHtl||tjmtnjoddƒdƒn8|tjpkrtl||tjqtnjoddƒdƒn|tjrkr¶tl||tjstnjoddƒdƒnÊ|tjtkrítl||tjutnjodd    ƒd
ƒn“|tjvkratjwƒjxtyjzƒd}tnj{d dƒ}    ||    kr€tl||tj|tnjod d ƒd ƒq€n|tj}kr€t~||ƒndS( Ns5PlayerGetReward: rewardType=%s,dataEx=%s,dataExStr=%stGameNoticeRewardit
GameNoticetShareGameRewardt    ShareGametGoodGameRewardtGoodGameitLikeGametOpenServerDailyAwardi(RRœRªt
RewardTypetDataExt    DataExStrR©RtDef_RewardType_ActivityR†tGetActivityAwardtDef_RewardType_DailyTasktGetDailyTaskAwardtDef_RewardType_SuccessRLtGetSuccessAwardtDef_RewardType_TreeFreeTimeRtFreeReduceTreeLVTimetDef_RewardType_ADAwardt OnGetADAwardtDef_RewardType_LLMJLVUpR‡t
OnLLMJLVUptDef_RewardType_FamilyTaofaBoxtPlayerFamilyTaofatGetTaofaBoxAwardtDef_RewardType_LineupRecommendR{tGetLineupRecommendAwardtDef_RewardType_OpenFuncRAtGetFuncOpenAwardtDef_RewardType_BeautyLVAwardRˆtGetBeautyLVAwardtDef_RewardType_DownLoadtGetDownloadAwardt'Def_RewardType_OSACelebrationPointAwardR‹tGetOSACelebrationPointAwardtDef_RewardType_LunhuidianAwardRtGetLunhuidianAwardt)Def_RewardType_ActHeroAppearStarFreeAwardRŽtGetHeroAppearStarFreeAwardt&Def_RewardType_FamilyAtkDefBatTreasuretGameLogic_FamilyAtkDefBattOnGetFamilyAtkDefBatTreasuretDef_RewardType_ActSignAwardR’tOnGetActSignAwardtDef_RewardType_ActTaskR“tOnGetActTaskAwardt!Def_RewardType_QunyingRankHighestRÃtGetQunyingRankHighestAwardtDef_RewardType_TotalRechargeRtOnGetTotalRechargeAwardt"Def_RewardType_TotDayRechargeAwardRtOnGetTotDayRechargeAwardtDef_RewardType_FamilyCTGAssisttPlayerActFamilyCTGAssisttGetFamilyCTGAssistAwardtDef_RewardType_FamilyGCZR”tGetFamilyGCZAwardtDef_RewardType_FirstChargeR@tGetPlayerFirstChargetDef_RewardType_ManyDayRechargeRWtOnGetManyDayRechargeAwardtDef_RewardType_SingleRechargeRXtOnGetSingleRechargeAwardtDef_RewardType_ActBuyCountGiftRVtOnGetBuyCountGiftAwardtDef_RewardType_BuyOneRPtGetBuyOneFreeAwardtDef_RewardType_TreasureCntAwardRGtGetTreasureCntAwardt!Def_RewardType_HistoryChargeAwardtOnGetHistoryRechargeAwardtDef_RewardType_CreateRoletOnGetCreateRoleAwardtDef_RewardType_CustomAwardR^tOnGetCustomAwardtDef_RewardType_RealmLVUpTaskR:tGetRealmLVUpTaskAwardtDef_RewardType_DailyPackBuyGifttGetDailyPackBuyGifttDef_RewardType_TaskR€t GetTaskAwardtDef_RewardType_ZhanlingRtGetZhanlingRewardRbtOnGiveAwardByClientR`RRRdRcRfReRhRgRjRùR)RÊtDef_Notify_WorldKey_ServerDayR0RiRltOnGetRechargeDayAward(
R¨RRRôR    t
rewardTypeRÌt    dataExStrt openServerDaytopenServerDayLimit((sgD:\SG_ServerCode\ServerPython\ZoneServerGroup\map1_8G\MapServer\MapServerData\Script\Player\ChPlayer.pytPlayerGetRewarda s¸              (((( +c
CsÒtjd|ƒ}|sdS|jƒ}|jtj|ƒ}|rn||krntjd|||fƒdS|d7}tj    |tj||ƒ|j
ƒ}|j ƒ}|j ƒ}tjd|||||fƒt ||gƒ|rtj||ddtigƒn|dkr-tj|tƒn‘|dkrR|}tj||ƒnl|dkr}|}    tj||    tjƒnA|dkrœtj||ƒn"|d    kr¾tj|d
tƒntj||ƒdS( NtADAwards-½ñÈÕ¸Ã¹ã¸æ½±ÀøÒÑ´ïÉÏÏÞ! adID=%s,adCnt=%s > %sisNÁìÈ¡¹ã¸æ½±Àø! adID=%s,adCnt=%s,adAwardType=%s,adAwardValue=%s,awardItemList=%steventiiiiR3(RRt GetADCntMaxR_RtDef_PDict_ADCntRR©R R/tGetADAwardItemListtGetADAwardTypetGetADAwardValueR„R7tGivePlayerItemOrMailRRtGetTreeEnergyAwardRIt
AddFBADCntRGt
DoTreasuretCostType_ADFreeR‰tAddTravelEnergyR–tDoRefreshBeastCallRR)t
DR_ADAward(
R    tadIDtipyDatatadCntMaxtadCntt awardItemListt adAwardTypet adAwardValuetadMapIDt treasureType((sgD:\SG_ServerCode\ServerPython\ZoneServerGroup\map1_8G\MapServer\MapServerData\Script\Player\ChPlayer.pyRÙì s> 
    "     cCs§g}tjƒ}xxt|jƒƒD]d}|j|ƒ}|jƒ}|jtj|ƒsbq%nt    j
|tj|dƒ|j |ƒq%W|r£t ||ƒndS(Ni( RR&RïtGetADAwardCounttGetADAwardByIndextGetADIDR_RR$R R/RÂR„(R    t syncADIDListR0R¨R1R0((sgD:\SG_ServerCode\ServerPython\ZoneServerGroup\map1_8G\MapServer\MapServerData\Script\Player\ChPlayer.pyRÃ s  c
Cs    |sItjƒ}gt|jƒƒD]}|j|ƒjƒ^q%}n|}g}xh|D]`}|jtj|ƒ}| r‘|dkr‘q\nt
j ƒ}||_ ||_ |j|ƒq\W|sÊdSt
jƒ}    |d |    _t|    jƒ|    _tj||    ƒdS(Niÿ(RR&RïR9R:R;R_RR$RËRt tagSCADInfotADIDtADCntRÂttagSCADInfoListt
ADInfoListRŸRfRR(
R    R<R0RõtadIDListt
adInfoListR0R3tadInfoR{((sgD:\SG_ServerCode\ServerPython\ZoneServerGroup\map1_8G\MapServer\MapServerData\Script\Player\ChPlayer.pyR„# s( 7            c
Cs|jtjƒ}|jtjƒ}}g}tjddiƒ}xM|jƒD]?\}}t|ƒ}    ||    krP|    |krP|    }|}qPqPWtj    d||||f|j
ƒƒ|sÃdSt j ||dƒsÜdSt j|tj|ƒt|||ƒdS(NtRechargeDayAwardisGÁìÈ¡ÀÛ³äÿÈÕ×î¸ßµµ½±Àø: awardCoinRecord=%s,realTotal=%s,awardCoin=%s,%s(R_RtDef_PDict_CTGRealTotalRkRRRRIRR©RRÆt GiveAwardItemR R/Ra(
R    Rt    realTotaltawardCoinRecordt    awardCoinR4t dayAwardDictt needCoinStrRžtneedCoin((sgD:\SG_ServerCode\ServerPython\ZoneServerGroup\map1_8G\MapServer\MapServerData\Script\Player\ChPlayer.pyR= s"  &cCsf|jtjƒr#tjdƒdStj|tjdƒƒsBdSt    j
|tjdƒt |ƒdS(NsÒÑÁìÈ¡´´½Ç½±Àø!tCreateRoleAwardi( R_RtDef_PDict_CreateRoleAwardStateRR©RÆRGRRR R/R](R    ((sgD:\SG_ServerCode\ServerPython\ZoneServerGroup\map1_8G\MapServer\MapServerData\Script\Player\ChPlayer.pyRR s 
cCs?tjƒ}|jƒ|jtjƒ|_tj||ƒdS(N(    RttagMCCreateRoleAwardStateRR_RROtGetStateRR(R    Rg((sgD:\SG_ServerCode\ServerPython\ZoneServerGroup\map1_8G\MapServer\MapServerData\Script\Player\ChPlayer.pyR]_ s
 
cCsû|jƒ}tjddƒ}|jtjƒ}||krZtjd||f|ƒdStjddƒ}|svdSt    j
|tj|ƒtjd||f|ƒ|dkrÎt j d|j ƒ|ƒntj||ddtigƒt|ƒdS(    Nt
DownRewardis7ÒÑÁìÈ¡·Ö°ü½±Àø! curAwardNum(%s) == downloadAwardNum(%s)is4ÁìÈ¡·Ö°üÏÂÔØ½±Àø: curAwardNum=%s,downloadAwardNum=%stSubpackageDownloadR"t PackDownload(RRR0R_RtDef_PDict_DownloadAwardStateRR©RR R/R|RRžR7R(RRY(R    RÌR¶tdownloadAwardNumt curAwardNumR4((sgD:\SG_ServerCode\ServerPython\ZoneServerGroup\map1_8G\MapServer\MapServerData\Script\Player\ChPlayer.pyRæf s    
cCsWtjddƒ}tjƒ}|jƒ|jtjƒ|k|_t    j
||ƒdS(NRRi( RR0RttagMCPackDownloadRecordRR_RRUtRecordRR(R    RVRg((sgD:\SG_ServerCode\ServerPython\ZoneServerGroup\map1_8G\MapServer\MapServerData\Script\Player\ChPlayer.pyRY| s  
cCsj|j|ƒr*tjd||fƒdStj|||ƒsCdStj||dƒt||dƒdS(Ns)ÒÑÁìÈ¡¹ý¸Ã½±Àø! rewardType=%s, dictKey=%si(R_RR©RÆRGR R/Ra(R    RtdictKeytawardCfgt    eventName((sgD:\SG_ServerCode\ServerPython\ZoneServerGroup\map1_8G\MapServer\MapServerData\Script\Player\ChPlayer.pyR… scCs<tjƒ}|jƒ||_||_tj||ƒdS(N(RttagMCPlayerRewardGetRecordRRÍtRewardGetRecordRR(R    RtrewardGetRecordRg((sgD:\SG_ServerCode\ServerPython\ZoneServerGroup\map1_8G\MapServer\MapServerData\Script\Player\ChPlayer.pyRa• s  
        cCsŒtjƒj|ƒ}t|jƒ}tjdƒ\}}}|jddg|ƒ}d}    x:t|ƒD],\}
} t    j
|t j |    |
f| ƒqhW|jddg|ƒ} d}    x:t| ƒD],\}
} t    j
|t j |    |
f| ƒqÄW|jddg|ƒ} d}    x:t| ƒD],\}
} t    j
|t j |    |
f| ƒq Wd}    |j|    dƒ} t    j
|t j |    df| ƒdS(NtAutoFightSettingt
BasicSkillit    AreaSkillRžtHPPackagePercent( RRœRªR¬tDataRœRRRR R/RtDef_PDict_AutoFightSetting(R¨RRR    t settingDicttBasicSkillCounttAreaSkillCounttBuffSkillCounttBasicSkillListtKeyt
ValueIndextValuet AreaSkillListt BuffSkillList((sgD:\SG_ServerCode\ServerPython\ZoneServerGroup\map1_8G\MapServer\MapServerData\Script\Player\ChPlayer.pytOnSaveAutoFightSetting  s&$$$ c Cs¡tjdƒ\}}}i}d}g}x@t|ƒD]2}|jtj||fdƒ}|j|ƒq7W|||<d}g}    x@t|ƒD]2}|jtj||fdƒ}|    j|ƒqW|    ||<d}g}
x@t|ƒD]2}|jtj||fdƒ}|
j|ƒqéW|
||<d}|jtj|dfdƒ}|||<tjƒ} | j    ƒd|| _
t | j
ƒ| _ t j|| ƒdS(NR`RaiRbRžRcs%s(RœRRïR_RReRÂRttagMCAutoFightSettingRRdRŸtSizeRR( R    RgRhRiRfRkRjRlRmRnRoRg((sgD:\SG_ServerCode\ServerPython\ZoneServerGroup\map1_8G\MapServer\MapServerData\Script\Player\ChPlayer.pytSync_AutoFightSetting¾ s:
 
 
 
 
 cCs#tjƒj|ƒ}|sdSdS(N(RRœRª(R¨RRR    ((sgD:\SG_ServerCode\ServerPython\ZoneServerGroup\map1_8G\MapServer\MapServerData\Script\Player\ChPlayer.pytOnQueryBossHurtListæ scCs    tjƒj|ƒ}|sdS|jsutj}||j|ƒtj|krbtjdƒdS|j    ||ƒn|j
}|j }|j }g}|ryt |j ƒ}Wn&tk
r×tjd|j ƒdSXt|tƒstjdt|ƒƒdSntjd||t|ƒfƒtjƒjƒ}    |    |krÊtj||ƒ}
tj|ƒ} | j|ƒ} d} | rŽ| jƒ} ntjd|    || t|
ƒfƒtj||| |
ƒn;dt|||gƒ}|jtjdd|t|ƒƒdS(    Ns OnQueryMapNPCInfo ²éѯ¹ýÓÚÆµ·±£¡sOnQueryMapNPCInfo, npcIDList=%ss-OnQueryMapNPCInfo, npcIDList=%s is not list£¡s7OnQueryMapNPCInfo tagMapID=%s,tagLineID=%s,npcIDList=%sisB    Í¬µØÍ¼²éѯcurMapID=%s,tagLineID=%s,playerCnt=%s,npcInfoDict=%ss%stNPCInfo(RRœRªt IsNoTimeLimitRt TYPE_Player_Tick_QueryMapNPCInfoRMROR©RPRƒR„t    NPCIDListR¬t BaseExceptionR¿t
isinstancetlistR›R„R"Rt
GetNPCInfoR†t GetMapCopyPlayerManagerByFbIndextGetPlayerCountt SyncNPCInfotGameServer_QueryPlayerByIDtqueryType_NPCInfoRŸ(R¨RRR    ttickTypettagMapIDt    tagLineIDt queryNPCStrt    npcIDListR¡t npcInfoDictt    gameWorldRôt    playerCnttsendMsg((sgD:\SG_ServerCode\ServerPython\ZoneServerGroup\map1_8G\MapServer\MapServerData\Script\Player\ChPlayer.pytOnQueryMapNPCInfoð sN                                c Cs©tjƒj|ƒ}|sdS|jsTtj|tj|ƒsTtjdƒdSn|j}|j    }|j
}g}|räyt |j
ƒ}Wn&t k
r¶tj d|j
ƒdSXt|tƒsätj dt|ƒƒdSntjd||t|ƒfƒtjƒjƒ}||krjtj||ƒ}    tjd||t|    ƒfƒtj|||    ƒn;dt|||gƒ}
|jtjdd|
t|
ƒƒdS(    Ns#OnQueryMapNPCCntInfo ²éѯ¹ýÓÚÆµ·±£¡s"OnQueryMapNPCCntInfo, npcIDList=%ss0OnQueryMapNPCCntInfo, npcIDList=%s is not list£¡s:OnQueryMapNPCCntInfo tagMapID=%s,tagLineID=%s,npcIDList=%ss5    Í¬µØÍ¼²éѯcurMapID=%s,tagLineID=%s,npcInfoDict=%ss%sitNPCCnt(RRœRªRvtCheckPlayerTickRRwR©RƒR„RxR¬RyR¿RzR{R›R„R"Rt GetNPCCntInfotSyncNPCCntInfoR€tqueryType_NPCCntRŸ( R¨RRR    RƒR„R…R†R¡R‡RŠ((sgD:\SG_ServerCode\ServerPython\ZoneServerGroup\map1_8G\MapServer\MapServerData\Script\Player\ChPlayer.pytOnQueryMapNPCCntInfo0s@                           cCs#tjƒj|ƒ}|jƒdS(N(RRœRªRm(R¨RRR    ((sgD:\SG_ServerCode\ServerPython\ZoneServerGroup\map1_8G\MapServer\MapServerData\Script\Player\ChPlayer.pytQueryWorldTick_s
cCsÈtjƒ}|sdStjƒ}|jƒ|j|_|j|_|j    |_
|j |_ |j |_|j|_|j|_tjtjƒjƒƒ|_|r·tj||ƒn tj|ƒdS(N(RtGetCurrentTimeRttagServerDateTimeRtyeartYeartmonthtMonthtdaytDaythourtHourtminutetMinutetsecondtSecondt microsecondt    MicSecondtChangeTimeNumToStrRÈtGetSSServerMgrt GetCrossTimetCrossServerTimeRRtSendFackPackOnline(R    t
serverTimetserverDateTime((sgD:\SG_ServerCode\ServerPython\ZoneServerGroup\map1_8G\MapServer\MapServerData\Script\Player\ChPlayer.pyRis"  
        cCs tjƒ}|sdStjƒ}tjƒjtjƒ|_    tjƒjtj
ƒ|_ tjƒjtj ƒ|_ tjƒjtjƒ|_|j|_|j|_|j|_|j|_|j|_|j|_|j|_tjƒ|_tjƒjtj ƒ|_!t"j#||ƒdS(N($RR“RttagMCOpenServerDayR¿tGetEventTrigMgrRRÊt Def_ServerDayRštDef_IsMixServert IsMixServertDef_MixServerDaytMixDaytDef_OpenServerWeekdayt OpenWeekdayR•tNowYearR—tNowMonthR™tNowDayR›tNowHourRt    NowMinuteRŸt    NowSecondR¡t NowMicSecondt GetWeekOfYeart
WeekOfYeartDef_InitOpenServerTimetOpenServerTimeRR(R    R¨R{((sgD:\SG_ServerCode\ServerPython\ZoneServerGroup\map1_8G\MapServer\MapServerData\Script\Player\ChPlayer.pyR„s&         cCsätjƒj|ƒ}t|||ƒsà|jƒ|jƒ}}tjƒj||ƒtkrÍt    j
||dƒ}|jƒ|kr²|jƒ|kr²tj d||fƒdS|jƒ}|jƒ}n|j ||ƒndS(NisÍæ¼Ò×ø±ê¿¨ËÀ %s %s( RRœRªtPYPlayerNormalMoveRßRàR„RòRRêtGetEmptyPlaceInAreaR¿Rí(R¨R{RR    RRt    resultPos((sgD:\SG_ServerCode\ServerPython\ZoneServerGroup\map1_8G\MapServer\MapServerData\Script\Player\ChPlayer.pyt PYPlayerMove«s$ tPYMoveDistCalcTickt PYMoveDistSumc Csvt|ƒstS|j}|j}|j}|j}|j}|j}|j}    |j    ƒ}
|    dkr’||
dkr’t
j d||
fƒtSt
j ƒj ||ƒs»t
j dƒtS|jƒ|krL|jƒ|krL|jt|ƒ|jtdƒ|    dkr||
dkrtS|j|ƒt|||||||    ƒtSt
j ƒjƒtjkr†tj||||ƒs†tSn|jƒ} | tjtjgkr®tStj||||ƒsÔ|j ƒtSt
j!|jƒ|jƒ||ƒ} | dkr:t
j d|jƒ|jƒ||f|j"ƒƒtS|j#tƒ} t$|j#tƒ| dƒ}|jt|ƒ|t%j&d    d
ƒkr&|j'ƒ}|| }||}|t%j&d    d ƒd }||krt
j d | |||||f|j"ƒƒtS|jt|ƒ|jtdƒntj(|tj)ƒ|j*||ƒt|||||||    ƒ|j|ƒtS(Nii2smove ·¢°üÌ«¿ì ÊÕ°ü%s - ÉÏÒ»´Î%ss
ÒÆ¶¯Õϰ­µãiÞis)ÒÆ¶¯¾àÀë¹ý´ó£¬ Íæ¼Ò×ø±ê %s-%s  ÊÕ°ü %s-%siáõt PyMoveCheckiigY@sU    dist=%s,distSum=%s,speed=%s,needTick=%s, ËùÐèÒÆ¶¯Ê±¼äÒì³£ passCalcTick(%s) < (%s)(+RCRtDirt
ClientPosXt
ClientPosYt    SeverPosXt    SeverPosYR\RJtGetClientMoveTickRR©R„RòRRßRàRtMoveDistCalcTickt MoveDistSumtSetClientMoveTicktPyNotifyPlayerMoveR…R†R‡R t DoFBCanMoveR]R^R_R RlRmRaRžR™tminRR0tGetSpeedRnRoRG(R    R{RtmoveDirt
clientPosXt
clientPosYtsendPack_SeverPosXtsendPack_SeverPosYRgtmoveTypet lastMoveTickRhtdisttcalcTicktdistSumtspeedt passCalcTicktneedTickt checkNeedTick((sgD:\SG_ServerCode\ServerPython\ZoneServerGroup\map1_8G\MapServer\MapServerData\Script\Player\ChPlayer.pyR¾Ãsr                               $  
$  
 
     # cCstjƒ}|jƒ|jƒ|_tj|_||_||_    ||_
||_ ||_ |j ƒ|_||_tj||tdƒdS(Ni(RttagMCPYPlayerMoveRRžRyR†t    gotPlayerRxRÅRÆRÇRÈRÉRÑtSpeedRJR RKR(R    RÒRÓRÔRRR×Rg((sgD:\SG_ServerCode\ServerPython\ZoneServerGroup\map1_8G\MapServer\MapServerData\Script\Player\ChPlayer.pyRÎ1s 
                         cCsEtjƒ}|jƒ||_||_||_tj||ƒdS(s»Í¨ÖªÇ°¶ËÏòij¸öµãÒÆ¶¯
                ÕâÀïǰ¶Ë¿ÉÄÜÐèÒªÕë¶Ôij´ÎÒÆ¶¯×ö¶îÍâ´¦Àí£¬±ÈÈçÒÆ¶¯µ½Ä³¸öµãºóÐèÒª×Ô¶¯Õ½¶·µÈ
                ËùÒÔÕâÀïÖ»×ö֪ͨǰ¶Ë¿ÉÒÔÏòij¸öµãÒÆ¶¯£¬×îÖÕÒÆ¶¯ÓÉǰ¶Ë·¢Æð
    N(RttagMCNotifyPlayerMoveRRDREtNPCIDRR(R    RRtnpcIDRg((sgD:\SG_ServerCode\ServerPython\ZoneServerGroup\map1_8G\MapServer\MapServerData\Script\Player\ChPlayer.pytNotifyPlayerMoveBs 
            cCstjƒj|ƒ}|j|jtj}tj|ƒ}||}|dkrmt    j    |ƒ}|j
ƒntj ||ƒdS(Ni( RRœRªtLostHPtLostHPExRÊtDef_PerPointValueR RáR tSetDeadR (R¨RRR    tlostHPtcurHPtupdHPR((sgD:\SG_ServerCode\ServerPython\ZoneServerGroup\map1_8G\MapServer\MapServerData\Script\Player\ChPlayer.pyt OnRoleLostHPWs
  cCsdS(N((R¨RR((sgD:\SG_ServerCode\ServerPython\ZoneServerGroup\map1_8G\MapServer\MapServerData\Script\Player\ChPlayer.pytOnSelectRealmDifficultylscCstjƒj|ƒ}|j}|j}|tjkr:dS|tjkrX|jƒ}nt    j
ƒj ||ƒ}t ||j ƒ||ƒdS(N(RRœRªtRecTypetRecIDRÊtDef_GameRecTypeListtDef_ViewGameRecSelfListRR¿RÅRÆtSyncGameRecInfot GetDataList(R¨RRR    trecTypetrecIDt recTypeIDMgr((sgD:\SG_ServerCode\ServerPython\ZoneServerGroup\map1_8G\MapServer\MapServerData\Script\Player\ChPlayer.pyt OnViewGameRecys        cCs\g}xü|D]ô}|sq n|s@|jƒ}|jƒ}ntjƒ}|jƒ|_|jƒ|_|jƒ|_    |j
ƒ|_ |j ƒ|_ |jƒ|_|jƒ|_|jƒ|_|jƒ|_|jƒ|_t|jƒ|_|j|ƒq Wtjƒ}|jƒ||_||_||_t|jƒ|_ t!j"||ƒdS(N(#t
GetRecTypetGetRecIDRt tagSCGameRectGetTimetTimet    GetValue1tValue1t    GetValue2tValue2t    GetValue3tValue3t    GetValue4tValue4t    GetValue5tValue5t    GetValue6tValue6t    GetValue7tValue7t    GetValue8tValue8t GetUserDatatUserDataRŸt UserDataLenRÂttagSCGameRecInfoRRðRñtRecListRfRR(R    t recDataListRöR÷R¶RÑtrecR{((sgD:\SG_ServerCode\ServerPython\ZoneServerGroup\map1_8G\MapServer\MapServerData\Script\Player\ChPlayer.pyRô…s8    
            (ãRR†RR RêRRžRRERRˆR RRRÆR7RTRåRœRTRÊRRR)R<R@RCR:RzRKR†RIRLRARÝRGRR+RPRQRRR•RûRWRXR‹RÃRuRÅR˜R?R\R~R^RRR‡R€R R‚R’R‘RVRRŽR”R“R|R¿RÜR…R°R×R®t    PyMongoDBRRyRwRƒR{RŒRRˆR‰RŠR5R}RªRRÞRÈR­RîR–tdatetimeRJtmathtreR«RR
R R$RR¢R—RÐRÓRåRàRæRËRÑRR˜RøR>R4RJRMRXRkRtRlR(RƒR—R©R§R³R²R'RËRÉR¬RýR RÝR$R>RRLRRRiRCRvR`RŠR†RR˜R¤R¦R¥R©R§RÂRÔRRåR[RõR6RýRRR RRRRRRRR!R R0R)RHRNRŽRžR–RŸRñR‰R|R~R}RŠR†R”RR’R‘R›RÂRÄR RÙRÃR„RRR]RæRYRRaRpRsRtR‹R‘R’RRRÁRËRÌR¾RÎRæRîRïRùRô(((sgD:\SG_ServerCode\ServerPython\ZoneServerGroup\map1_8G\MapServer\MapServerData\Script\Player\ChPlayer.pyt<module>s¾                                                                                                                  &         ¤    A    ?    )     1             2            4    A         ,        
        <            
         
    ?    A    
        Ž                 %    2 !    $    :    K    +    $ 6                        
              0         -        "        
                     "                                      
    !    )    "    #     +    ?                             A                    J    #    ‹    )                                            (    
    @    /    
    '        n