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
432
433
434
435
436
437
438
439
440
441
442
443
444
445
446
447
448
449
450
451
452
453
454
455
456
457
458
459
460
461
462
463
464
465
466
467
468
469
470
471
472
473
474
475
476
477
478
479
480
481
482
483
484
485
486
dnŒic@s1
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@ddlAZAddlBZBddlCZCddlDZDddlEZEddlFZFddlGZGddlHZHddlIZIddlJZJddlKZKddlLZLddlMZMddlNZNddlOZOddlPZPddlQZQddlRZRddlSZSddlTZTddlUZUddlVZVddlWZWddlXZXddlYZYddlZZZddl[Z[ddl\Z\ddl]m^Z^ddl_Z_ddl`Z`ddlaZaddlbZbddlcZcddldZdddleZeddlfZfddlgZgddlhZhddliZiddljZjddlkZkddllZlddlmZmddlnZnddloZoddlpZpddlqZqddlrZrddlsZsd„Ztd„Zud„Zvd„Zwd„Zxd„Zyd    „Zzd
„Z{d „Z|d „Z}d „Z~d„Zdd„Z€d„Zd„Z‚d„Zƒe„dd„Z…d„Z†d„Z‡d„Zˆd„Z‰d„ZŠd„Z‹d„ZŒd„Zd„ZŽd„Zd„Zd „Z‘d!„Z’d"„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 d0„Z¡d1„Z¢d2„Z£d3„Z¤e„d4„Z¥d5„Z¦d6„Z§d7„Z¨d8„Z©d9„Zªd:„Z«d;„Z¬d<„Z­d=„Z®d>„Z¯d?„Z°d@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ÃdT„ZÄdU„ZÅdV„ZÆde„dW„ZÈdX„ZÉde„dY„ZÊdZ„ZËde„d[„ZÌd\„ZÍd]„ZÎd^„ZÏd_„ZÐd`„ZÑddda„ZÒdd@e„ddb„ZÓdc„ZÔdd„ZÕde„ZÖdf„Z×dg„ZØdh„ZÙdi„ZÚdj„ZÛdk„ZÜddl„ZÝdm„ZÞdn„Zßdo„Zàdp„Zádq„Zâd@dr„Zãds„Zädt„Zådu„Zædv„Zçdw„Zèdx„Zédy„Zêddz„Zëd{„Zìd|„Zíd}Zîd~Zïd„Zðd€„Zñdd„Zòd‚„Zódƒ„Zôd„„Zõd…„ZödS(†iÿÿÿÿN(tRecvPackToMapDBcCsdS(N((ttick((sgD:\SG_ServerCode\ServerPython\ZoneServerGroup\map1_8G\MapServer\MapServerData\Script\Player\ChPlayer.pyt
InitPlayer‰scCs6tj|ƒ|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žsc Csÿtjƒj|ƒ}|j}|j}|j}tjddiƒ}t|ƒ|kr[dS|t|ƒ}||dkrdS|d}    |dkr™dSt    j
|||dƒsµdS||    }
t    j |||
dƒtj d||||
f|j ƒƒdS(NtEqualValueMoneyiit MoneyExchangesI»õ±Ò¶Ò»»: srcMoneyType=%s,exchangeValue=%s,tagMoneyType=%s,tagMoneyAdd=%s(t    GameWorldtGetPlayerManagertGetPlayerByIndext SrcMoneyTypet TagMoneyTypet ExchangeValuet IpyGameDataPYtGetFuncEvalCfgtstrt PlayerControltPayMoneyt    GiveMoneytLogt GetPlayerID( tindext
clientDataRR    t srcMoneyTypet tagMoneyTypet exchangeValuetexchangeMoneyInfot exchangeInfotmultiplet tagMoneyAdd((sgD:\SG_ServerCode\ServerPython\ZoneServerGroup\map1_8G\MapServer\MapServerData\Script\Player\ChPlayer.pytOnMoneyExchange­s(            
 
    cCs5tjƒj|ƒ}tj||jƒ|jƒdS(N(RRRtPlayerChangeJobt DoChangeJobtGetJobtTagJob(RRRR    ((sgD:\SG_ServerCode\ServerPython\ZoneServerGroup\map1_8G\MapServer\MapServerData\Script\Player\ChPlayer.pyt OnChangeJobÍsc    Cstjƒj|ƒ}t|ƒtj|ƒdksI|jƒtjkr_t    |t
j |ƒn|j t
j dƒtj|ƒ}|jƒt|ƒtj|ƒ|jtƒtj|dƒ|jƒtj|t
jƒ|jƒd}tjƒj|jƒddd|t|ƒƒdS(NittRefreshMainServerRole(RRRt Sync_DBPlayertGameObjtGetHPtGetPlayerActiont IPY_GameWorldtpaDietPlayerRebornByTypeRtrebornType_SystemtSetDictt Def_PlayerKey_NotifyAllAttrStateRtReCalcAllStatet__Sync_ClientBufft PlayerStatetSync_PKBossStatet
SetVisibletTruetSetSightt RefreshViewtDef_PlayerSight_DefaulttGameServer_QueryPlayerResultRtlen(RRRR    t playerControltmsgInfo((sgD:\SG_ServerCode\ServerPython\ZoneServerGroup\map1_8G\MapServer\MapServerData\Script\Player\ChPlayer.pytOnRefreshMainServerRoleØs"
*
 
 
 
.cCsÞtjƒ}|jƒ|_|jƒ|_|jƒ|_|jƒ|_    |j
ƒ|_ |j ƒ|_ |jƒ|_|jƒ|_|jƒ|_|jƒ|_|jƒ|_|jƒ|_|jƒ|_|jƒ|_|jƒ|_|j ƒ|_!|j"ƒ|_#|j$ƒ|_%|j&ƒ|_'|j(ƒ|_)|j*ƒ|_+|j,ƒ|_-|j.ƒ|_/|j0ƒ|_1|j2ƒ|_3|j4ƒ|_5|j6ƒ|_7|j8ƒ|_9|j:ƒ|_;|j<ƒ|_=|j>ƒ|_?|j@ƒ|_A|jBƒ|_C|jDƒ|_E|jFƒ|_G|jHƒ|_I|jJƒ|_K|jLƒ|_M|jNƒ|_O|jPƒ|_Q|jRƒ|_S|jTƒ|_U|jVƒ|_W|jXƒ|_Y|jZƒ|_[|j\ƒ|_]|j^ƒ|__|j`ƒ|_a|jbƒ|_c|jdƒ|_e|jfƒ|_g|jhƒ|_i|jjƒ|_k|jlƒ|_m|jnƒ|_o|jpƒ|_q|jrƒ|_s|jtƒ|_u|jvƒ|_w|jxƒ|_y|jzƒ|_{|j|ƒ|_}|j~ƒ|_|j€ƒ|_|j‚ƒ|_ƒ|j„ƒ|_…|j†ƒ|_‡|jˆƒ|_‰|jŠƒ|_‹|jŒƒ|_|jŽƒ|_|jƒ|_‘|j’ƒ|_“|j”ƒ|_•|j–ƒ|_—|j˜ƒ|_™|jšƒ|_›|jœƒ|_|jžƒ|_Ÿ|j ƒ|_¡|j¢ƒ|_£|j¤ƒ|_¥|j¦ƒ|_§|j¨ƒ|_©|jªƒ|_«|j¬ƒ|_­|j®ƒ|_¯|j°ƒ|_±|j²ƒ|_³|j´ƒ|_µ|j¶ƒ|_·|j¸ƒ|_¹|jºƒ|_»|j¼ƒ|_½|j¾ƒ|_¿|jÀƒ|_Á|jƒ|_Ã|jă|_ÅtÆjÇ||ƒdS(N(ÈtChPyNetSendPackt tagMCDBPlayertGetAccIDtAccIDRtPlayerIDt GetPlayerNamet
PlayerNamet GetAccStatetAccStatet
GetGMLeveltGMLeveltGetSextSexR*tJobtGetReincarnationLvtReincarnationLvtGetLVtLVtGetLVExtLVExtGetLV2tLV2t GetExpPointtExpPointt GetTotalExptTotalExpt GetFamilyIDtFamilyt GetFamilyNamet
FamilyNamet GetTeamHornort
TeamHornortGetFamilyHornort FamilyHornortGetFamilyActiveValuetFamilyActiveValuetGetLastWeekFamilyActiveValuetLastWeekFamilyActiveValuetGetCountryHornort CountryHornortGetCountryLastWeekHornortCountryLastWeekHornortGetMatetMatetGetGoldtGoldt GetGoldPapert    GoldPapert    GetSilvertSilvertGetSilverPapert SilverPapert GetFightPointt
FightPointt GetHappyPointt
HappyPointt    GetLineIDtLineIDtGetMapIDtMapIDtGetPosXtPosXtGetPosYtPosYtGetRebornMapIDt RebornMapIDt GetRebornPosXt
RebornPosXt GetRebornPosYt
RebornPosYtGetStatetStateR1tHPtGetHPExtHPExtGetXPtXPtGetHPRestoreSettingtHPRestoreSettingtGetMPRestoreSettingtMPRestoreSettingt GetFreePointt    FreePointtGetFreeSkillPointtFreeSkillPointt
GetBaseSTRtBaseSTRt
GetBasePNEtBasePNEt
GetBasePHYtBasePHYt
GetBaseCONtBaseCONtGetSTRtSTRtGetPNEtPNEtGetPHYtPHYtGetCONtCONt
GetPKValuetPKValuet GetBackpackLVt
BackpackLVtGetWarehouseLVt WarehouseLVt    GetTeamIDtTeamIDtGetUseGoldTypet UseGoldTypetGetUseSilverTypet UseSilverTypet GetAttackModet
AttackModetGetLastWeekOnlineTimetLastWeekOnlineTimetGetClientLineIDtFBIDt GetFamilyLVtFamilyLVtGetFriendFavort FriendFavort    GetEnergytEnergytGetEquipShowSwitchtEquipShowSwitcht GetLuckValuet    LuckValuet
GetExAttr1tExAttr1t
GetExAttr2tExAttr2t
GetExAttr3tExAttr3t
GetExAttr4tExAttr4t
GetExAttr5tExAttr5t
GetFactiontFactiontGetInfamyValuet InfamyValuetGetOfficialRankt OfficialRanktGetChangeCoinPointTotaltChangeCoinPointTotaltGetVIPLvtVIPLvtGetVIPLvForPhonet VIPLvForPhonet
GetExAttr6tExAttr6t
GetExAttr7tExAttr7t
GetExAttr8tExAttr8t
GetExAttr9tExAttr9t GetExAttr10tExAttr10t GetModelMarkt    ModelMarkt GetExAttr11tExAttr11t GetExAttr12tExAttr12t GetExAttr13tExAttr13t GetExAttr14tExAttr14tGetOperateInfot OperateInfot
GetOperatetOperatet GetServerIDtServerIDt GetExAttr15tExAttr15t GetExAttr16tExAttr16t GetExAttr17tExAttr17t GetExAttr18tExAttr18t GetExAttr19tExAttr19t GetExAttr20tExAttr20tGetFacetFacet
GetFacePictFacePict GetRoleTypetRoleTypet NetPackCommont SendFakePack(R    tdbPlayer((sgD:\SG_ServerCode\ServerPython\ZoneServerGroup\map1_8G\MapServer\MapServerData\Script\Player\ChPlayer.pyR/ösÊ cCsÊ|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(R7RtDef_PlayerKey_LoadMapIsLogint CrossPlayertGetCrossPlayerMgrt RegistPlayerRtSync_PyServerDataTimeToClienttSync_OpenServerDaytSync_ClientPlayerLogintSyncSettingDataRt IsCrossServertSetForbiddenSyncClientStateR>tPlayerEventCountertUpdatePlayerLoginTimet__DoPlayerLoginServertFalseRt SetCrossMapIDRtBalanceServer_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|ƒt0j1|ƒt2j|ƒt3j4|ƒt5j|ƒt
j6|ƒt
j7|ƒt8j|ƒt9j|ƒt:j|ƒt;j|ƒt<j|ƒt=j|ƒt>j|ƒt?j|ƒt@j|ƒtAjB|ƒtCjD|ƒtEj|ƒtFj|ƒtGj|ƒtHj|ƒtIj|ƒtJj|ƒtKj|ƒtLj|ƒtMj|ƒtNj|ƒtO|ƒt"jP|ƒtQj|ƒtRj|ƒtSj|ƒtT|ƒtUj|ƒtV|ƒtWj|ƒtXj|ƒ|jYt jZƒ}|rët[|t j\|ƒn|jYt j]ƒ}|rt[|t j^|ƒn|jYt j_ƒ}|rGt[|t j`|ƒn|jYt jaƒ}|rut[|t jb|ƒn|jYt jcƒ}|r£t[|t jd|ƒn|jYt jeƒ}|rÑt[|t jf|ƒn|jgdƒ|jhdƒt
j|ƒtj|ƒdS(s2 Íæ¼ÒµÇ¼ÐèÒª´¦ÀíµÄÄÚÈÝ£¬±¾·þ¼°¿ç·þ·þÎñÆ÷·Ö¿ª
    Nièi(it SetLoginTimeRtGetCurrentDataTimeStrtInitPlayerPackRtDoPlayerLoginInMaptDataRecordPacktDR_PlayerLogint EventReporttWriteEvent_loginRtGetPlayerLeaveServerSecondRtDef_PlayerOfflineProtectTimetNomalDictSetPropertyt Def_Player_Dict_PlayChangeLineIDt Def_Player_Dict_FuncChangeLineIDt Def_Player_Dict_HighChangeLineIDt GetCrossMapIDRt__FirstLoginOnEntert
TurnAttackRtSyncGuideStatet ItemControlertSyncOnLineTimeTotaltSyncTrainRealmLVtPlayerPrestigeSystOnLogintPlayerBillboardtBillboardOnLogint__SyncPlayerInfoExt
PlayerCointPlayerGoldGiftt GameFuncCommtSync_FuncOpenStatet PlayerSignDaytSignDayOnLogint PlayerHorsetPlayerHorseLogint
PlayerFaQitPlayerFaQiLogint PlayerLianTitPlayerTreasuretOnTreasureLogintFBCommont    FBOnLogintPlayerGoldInvestt PlayerSuccesst SuccOnLogint PlayerCharmt
PlayerLoveRt PlayerArenatNotifyPlayerAllCurrencytNotifyUseMoneyTotaltPlayerActTotalRechargetPlayerActGrowupBuytPlayerSpringSaletPlayerFlashGiftbagtPlayerDailyGiftbagtPlayerFlashSaletPlayerActBuyOnetPlayerActFamilyCTGAssisttPlayerActCollectWordstChItemtSync_ItemDayUseCnttFunctionNPCCommontShopItemOnLogintPlayerFreeGoodstPlayerActBuyCountGiftt PlayerActTasktPlayerActYunshitPlayerActLoginNewtPlayerActLianqitPlayerActGodGifttPlayerActManyDayRechargetPlayerActSingleRechargetPlayerActTurntabletSyncPackDownloadAwardtDoFuncOpenLogict
PlayerDogztPlayerWishingWelltPlayerLuckyTreasuretSyncLittleHelpertPlayerFBtSync_CreateRoleAwardInfotPlayerCustomAwardtPlayerFuncSysPrivilegetNomalDictGetPropertytDef_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¾
 
 
 
 
 
 
      cCsÚtjd|jƒƒtjƒr%nbtjƒj|ƒtj|ƒtj||ƒt    j|ƒt
j|ƒt j|ƒt j|ƒt j|ƒtj|ƒtj|ƒtj|ƒtj|ƒtj|ƒtj|ƒt|ƒtj|ƒtj|ƒtj|ƒtj|ƒtj|ƒtj|ƒtj|ƒtj|ƒtj|ƒtj|ƒt|ƒt |dƒ|j!t"j#ƒ}t$|gƒ}tj%ƒj&|j'ƒddd|t(|ƒƒdS(s     Íæ¼Ò×îÖյǼ³É¹¦´¦Àí£¬ ÓÉ  GameServerRefresh GameSever_PlayerInitOK  µ÷ÓÃ
        ¸Ãº¯ÊýΪµØÍ¼×îÖյǼ³É¹¦²Å»áÖ´Ðе½£¬ÒÔºóһЩ¹¦ÄÜÀàµÄµÇ¼´¦Àí½¨Òé¾ùдµ½ÕâÀï
        ¾ÉµÄ¹¦ÄÜÏȲ»¶¯( __DoPlayerLoginServer º¯ÊýÖеŦÄÜ)£¬Èç¹ûÓеǼÏà¹ØµÄbugÔÙ¿¼ÂÇÊÇ·ñÒÆ¶¯µ½´Ëº¯Êý
    sMapServer->DoPlayerRealLoginOKiitPlayerRealLoginOKN()RRRRt PyMongoMaint GetUserCtrlDBRt GMT_BroadCastt PlayerFamilyt
PlayerHerot
PlayerMailt    PlayerHJGtPlayerXiangongt PlayerGubaotPlayerZhanlingt
PlayerTaskt
PlayerTreetPlayerGoldRushtPlayerActFamilyGCZt
PlayerTalkt SyncADCntInfotUpdatePlayerNametPlayerActivityt
PlayerLLMJt PlayerBeautyt PlayerTravelt PlayerMinggetOpenServerActivityt PlayerPresetRtPlayerActLunhuidiant__OnFixVersiontSyncOnlineStateToCrosst GetDictByKeyRt!Def_PlayerKey_MixServerFirstLoginRRRBtGetIDRC(R    RtisMixServerFirstLogintmsg((sgD:\SG_ServerCode\ServerPython\ZoneServerGroup\map1_8G\MapServer\MapServerData\Script\Player\ChPlayer.pytDoPlayerRealLoginOKzsD             
 
 .cCs|jƒ}d}|jtjƒ}|s…|jƒ}|jdƒd}tjd|jddƒƒ}tj    d||f|ƒn||kr©tj    d||ƒd    Stj
d
||f|ƒd}||krþt j ||ƒt j|tj|ƒnt j|tj|ƒd    S( sº ÐÞÕýÏßÉÏÍæ¼ÒÊý¾ÝÄÚÈÝ
    Ã¿´ÎÓÐÐèÒªÐÞÕýʱ£¬Ö»Òª¶¨ÒåÒ»¸öеÄϵͳÄÚÈݰ汾ºÅ  sysFixVersion , È»ºóÍæ¼Ò¸ù¾Ý×ÔÉí°æ±¾ºÅ½øÐÐÖð²½ÐÞÕý¼´¿É
    ÕâÑùÖ»Óõ½Ò»¸ökey¼´¿É£¬²»ÐèҪÿ´Î¶¼¶¨ÒåеÄkey
    iÄì´xs is%s00s-R-sĬÈÏÊý¾Ý°æ±¾Îª´´½ÇÈÕÆÚ: %s, %ss0Íæ¼Òµ±Ç°Êý¾Ý°æ±¾ºÅÒÑÊÇ×îа汾! playerVersion=%sNsDÍæ¼Òµ±Ç°Êý¾Ý°æ±¾ºÅ²»µÈÓÚϵͳ°æ±¾ºÅ£¬¿ªÊ¼ÐÞÕý! playerVersion=%s != %s(RRpRtDef_Player_Dict_FixVersiontGetCreateRoleTimetsplitRtToIntDeftreplacetDebugLogRtChEquiptFixRoleEquipHPRR((R    tplayerIDt sysFixVersiont playerVersiontcreateRoleTimetymdt
fixVersion((sgD:\SG_ServerCode\ServerPython\ZoneServerGroup\map1_8G\MapServer\MapServerData\Script\Player\ChPlayer.pyR ³s$    cCsli}g}tjƒrbtjƒjƒ}|dkrb||d<||kr_|j|ƒq_qbn||fS(NitcrossFamilyServerID(tDBFamilyt IsFamilyCrosst    DBDataMgrt GetFamilyMgrtGetCurCrossServerIDtappend(tdataExt serverIDListR¶((sgD:\SG_ServerCode\ServerPython\ZoneServerGroup\map1_8G\MapServer\MapServerData\Script\Player\ChPlayer.pytGetSyncCrossServerIDAndFuncInfoÖs  
 ic CsM|jƒ}tjƒ}|j|ƒ}|s1dStj|ƒ|tjkr]tj    |ƒnd}|tj
kr{d    }nt j ƒj ƒ}|jdƒ}|r¶|||kr¶dS|jd|ƒ|tjkrî|jƒdkrîdSntƒd}|sdS|jƒ}tj||ƒ}    i|    d6}
tjtj|
||ƒdS(
sˆÍæ¼Ò»ù´¡ÐÅÏ¢±ä¸üͬ²½¸üÐÂÆäËû¹¦ÄÜ£¬¿ÉÒÔÊÓΪͬ²½µ½ÒÔǰµÄGameServer
    ³ýÁËÏà¹Ø»ù´¡Öµ±ä»¯Í¬²½Í⣬ÉÏÏÂÏß״̬±ä¸üÒ²»á¸½´ø»ù´¡ÐÅÏ¢µÄͬ²½
    NiÐi<iètS2C_PlayerBaseInfoiitbaseInfoi`ê(RRRtFindCrossPlayerRŠtRefreshFamilyMembertIPY_PlayerDefinetCDBPlayerRefresh_PlayerNameR5tUpdatePlayerBillboardNametCDBPlayerRefresh_FightPowerRt GetGameWorldtGetTickR¢R7tCDBPlayerRefresh_LVRWR¿tPlayerViewCachetGetPlayerBaseViewInfotCrossMsgtSendToCrossServert ShareDefineRÀ( R    t refreshTypeR°tcrossPlayerMgrt crossPlayertsyncCDRt lastSyncTickR¾RÁtdataMsg((sgD:\SG_ServerCode\ServerPython\ZoneServerGroup\map1_8G\MapServer\MapServerData\Script\Player\ChPlayer.pytOnPlayerBaseInfoChangeçs6          cCs't}|d}t||||ƒdS(NRÁ(R>tUpdCrossPlayerFromMainServer(RÕt fromServerIDR°tisOnlineRÁ((sgD:\SG_ServerCode\ServerPython\ZoneServerGroup\map1_8G\MapServer\MapServerData\Script\Player\ChPlayer.pyRÀs
cCstjƒ}|j|ƒ}|s3|j|ƒ}ntj||| ƒ}|j||ƒtj|ƒ|s‰tj    |ƒ|j
|ƒn|S(N( RRRÂRRËtUpdPlayerBaseViewInfotUpdByViewCacheRŠRÃtOnCrossPlayerLogoutt DeletePlayer(RØR°RÁRÙRÑRÒtcurCache((sgD:\SG_ServerCode\ServerPython\ZoneServerGroup\map1_8G\MapServer\MapServerData\Script\Player\ChPlayer.pyR×s   cCsdtjƒ}xQt|jƒƒD]=}|j|ƒ}tj|ƒsIqnt|dt|ƒqWdS(Ni(RRtxranget OnlineCounttOnlineAttIsNormalPlayerR¡R(ttoCrossServerIDt playerManagertiR    ((sgD:\SG_ServerCode\ServerPython\ZoneServerGroup\map1_8G\MapServer\MapServerData\Script\Player\ChPlayer.pytSyncOnlinePlayerToCross4s c
CsÀ|jƒ}tjƒ}|s.|j|ƒntƒ\}}|sGdS|ri||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      cCsŠ|d}|d}t||||ƒ}tjƒjƒ}d|kr†|d}||kr†|rstj|ƒqƒtj|ƒq†ndS(sbÊÕµ½ÓÎÏ··þÍæ¼ÒÔÚÏß״̬ͬ²½
    ¿ç·þÊÕµ½ÔÚÏß״̬ͬ²½Ê±¶¼ÊÓΪÔÚ¿ç·þÉÏÏߣ¬ÐèÒª´¦Àí¿ç·þÔÚÏß/ÉÏÏßµÄÂß¼­
    ²»È»ÔÚ¿ç·þά»¤ÓÎÏ··þ²»Î¬»¤µÄÇé¿öÏ£¬µÈ¿ç·þÖØ¿ªºó£¬ÓÎÏ··þÖØÐÂͬ²½ÔÚÏßÍæ¼Ò£¬´ËʱÈç¹û¿ç·þ²»´¦ÀíµÇ¼Âß¼­£¬»áÉÙͬ²½·â°ü
    È繫»á£¬¿ç·þά»¤Ö®ºóµÇ¼µÄÍæ¼Ò»áÈ¡²»µ½¹«»áÊý¾Ý£¬µÈ¿ç·þÖØ¿ªºó£¬ÐèÊÓΪµÇÂ¼ÖØÐÂͬ²½
    Óë¿ç·þÖØÁ¬Ò»ÑùµÄµÀÀí£¬¶¼ÊÇÖØÐÂͬ²½ËùÓÐÐÅÏ¢
    RÙRÁR¶N(R×RRÈRöRŠtOnCrossPlayerLoginRÜ(RÕRØR°RÙRÁRÒt curServerIDR¶((sgD:\SG_ServerCode\ServerPython\ZoneServerGroup\map1_8G\MapServer\MapServerData\Script\Player\ChPlayer.pyRéZs
 
 
 
cCsHtjƒ}|jƒ|jƒ|_|jƒ|_tj||ƒdS(N(RGttagMCPlayerInfotCleartIsAdultR©tCreateRoleTimeR
R (R    t playerInfoEx((sgD:\SG_ServerCode\ServerPython\ZoneServerGroup\map1_8G\MapServer\MapServerData\Script\Player\ChPlayer.pyR7€s  
cCs"|jƒ}|jtjƒr"dStjd|ƒtj|dƒ|jdƒt    j
|t    j |ƒƒ|j ƒdkrŠt j|ƒntj|jƒ|jƒ|ƒtjddƒ}x0|D](\}}tj||jƒg|ƒqÂWtj|ƒtj|ƒtj|tjdƒdS(NsÍæ¼ÒÊǵÚÒ»´Î½øÈëÓÎÏ·iit MailLVAwardi(R¤RpRtDef_Player_Dict_FirstLoginRRR$tWriteEvent_Entryt SetFightPointR0tSetHPtGetMaxHPRWR:RgR"t DR_FirstLoginRItGetIPRRRt SendMailByKeyRR‹tOnPlayerFirstLoginR“tInitGoldEnergyR((R    R°tmailListt mailTypeKeyt mailItemList((sgD:\SG_ServerCode\ServerPython\ZoneServerGroup\map1_8G\MapServer\MapServerData\Script\Player\ChPlayer.pyR-‰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|ƒt!j"|dt#ƒdS(Ns'±¾´ÎºÏ·þÒѾ­µÇ¼¹ý. lastMixServerDay=%ss9Íæ¼ÒºÏ·þÊ׵Ǵ¦Àí! lastMixServerDay=%s,mixServerWorldLV=%sis    ÐºŲ»¸øºÏ·þ½±Àø!t    MixServert MixServerMailiiii–itMixServerWorldLVtLastMixServerDayt ItemWorldLVs3    ·¢ËͺϷþ²¹³¥Óʼþ: itemWorldLV=%s,addItemList=%st
MixServer1tgoldtsilvertdetailtisAll($RRÈtGetGameWorldDictByKeyRÏtDef_Notify_WorldKey_IsMixServerRt$Def_Notify_WorldKey_LastMixServerDayRpRtDef_PDict_MixLoginDayR­t(Def_Notify_WorldKey_LastMixServerWorldLVRRR(RWR7R£R<t ResetDaySignR8tDoResetCTGCountRRt
GetFuncCfgtmaxt GetGameDatatGetItemByTypeIDtGetEffectByIndext GetEffectIDtDef_Effect_ItemAddLVtGetEffectValueRùR5t"UpdatePlayerBillboardOnLeaveServerR>(R    t isMixServerR°tlastMixServerDayt    playerDaytmixServerWorldLVRþtworldLVMailItemListt mailMoneyListt worldLVDownt itemWorldLVRRtworldLVItemListtitemIDt    itemCounttisBindtitemDatatcurEfftcurEffIDtlvLimitt
detailDictt addItemList((sgD:\SG_ServerCode\ServerPython\ZoneServerGroup\map1_8G\MapServer\MapServerData\Script\Player\ChPlayer.pyt__DoMixServerFirstLogin¸sZ      
(cCs0tj|tjdƒtj|tjdƒdS(Ni(RR(RtDef_Player_Dict_PlayerDeadCnttDef_Player_Dict_DeadTime(R    ((sgD:\SG_ServerCode\ServerPython\ZoneServerGroup\map1_8G\MapServer\MapServerData\Script\Player\ChPlayer.pytClearPlayerDeadInfoùscCsg|jƒ}x*tjD]}|j|ƒ}|jƒqWx'tjjƒD]}tj||ƒqIWdS(N(    tGetItemManagerRt Def_PlayerLoginInitPackIndexListtGetPackt Sync_RefreshtDef_VPackCnt_DicttkeysR0tSync_VPackItem_Refresh(R    t itemManagert    packIndextrolePack((sgD:\SG_ServerCode\ServerPython\ZoneServerGroup\map1_8G\MapServer\MapServerData\Script\Player\ChPlayer.pyt__Sync_PackDetels cCsÆtjƒ}|jƒg|_|jƒ}xrt|jƒƒD]^}|j|ƒ}tjƒ}|j    ƒ|_
|j ƒ|_ |j ƒ|_|jj|ƒq>Wt|jƒ|_tj||ƒdS(N(RGttagMCPlayerSkillsRítSkillstGetSkillManagertranget GetSkillCounttGetSkillByIndexttagPlayerSkillt
GetSkillIDtSkillIDt GetRemainTimet
RemainTimetGetProficiencyt ProficiencyR¼RCtCountR
R (R    tsendPackt skillManagerRåtcurSkillt    skillInfo((sgD:\SG_ServerCode\ServerPython\ZoneServerGroup\map1_8G\MapServer\MapServerData\Script\Player\ChPlayer.pyt__Sync_ClientSkill0s 
      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.pyR:Hs
cCsQtjƒ}|jƒ|jƒ|_|jƒ|_d|_tj    ||ƒdS(Nic(
t ChNetSendPackttagClearObjBuffRítGetGameObjTypetObjTypeR¤tObjIDtBuffTypeR
R (R    t
clientPack((sgD:\SG_ServerCode\ServerPython\ZoneServerGroup\map1_8G\MapServer\MapServerData\Script\Player\ChPlayer.pyRMRs 
    cCs|jtƒ|jtƒ|jtƒ|jtƒ|jtƒt||ƒtjƒj    ƒt
j kr‚t j |tj|ƒn|jƒ|jƒkr³tj||jƒƒn|jƒdkrØtj|dƒntj||ƒtjƒr|jtƒntj|ƒ}|jƒtjƒr9|jtƒn|j|ƒ|j|ƒ|j tj!|ƒtj"||ƒt#|ƒtt$_%dS(Ni(&t
SetCanMoveRt    SetInitOKt SetMapLoadOKR=t SetCanAttackt__CheckClearBuffOnMapChangeRtGetMapt GetMapFBTypeR3tfbtNullt SkillCommontAddBuffBySkillType_NoRefurbishRtDef_SkillID_LimitSuperBufft GetSightLevelR¤RtSetPlayerSightLeveltGetSightR?R;tChangePlayerSighRRRtGetOnlinePlayert ReCalcAllAttrR>tSetProcessEquipDurgTickt SetLoginTickR7tDef_PlayerKey_CalcOLTimeTicktRefreshRebornPointtSavePlayerMessionInDataServert
PyGameDatatg_needRefreshMapServerState(R    RtolPlayer((sgD:\SG_ServerCode\ServerPython\ZoneServerGroup\map1_8G\MapServer\MapServerData\Script\Player\ChPlayer.pyR!as4       
 
    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( RRaRt ReadChConfigtGetEvalChConfigtitemst    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.pyRq±scCstjtƒ||ƒdS(N(Rt GetPsycoFunct__Func_PlayerLogin(RR((sgD:\SG_ServerCode\ServerPython\ZoneServerGroup\map1_8G\MapServer\MapServerData\Script\Player\ChPlayer.pyt PlayerLogin¿scCs²tjƒj|ƒ}y\t||ƒt||ƒ|jtƒ|jƒt||ƒt    ||ƒt
||ƒWn:|j t j ƒddl}tjd|jƒƒnXdS(NiÿÿÿÿsÍæ¼ÒÉÏÏßÂß¼­´íÎó
%s(RRRR
RR\RtSendToBServerServerInitOKR t__Func_LoadMapOKR§tKickR3tdisWaitForPlayerLoinErrort    tracebacktRaiseExceptiont
format_exc(RRR    Rˆ((sgD:\SG_ServerCode\ServerPython\ZoneServerGroup\map1_8G\MapServer\MapServerData\Script\Player\ChPlayer.pyR‚És   
   cCstjtƒ||ƒdS(N(RRt__Func_ChangeMapInit(RR((sgD:\SG_ServerCode\ServerPython\ZoneServerGroup\map1_8G\MapServer\MapServerData\Script\Player\ChPlayer.pyt ChangeMapInitéscCs¦tjƒj|ƒ}t||ƒtj||ƒt|ƒt||ƒ|jƒtj    ƒj
ƒt j kr~|j dƒn |j dƒ|jƒ|jtƒdS(Nii(RRRR
RdtPlayerChangeMapUpdateSkillCDR R!tInitChangeMapPlayerSummonInfoRaRbR3tfbtTeamtGameServer_TeamEnterFBt#BalanceServer_PlayerChangeMapInitOKR\R(RRR    ((sgD:\SG_ServerCode\ServerPython\ZoneServerGroup\map1_8G\MapServer\MapServerData\Script\Player\ChPlayer.pyR‹ós
 
     
 
cCstj|tjdtdtƒtj|tjƒtj|tjdtƒtj|tj    ƒtj|tj
dtdtƒtj|tj dtdtƒtj|tj dtdtƒtj|tj dtdtƒtj|tjƒtj|ƒt|ƒtj|ƒdS(Nt
defaultMaxtisSync(RtInit_PackCountR3trptEquipR>RtrptItemt rptIdentifyRÏtrptHerot
rptMGGuayut rptMGTuiyant rptTempSwapt rptTempItemt rptTreasuret
ItemCommontSyncPackBuyCntR9R0tCheckGiveBindMoneyTypeItem(R    ((sgD:\SG_ServerCode\ServerPython\ZoneServerGroup\map1_8G\MapServer\MapServerData\Script\Player\ChPlayer.pyR 2s 
 cCstj}t||ƒS(N(RRftCheckHasBuffBySkillID(R    tskillID((sgD:\SG_ServerCode\ServerPython\ZoneServerGroup\map1_8G\MapServer\MapServerData\Script\Player\ChPlayer.pyt__CheckLimitSuperBuffws    cCstjƒj|ƒ}|s9tjd||jƒƒtStj|ƒ}tj||ƒ}|dkrjtS|d}|j    ƒ}|j
|ƒ}|s™tSt S(Ns,Íæ¼ÒÈ¡Ïûbuffʧ°Ü,Êý¾Ý¿âÎÞ´Ëbuff,buffid = %s i(( RRtGetSkillBySkillIDRRRRdt 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 ƒt"|ƒsÛ|j#t ƒn|j$t ƒt j%|t ƒt&j'||ƒtj(||ƒtj)ƒ}|jƒ}|jƒ}|j*tj+ƒrÃ|j*tj+ƒdkr|t j |ƒj,ƒn.t-j.||tj/ƒ\}}|j0||ƒt j1|tj+dƒntj|ƒdksí|j2ƒtj krB|jtj3ƒ}|rtj4ntj5}    tj6ƒr/tj5}    nt7||    |ƒn½|j8||ƒt krÿt-j.||tj/ƒ\}
} |
dkrÌ| dkrÌtjd||f|j    ƒƒt j |ƒ} | j,ƒqÿ|j0|
| ƒtjd|
| f|j    ƒƒn|j9ƒtj:krwt;j<tj)ƒj=ƒƒtj>krw|j?tj:ƒt@jA|tjB|ƒt@jA|tjC|ƒn|jDƒ} |jEƒ| krÀ|jF| ƒtG|ƒtjHd| ƒntIjJ|ƒtKjL|ƒ|jMƒt S(Ns'Íæ¼Ò¸±±¾Öбä¸ü¹¦ÄÜÏß·ÐéÄâÇеØÍ¼³É¹¦!!!is µØÍ¼¶ÁÈ¡³É¹¦is:Íæ¼ÒµÇÂ¼ÖØÖÃλÖÃʧ°Ü, °ÑÍæ¼Ò´ò»ØÖØÉúµã posX = %s posY = %ss<Íæ¼ÒµÇÂ¼ÖØÖÃλÖÃʧ°Ü, ÉèÖø½½üµã nearPosX = %s nearPosY = %ss½øÈëµØÍ¼Ç¿ÖÆÇл»PKģʽ: %s(NRRRt GetMapLoadOKR¢RtDef_PlayerKey_ResetFBLinePosXtDef_PlayerKey_ResetFBLinePosYRRR7R=R>RR?RAR@R t    DoEnterFBt__CheckForbidLoginR^tInitPosRƒR…RgR¤RhRiR0R1tSetPlayerActionR3R4R]R£R_R\tSetIsNeedProcesst PlayerGMOpert DoGMOperLogictDoEnterFBLogicRaRptDef_PDict_IsReBorntSetToBornPlacetGameMaptGetNearbyPosByDistDef_RebornPos_Area_RangetResetPosR(R2R trebornType_CityR6RR5tCanMoveRÒtCampType_NeutralREtGetRecordMapIDRtDef_MapID_NeedCampt
SetFactionRyRztDef_SkillID_JusticetDef_SkillID_EviltGetInitAttackModelR¸t SetAttackModet SyncPKModelR­tPassiveBuffEffMngtOnLoadMapGFPassivet PlayerYinjit    OnLoadMapt
EndLoadMap(RRR    tresetFBLinePosXtresetFBLinePosYtcurMaptposXtposYtisLogint
rebornTypetnearPosXtnearPosYRDtinitAttackModel((sgD:\SG_ServerCode\ServerPython\ZoneServerGroup\map1_8G\MapServer\MapServerData\Script\Player\ChPlayer.pyR…ŸsŒ   
 
 
    *    #$  
 
cCs9tjƒ}|jƒ|jƒ|_tj||ƒdS(N(RGttagMCAttackModeRíR¸tModeR
R (R    RH((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;scCs:|jƒtdtjƒ@dkr&tS|jtjƒdS(Nii(RNtpowRtDef_PysForbidByPyR>R†R3t    disGMKick(R    ((sgD:\SG_ServerCode\ServerPython\ZoneServerGroup\map1_8G\MapServer\MapServerData\Script\Player\ChPlayer.pyR³Ss"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(RRRtPointAttrIDListtPointValueListRCt    enumerateRtGetIpyGameDataR˜R­t SetFreePointRpRtDef_PDict_AddPointValueRR(tNotifyPlayerBasePointtRefreshPlayerAttrState(RRRR    tpointAttrIDListtpointValueListtneedTotalPointRåtattrIDt curFreePointtaddPointtcurPointtupdPointRD((sgD:\SG_ServerCode\ServerPython\ZoneServerGroup\map1_8G\MapServer\MapServerData\Script\Player\ChPlayer.pyt
OnAddPointds2        &  
 
! 
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(RRRRtIPY_DataRßtGetRolePointCounttGetRolePointByIndext    GetAttrIDRRpRRæR>R­RWRRR/R1R3R–RžtGetItem_FromPack_ByIDtGetAttCheckItemCanUsetGetItemRemainingTimet
ReduceItemtItemDel_ResetAttrPoint(RRRR    t
ipyDataMgrtcanResetIDListtcanResetRìRïtisFreetneedItemIDListtitemPacktdelIndext
expireTimeR"t    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öRpRRæR¼RGttagMCRolePointInfoRáRâRCtPointAttrIDCountR
R (    R    tsyncAttrIDListRýRRéRêRìRït    pointInfo((sgD:\SG_ServerCode\ServerPython\ZoneServerGroup\map1_8G\MapServer\MapServerData\Script\Player\ChPlayer.pyRç»s 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ÿÿÿÿ(RRRt__CheckPlayerCanMoveRaRÁR„R†tStopMovet    ChangePosRGttagMCMoveByTypeRíR¤tIDRWRXtMoveTypeRt PyNotifyAllR(RRRR    RH((sgD:\SG_ServerCode\ServerPython\ZoneServerGroup\map1_8G\MapServer\MapServerData\Script\Player\ChPlayer.pyt OnMoveByTypeÜs  
 
   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ÿÿÿÿ(RRRt GetTickByTypeRtTYPE_Player_Tick_RushtTYPE_Player_Tick_Timet SetTickByTypeRRaRÁR„R†RRRGt    tagMCRushRíR¤RRWRXRRR(RRRR    RH((sgD:\SG_ServerCode\ServerPython\ZoneServerGroup\map1_8G\MapServer\MapServerData\Script\Player\ChPlayer.pyt OnPlayerRushs$& 
 
  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(RRRtOperControlManagertIsObjCanDoActionRtDef_Obj_ActState_ServerActR3toalMoveRRtStartXtStartYtDestXtDestYt    WorldTickRaRÁR¿RƒR…R¢R7tGetPlayerVehicletpvNulltpvHorset CheckMovePostGetDistRtDelLimitSuperBuffR( RRRR    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
GetCanMoveR0R1RR RR!R3R"RtPlayerCanStateTransferR>(R    ((sgD:\SG_ServerCode\ServerPython\ZoneServerGroup\map1_8G\MapServer\MapServerData\Script\Player\ChPlayer.pyR…s   cCsdStjƒ}tj||||ƒs6|jƒdSt|||||||ƒsXdStj|tjƒ|j    ||ƒdS(N(
RRaRtPlayerMoveCheckClientWorldTicktSync_ClientTickR+tChangePlayerActionR3tpaNulltMove(R    t client_StartXt client_StartYt client_DestXt client_DestYtclientWorldTickRRÒ((sgD:\SG_ServerCode\ServerPython\ZoneServerGroup\map1_8G\MapServer\MapServerData\Script\Player\ChPlayer.pytPlayerNormalMove°s 
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(RtPlayerRefreshPosR¤R¿RƒR…RRÁtMoveFailRR,RtDef_PlayerMaxMoveDistR>( R    tcheckObjRÒtstartXtstartYtdestXtdestYtsendPlayerMoveFailtobjPosXtobjPosYtmoveDist((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(RRRR3tIPY_CCliectReborntGetTypeR­RRRR,tOnReqCrossServerRebornR tDoFBForbidRebornt
NotifyCodeR5tPlayerReborn_InFB(RRR    RHRÖ((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 checkHPStateRKt
RebornTypes(¿ç·þÖÐÇëÇó¸´»î, crossMapID=%s,msgDict=%s(
RR,RR­t__CheckCanRebornRRtSendMsgToCrossServerRÏtClientServerMsg_Reborn(R    RÖt
crossMapIDtmsgDict((sgD:\SG_ServerCode\ServerPython\ZoneServerGroup\map1_8G\MapServer\MapServerData\Script\Player\ChPlayer.pyRQ(s  cCsŒ|d}tjƒ}t|||ƒs,dS|jtjƒ}t|||ƒidd6|d6}|j|ƒtjt    j
||gƒdS(NRWitResultt ReviveTired( RRaRXRpRtDef_PDict_IsAddReviveTiredt__DoPlayerRebornRètSendMsgToClientServerRÏtCrossServerMsg_RebornRet(R    tmsgDatat serverGroupIDRRÖtgameMaptisAddReviveTiredRE((sgD:\SG_ServerCode\ServerPython\ZoneServerGroup\map1_8G\MapServer\MapServerData\Script\Player\ChPlayer.pyRZ8s
  cCsX|d}|dkrdS|d}|d}t||tƒ|rTt||ƒndS(NR]iRWR^(t __RebornCostR>t__AddReviveTired(R    RcRtresultRÖRf((sgD:\SG_ServerCode\ServerPython\ZoneServerGroup\map1_8G\MapServer\MapServerData\Script\Player\ChPlayer.pyRbJs
 
 
cCs`tjƒ}|jƒ|jƒ|_||_|jƒ|_|jƒ|_    t
j ||ƒdS(N( RUttagPlayerRebornRíRRKtTypeRƒR„R…R†R
R (R    RÖt
rebornInfo((sgD:\SG_ServerCode\ServerPython\ZoneServerGroup\map1_8G\MapServer\MapServerData\Script\Player\ChPlayer.pytSyncPlayerRebornZs 
    cCstjtƒ||ƒdS(N(RRt__Func_PlayerDisconnect(RR((sgD:\SG_ServerCode\ServerPython\ZoneServerGroup\map1_8G\MapServer\MapServerData\Script\Player\ChPlayer.pytPlayerDisconnectjscCswtjƒj|ƒ}yt||ƒWn*ddl}tjd|jƒƒnXtjt    |ƒƒ|j
|ƒdS(NiÿÿÿÿsÍæ¼ÒÏÂÏßÂß¼­´íÎó
%s( RRRtDoPlayerDisconnectRˆR‰RŠRt    MapCallDBtGetPackSaveDatat DoDisconnect(RRR    Rˆ((sgD:\SG_ServerCode\ServerPython\ZoneServerGroup\map1_8G\MapServer\MapServerData\Script\Player\ChPlayer.pyRnss cCsOtj|jƒƒ}d}tj|tjƒ}tj|t|ƒ|ƒ}|S(NR-(    tbase64t    b64decodet GetPackDatatCommFunct    WriteBYTEtIPY_ServerDefinet    gstUpdatet WriteStringRC(R    t roleSaveDatatallData((sgD:\SG_ServerCode\ServerPython\ZoneServerGroup\map1_8G\MapServer\MapServerData\Script\Player\ChPlayer.pyRr€s
cCstjd|jƒƒtj||ƒ|jtjƒƒtj|ƒtj    |t
j dƒtj    |t
j dƒt j|ƒt|dƒtj|ƒdS(NsPlayerDisconnect!i(RRRRtPlayerLeaveServert SetLogoffTimeRR"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.pyRps    cCsƒtjƒj|ƒ}tjƒ}|jƒ}tj|ƒs\d}tjd|jƒƒdSt    |ƒdkrrdS|j
|ƒdS(NR-sSetShutCutData Encoding Errid( RRRR3tIPY_CSetShutCutDatat
GetSettingtEncodingToUnicodetErrLogR¤RCt
SetSetting(RRR    RHtsetting((sgD:\SG_ServerCode\ServerPython\ZoneServerGroup\map1_8G\MapServer\MapServerData\Script\Player\ChPlayer.pytSetShutcutSettingHV½s   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(RRRRtKeyNumtSetDataR¬RR¹t GetGameRecMgrtGetRecTypeIDMgrRÏtDef_GameRecType_Settingt GetOneRecDataR>t GetUserDicttpoptNoneRCRˆR( RRRR    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’R4RR«R”RGttagSCSettingDataRŒRRCtDataLenR¼ttagSCSettingDataInfotSettingDataListtDataCntR
R ( R    R—R°R˜R™RšR›tsettingDataListt syncKeyListR–R•tsDataR[((sgD:\SG_ServerCode\ServerPython\ZoneServerGroup\map1_8G\MapServer\MapServerData\Script\Player\ChPlayer.pyRôs8                      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(RRRtSetNumRtLittleHelperSetNumCountRˆRRßtLittleHelperValueCountthasattrtgetattrRR(t!Def_Player_Dict_LittleHelperValueR­(RRRR    tsetNumRåtvalue((sgD:\SG_ServerCode\ServerPython\ZoneServerGroup\map1_8G\MapServer\MapServerData\Script\Player\ChPlayer.pytOnSetLittleHelper!    s      '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¨RpR«RGttagMCLittleHelperFuncSetR¦R©tsetattrR¼ttagMCLittleHelperSett FuncSetListRCt FuncSetCountR
R (R    t funcSetListR¬tfuncSetRåR­tsetPack((sgD:\SG_ServerCode\ServerPython\ZoneServerGroup\map1_8G\MapServer\MapServerData\Script\Player\ChPlayer.pyRk0    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(RRRt
GuideIndextIsOKRÝRßRtDef_GuideStateKeyCountRR(tDef_Player_Dict_GuideStateR­RˆtSetDictValueByBit(RRRR    t
guideIndextisOKR­Rå((sgD:\SG_ServerCode\ServerPython\ZoneServerGroup\map1_8G\MapServer\MapServerData\Script\Player\ChPlayer.pyt OnSetGuideOKR    s         cCsutjƒ}g|_x7ttjƒD]&}|jj|jtj|ƒƒq%Wt    |jƒ|_
t j ||ƒdS(N( RGttagMCGuideStatet
GuideStateRßRR¹R¼RpRºRCRGR
R (R    tguideStatePackRå((sgD:\SG_ServerCode\ServerPython\ZoneServerGroup\map1_8G\MapServer\MapServerData\Script\Player\ChPlayer.pyR/g    s     $cCs)tjƒ}||_tj||ƒdS(N(RGttagMCShowGuidetGuideIDR
R (R    tguideIDt    showGuide((sgD:\SG_ServerCode\ServerPython\ZoneServerGroup\map1_8G\MapServer\MapServerData\Script\Player\ChPlayer.pyt    ShowGuideq    s     cCsKtjƒj|ƒ}|sdS|jƒ}|jƒ}||krGdSdS(N(RRRtGetPlayerLastActionR2(RRR    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( RRRR3tIPY_CSetHPRestoretGetValuetSetHPRestoreSettingR0R1RtPlayerAutoRestoreHP(RRR    RHtcurValue((sgD:\SG_ServerCode\ServerPython\ZoneServerGroup\map1_8G\MapServer\MapServerData\Script\Player\ChPlayer.pyR•š    s   cCs‚tjƒj|ƒ}tjƒ}|jƒ}|dksE|dkrIdS|j|ƒtj|ƒdkr~t    j
||ƒndS(Niid( RRRR3tIPY_CSetMPRestoreRÌtSetMPRestoreSettingR0R1RtPlayerAutoRestoreMP(RRR    RHRÏ((sgD:\SG_ServerCode\ServerPython\ZoneServerGroup\map1_8G\MapServer\MapServerData\Script\Player\ChPlayer.pyR—¸    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( R3tamPeacetamMaxRR­R¸RatGetAttackModelsRÝt    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(RRRtAdultt ChangeAdult(RRRR    tadult((sgD:\SG_ServerCode\ServerPython\ZoneServerGroup\map1_8G\MapServer\MapServerData\Script\Player\ChPlayer.pyt
PySetAdultï    s cCs\|jƒsdStj|ƒdkr)dStj|ƒtkrBdS|jƒtkrXdStS(Ni(R¯R0R1RR6R>R5(R    ((sgD:\SG_ServerCode\ServerPython\ZoneServerGroup\map1_8G\MapServer\MapServerData\Script\Player\ChPlayer.pytCheckPlayerStopMoveú    s cCstjtƒ||ƒdS(N(RRt__Func_PlayerCanResetWorldPos(RR((sgD:\SG_ServerCode\ServerPython\ZoneServerGroup\map1_8G\MapServer\MapServerData\Script\Player\ChPlayer.pytPlayerCanResetWorldPos
scCs)tjƒj|ƒ}tj||ƒdS(N(RRRRtDoPlayerResetWorldPos(RRR    ((sgD:\SG_ServerCode\ServerPython\ZoneServerGroup\map1_8G\MapServer\MapServerData\Script\Player\ChPlayer.pyRà
scCs-tjƒj|ƒ}|jƒt|ƒdS(N(RRRt    ExitEventtNotifyChangeMapFail(RRR    ((sgD:\SG_ServerCode\ServerPython\ZoneServerGroup\map1_8G\MapServer\MapServerData\Script\Player\ChPlayer.pytPlayerChangeMapFailCallback*
s
 
cCsM|jtƒtjƒ}|jƒtj||ƒtjd|j    ƒƒdS(Ns µØÍ¼Çл»Ê§°Ü(
R=R>RGttagMCChangeMapFailRíR
R RRR¤(R    RH((sgD:\SG_ServerCode\ServerPython\ZoneServerGroup\map1_8G\MapServer\MapServerData\Script\Player\ChPlayer.pyRä3
s   
cCs&tjƒj|ƒ}t||ƒdS(N(RRRt __Func_ExitFB(RRR    ((sgD:\SG_ServerCode\ServerPython\ZoneServerGroup\map1_8G\MapServer\MapServerData\Script\Player\ChPlayer.pytExitFBN
s cCs‘tjƒjƒtjkr=|jƒtjddƒkr=dStjd|j    ƒ|j
ƒƒt j |ƒspdSt j ||ƒtj|ƒdS(NtMapLineisÍæ¼Ò = %s , Ö÷¶¯À뿪¸±±¾(RRaRbR3RcRRRRtGetNameR¤R tCanPlayerLeaveFBtDoPlayerLeaveFBRt PlayerLeaveFB(R    R((sgD:\SG_ServerCode\ServerPython\ZoneServerGroup\map1_8G\MapServer\MapServerData\Script\Player\ChPlayer.pyRçX
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(RRRR3tIPY_CChangeLinetGetLineRˆR¤RRRRRt__CheckCanChangLineRtPlayerChangeLine(    RRR    RHt changLineIDtmapIDtactivityLineIDtactivityMapLineDictt mapLineDict((sgD:\SG_ServerCode\ServerPython\ZoneServerGroup\map1_8G\MapServer\MapServerData\Script\Player\ChPlayer.pyt
ChangeLiney
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_TickRRSRR2R3tpaSitt 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(R0R1R2R3R4RRÀtrebornType_MainCityRRaRbRcRRRERÃRtgetRpR_Rdt FindBuffByIDtDef_SkillID_ReviveTiredtGetSkillt
GetSkillLVt GetSkillMaxLV(R    RÖtmapTypetfbRebornTimeDictR|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(RpRR-tintttimeRR­R(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)(R0R1R2R3R4RmRtDef_RebornTypeListRtrebornType_HealthtrebornType_UseItemtGetLocalRebornRRˆRRRRRpR-RRSRRRgRR t OnCanFBRebornR>(R    RÖReRVR°trebornCDtcurTimetdeadTime((sgD:\SG_ServerCode\ServerPython\ZoneServerGroup\map1_8G\MapServer\MapServerData\Script\Player\ChPlayer.pyRXò
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(NRiis%»õ±Ò²»×㣬ÎÞ·¨Ô­µØ¸´»î! moneyPrice=%ss¸´»îµÀ¾ß²»×㣬ÎÞ·¨Ô­µØ¸´»î! tReborn(RR,RRRRRt HaveMoneyExRÏtTYPE_Price_Gold_Paper_MoneyRRˆRtDef_Cost_ReviveRRžtFindItemInPackByEffectExtDef_Effect_ReborntDelItemR>( R    RÖtisDoCostR[R°t    rebornCfgt
moneyPricet costMoneyListt    moneyTypetmoneyCntt
rebornItem((sgD:\SG_ServerCode\ServerPython\ZoneServerGroup\map1_8G\MapServer\MapServerData\Script\Player\ChPlayer.pyRg s* 
c
    Csrtj}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|ƒƒtj ||ƒt!j"ƒ}    |tjkrÈ| st!j"ƒj#|j$ƒ|j%ƒƒ s|tj
kr!|    j&ƒ|j'ƒkr!|j(ƒn:|tj
kr[tj)||    j&ƒ|    j*ƒ|    j+ƒƒntj,|t-j.ƒdS(NiitPKConfigiiè(/RtDef_MaxRateValueRRÀR tOnPlayerRebornR>RR(RºRR tOnResetFBRebornPlacePosRdReRfRpR_RhRRR;t IsInPKStatetSetPKStateTickt IsInBossStatetSetBossStateTicktRefreshAllStateR0RõRöt    SetProDeft GetMaxProDeftOnPlayerRebornOverRRaRÁRƒR…R‡RR»tPlayerResetWorldPost GetRebornMapXt GetRebornMapYR9R3R:(
R    RÖRt mapBornPlacetisAddSuperBufftresetHpPercentt
isFBRebornt    validTimeRDRe((sgD:\SG_ServerCode\ServerPython\ZoneServerGroup\map1_8G\MapServer\MapServerData\Script\Player\ChPlayer.pyR`: sD          
$ %' +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( RdRRR    R
R R ReRR­RR(R_(R    RRt buffSkillLV((sgD:\SG_ServerCode\ServerPython\ZoneServerGroup\map1_8G\MapServer\MapServerData\Script\Player\ChPlayer.pyRhy scCsatjƒ}t|||ƒs"dStjƒsGt||tƒsGdSnt|||||ƒtS(s Íæ¼Ò¸´»î
    N(RRaRXRRgR>R`(R    RÖRR=R>Re((sgD:\SG_ServerCode\ServerPython\ZoneServerGroup\map1_8G\MapServer\MapServerData\Script\Player\ChPlayer.pyR5‡ s  cCs<tjƒjƒ}|tjkr%dStj|||ƒdS(N(RRaRbR3RcR t DoFBOnReborn(R    RÖRR ((sgD:\SG_ServerCode\ServerPython\ZoneServerGroup\map1_8G\MapServer\MapServerData\Script\Player\ChPlayer.pyRTœ s
cCsdS(N((RRR((sgD:\SG_ServerCode\ServerPython\ZoneServerGroup\map1_8G\MapServer\MapServerData\Script\Player\ChPlayer.pytOnEnterCrossServer® scCstjtƒ||ƒdS(N(RRt__Func_EnterFbGameEvent(RR((sgD:\SG_ServerCode\ServerPython\ZoneServerGroup\map1_8G\MapServer\MapServerData\Script\Player\ChPlayer.pytEnterFbGameEventÄ scCsPtjƒj|ƒ}tjƒ}|jƒ}|jƒ}tj|||ƒdS(N(    RRRR3tIPY_CEnterFbGameEventRRRt PlayerEnterFB(RRR    RHRótclientSendLineID((sgD:\SG_ServerCode\ServerPython\ZoneServerGroup\map1_8G\MapServer\MapServerData\Script\Player\ChPlayer.pyREÍ s    c
    Csntjƒj|ƒ}|j}|j}|j}|j}|j}|j}    t    ||||||||    ƒdS(N(
RRRRkR‚R€R„R†tExData1t__Func_WorldTransPort(
RR[RR    tpackTransportTypeRótlineIDRÓRÔtexData1((sgD:\SG_ServerCode\ServerPython\ZoneServerGroup\map1_8G\MapServer\MapServerData\Script\Player\ChPlayer.pytPYWorldTransPortâ 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-927DE1ACCC4F378ERMRN(ii(RRRtTYPE_Player_Tick_WorldTransportRRRRR­RtDef_PackType_TransportTypeR4RˆRRtCheckPlayerTransporttCheckTagCountrytGetTransportPosRStDef_Transport_Type_MissiontTransportVipLvRestricttPayForTransportR7tDef_PlayerKey_TransTypet
BeginTrans(
R    RLRóRÓRÔRRMRNR°t transportType((sgD:\SG_ServerCode\ServerPython\ZoneServerGroup\map1_8G\MapServer\MapServerData\Script\Player\ChPlayer.pyRKí s>&          c    Cs&tj||||||||ƒtS(N(RR:R(R    RóRÓRÔRMR¦tcanLockRN((sgD:\SG_ServerCode\ServerPython\ZoneServerGroup\map1_8G\MapServer\MapServerData\Script\Player\ChPlayer.pyRY. s"cCsX|jƒ|krNtjƒj||ƒsNtj||tjƒ\}}qNn||fS(N(RRRaRÁR¼R½RR¾(R    RZttransportMapIDt transportPosXt transportPosY((sgD:\SG_ServerCode\ServerPython\ZoneServerGroup\map1_8G\MapServer\MapServerData\Script\Player\ChPlayer.pyRTI 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(RRR>R/R1R3R–RžR÷tTransportPayMoneytTYPE_Price_Gold_PaperRR­RRû(R    RZR"tuseCountRRtitemListt    costMoney((sgD:\SG_ServerCode\ServerPython\ZoneServerGroup\map1_8G\MapServer\MapServerData\Script\Player\ChPlayer.pyRWe scCsdS(Ni((R    RZ((sgD:\SG_ServerCode\ServerPython\ZoneServerGroup\map1_8G\MapServer\MapServerData\Script\Player\ChPlayer.pyRV{ sc    CsŽtj|||ƒ}|gkr%tSxb|D]Z\}}|dkr,tj|||tji|d6ƒtj||dd||ƒq,q,WtS(Nit TransportType(    RR!RRRtDef_Cost_TransportRtLogin_Interface_GoldRecR>(R    R+tmoneyRZt    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(RRRvRwRRRlt ExchangeTimeRRRˆRÚtGetOfflineMinutesRtGetPlayerReExpRWtevalR!RRtDef_Cost_OffLineExptDef_Cost_Reason_SonKeytAddExpRtSetOfflineMinutestSyn_OfflineTimeQueryResult(Rt curPackDataRtOfflineExpChangeDictR    tmulIndext exchangeTimetrecListtminVIPLvRÛt
useMinutest haveMinutestrExptreLVtworldLvExpRatet    redeemExpt moneyInfoListR+RdRDt haveMoneyListR,t 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(RpRRqRR(RrRsRtRuRzR{R|R}t
ADCntOnDay(R    RR‚R…((sgD:\SG_ServerCode\ServerPython\ZoneServerGroup\map1_8G\MapServer\MapServerData\Script\Player\ChPlayer.pyt PlayerOnDayè s$
c
Csotjƒ}|j|ƒ}|j}|j}|j}tjd|||fƒ|tjkrrt    j
||ƒnù|tj kr”t    j ||ƒn×|tj kr¶tj||ƒnµ|tjkrØtj||ƒn“|tjkr÷t||ƒnt|tjkrtj|ƒnU|tjkr5tj|ƒn6|tjkrZtj|||ƒn|tjkr|tj ||ƒnï|tj!kržt"j#||ƒnÍ|tj$kr½t%||ƒn®|tj&krßt'j(||ƒnŒ|tj)krt*j+|||ƒng|tj,kr#t-j.|ƒnH|tj/krHt0j1|||ƒn#|tj2krjt3j4||ƒn|tj5krt6j7|||ƒnÜ|tj8kr´t9j:|||ƒn·|tj;krÙt<j=|||ƒn’|tj>krøt?j@|ƒns|tjAkrtBjC|||ƒnN|tjDkrBtEjF|||ƒn)|tjGkrgtHjI|||ƒn|tjJkrŒtKjL|||ƒnß|tjMkr±tNjO|||ƒnº|tjPkrÖtQjR|||ƒn•|tjSkrøtTjU||ƒns|tjVkrtWjX|||ƒnN|tjYkr?t0jZ||ƒn,|tj[kr[t\|ƒn|tj]kr}t^j_||ƒnî|tj`krŸtajb||ƒnÌ|tjckrÁt0jd||ƒnª|tjekrãtfjg||ƒnˆ|tjhkrtijj|||ƒnc|tjkkr<tl||tjmtnjoddƒƒn/|tjpkrptl||tjqtnjoddƒƒnû|tjrkr¤tl||tjstnjoddƒƒnÇ|tjtkrØtl||tjutnjoddƒƒn“|tjvkrLtjwƒjxtyjzƒd}tnj{ddƒ}    ||    krktl||tj|tnjoddƒdƒqkn|tj}krkt~||ƒndS(    Ns5PlayerGetReward: rewardType=%s,dataEx=%s,dataExStr=%stGameNoticeRewarditShareGameRewardtGoodGameRewarditOpenServerDailyAwardi(RRRt
RewardTypetDataExt    DataExStrR­RtDef_RewardType_ActivityR˜tGetActivityAwardtDef_RewardType_DailyTasktGetDailyTaskAwardtDef_RewardType_SuccessRHtGetSuccessAwardtDef_RewardType_TreeFreeTimeR’tFreeReduceTreeLVTimetDef_RewardType_ADAwardt OnGetADAwardtDef_RewardType_LLMJLVUpR™t
OnLLMJLVUptDef_RewardType_FamilyTaofaBoxtPlayerFamilyTaofatGetTaofaBoxAwardtDef_RewardType_LineupRecommendR‹tGetLineupRecommendAwardtDef_RewardType_OpenFuncR:tGetFuncOpenAwardtDef_RewardType_BeautyLVAwardRštGetBeautyLVAwardtDef_RewardType_DownLoadtGetDownloadAwardt'Def_RewardType_OSACelebrationPointAwardRtGetOSACelebrationPointAwardtDef_RewardType_LunhuidianAwardRŸtGetLunhuidianAwardtDef_RewardType_DayFreeGoldGiftRStOnGetDailyFreeGiftbagtDef_RewardType_FirstChargeR9tGetPlayerFirstChargetDef_RewardType_FreeGoodsR\tOnGetFreeGoodstDef_RewardType_TotalRechargeROtOnGetTotalRechargeAwardtDef_RewardType_ManyDayRechargeRctOnGetManyDayRechargeAwardtDef_RewardType_SingleRechargeRdtOnGetSingleRechargeAwardtDef_RewardType_WishingWellRitDoGetWishingAwardtDef_RewardType_ActLoginAwardNewR`tOnGetActLoginAwardtDef_RewardType_ActBuyCountGiftR]tOnGetBuyCountGiftAwardtDef_RewardType_ActTaskR^tOnGetActTaskAwardtDef_RewardType_BuyOneRUtGetBuyOneFreeAwardtDef_RewardType_FamilyCTGAssistRVtGetFamilyCTGAssistAwardtDef_RewardType_FamilyGCZR”tGetFamilyGCZAwardtDef_RewardType_TiandaoTreeRŽtGetTiandaoTreeAwardtDef_RewardType_TreasureCntAwardRCtGetTreasureCntAwardt!Def_RewardType_HistoryChargeAwardtOnGetHistoryRechargeAwardtDef_RewardType_CreateRoletOnGetCreateRoleAwardtDef_RewardType_CustomAwardRntOnGetCustomAwardtDef_RewardType_RealmLVUpTaskR3tGetRealmLVUpTaskAwardtDef_RewardType_DailyPackBuyGifttGetDailyPackBuyGifttDef_RewardType_TaskR‘t GetTaskAwardtDef_RewardType_ZhanlingRtGetZhanlingRewardRstOnGiveAwardByClientRqRRRuRtRwRvRyRxR{RÈR    RÏtDef_Notify_WorldKey_ServerDayRRzR}tOnGetRechargeDayAward(
RRRRäR    t
rewardTypeR½t    dataExStrt openServerDaytopenServerDayLimit((sgD:\SG_ServerCode\ServerPython\ZoneServerGroup\map1_8G\MapServer\MapServerData\Script\Player\ChPlayer.pytPlayerGetReward 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ƒno|dkrR|}tj||ƒnJ|dkr}|}    tj||    tjƒn|dkrœtj||ƒndS(    NtADAwards-½ñÈÕ¸Ã¹ã¸æ½±ÀøÒÑ´ïÉÏÏÞ! adID=%s,adCnt=%s > %sisNÁìÈ¡¹ã¸æ½±Àø! adID=%s,adCnt=%s,adAwardType=%s,adAwardValue=%s,awardItemList=%steventiii(RRät GetADCntMaxRpRtDef_PDict_ADCntRR­RR(tGetADAwardItemListtGetADAwardTypetGetADAwardValueR–R0tGivePlayerItemOrMailRR’tGetTreeEnergyAwardREt
AddFBADCntRCt
DoTreasuretCostType_ADFreeR›tAddTravelEnergy(
R    tadIDtipyDatatadCntMaxtadCntt awardItemListt adAwardTypet adAwardValuetadMapIDt treasureType((sgD:\SG_ServerCode\ServerPython\ZoneServerGroup\map1_8G\MapServer\MapServerData\Script\Player\ChPlayer.pyR˜— s8 
    "    cCs§g}tjƒ}xxt|jƒƒD]d}|j|ƒ}|jƒ}|jtj|ƒsbq%nt    j
|tj|dƒ|j |ƒq%W|r£t ||ƒndS(Ni( RRóRßtGetADAwardCounttGetADAwardByIndextGetADIDRpRRáRR(R¼R–(R    t syncADIDListRýRRìRë((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ßRôRõRöRpRRáR”RGt tagSCADInfotADIDtADCntR¼ttagSCADInfoListt
ADInfoListRCRGR
R (
R    R÷RýRåtadIDListt
adInfoListRëRîtadInfoR[((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(RpRtDef_PDict_CTGRealTotalR|RRRxRRR­RRžt GiveAwardItemRR(Rr(
R    RÙt    realTotaltawardCoinRecordt    awardCoinRït dayAwardDictt needCoinStrRctneedCoin((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( RpRtDef_PDict_CreateRoleAwardStateRR­RžRRRRR(Rm(R    ((sgD:\SG_ServerCode\ServerPython\ZoneServerGroup\map1_8G\MapServer\MapServerData\Script\Player\ChPlayer.pyRËø s 
cCs?tjƒ}|jƒ|jtjƒ|_tj||ƒdS(N(    RGttagMCCreateRoleAwardStateRíRpRR
RR
R (R    RH((sgD:\SG_ServerCode\ServerPython\ZoneServerGroup\map1_8G\MapServer\MapServerData\Script\Player\ChPlayer.pyRms
 
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(RRRRpRtDef_PDict_DownloadAwardStateRR­RRR(RŒRùR¤R0RåRRf(R    R½R°tdownloadAwardNumt curAwardNumRï((sgD:\SG_ServerCode\ServerPython\ZoneServerGroup\map1_8G\MapServer\MapServerData\Script\Player\ChPlayer.pyR¥ s    
cCsWtjddƒ}tjƒ}|jƒ|jtjƒ|k|_t    j
||ƒdS(NR i( RRRGttagMCPackDownloadRecordRíRpRRtRecordR
R (R    RRH((sgD:\SG_ServerCode\ServerPython\ZoneServerGroup\map1_8G\MapServer\MapServerData\Script\Player\ChPlayer.pyRf"s  
cCsj|j|ƒr*tjd||fƒdStj|||ƒsCdStj||dƒt||dƒdS(Ns)ÒÑÁìÈ¡¹ý¸Ã½±Àø! rewardType=%s, dictKey=%si(RpRR­RžRRR(Rr(R    RÙtdictKeytawardCfgt    eventName((sgD:\SG_ServerCode\ServerPython\ZoneServerGroup\map1_8G\MapServer\MapServerData\Script\Player\ChPlayer.pyRÖ+scCs<tjƒ}|jƒ||_||_tj||ƒdS(N(RGttagMCPlayerRewardGetRecordRíRŒtRewardGetRecordR
R (R    RÙtrewardGetRecordRH((sgD:\SG_ServerCode\ServerPython\ZoneServerGroup\map1_8G\MapServer\MapServerData\Script\Player\ChPlayer.pyRr;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    AreaSkillRytHPPackagePercent( RRRRptDataRvRwRRãRR(RtDef_PDict_AutoFightSetting(RRRR    t settingDicttBasicSkillCounttAreaSkillCounttBuffSkillCounttBasicSkillListtKeyt
ValueIndextValuet AreaSkillListt BuffSkillList((sgD:\SG_ServerCode\ServerPython\ZoneServerGroup\map1_8G\MapServer\MapServerData\Script\Player\ChPlayer.pytOnSaveAutoFightSettingFs&$$$ 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(NRRiRRyRs%s(RvRwRßRpRRR¼RGttagMCAutoFightSettingRíRRCtSizeR
R ( R    R!R"R#R R%R$R&R'R(R)RH((sgD:\SG_ServerCode\ServerPython\ZoneServerGroup\map1_8G\MapServer\MapServerData\Script\Player\ChPlayer.pytSync_AutoFightSettingds:
 
 
 
 
 cCs#tjƒj|ƒ}|sdSdS(N(RRR(RRRR    ((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(RRRt IsNoTimeLimitRt TYPE_Player_Tick_QueryMapNPCInfoRRR­RR‚R€t    NPCIDListRpt BaseExceptionRˆt
isinstancetlistRRaRRÖt
GetNPCInfoR3t GetMapCopyPlayerManagerByFbIndextGetPlayerCountt SyncNPCInfotGameServer_QueryPlayerByIDtqueryType_NPCInfoRC(RRRR    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(RRRR0tCheckPlayerTickRR1R­R‚R€R2RpR3RˆR4R5RRaRRÖt GetNPCCntInfotSyncNPCCntInfoR:tqueryType_NPCCntRC( RRRR    R=R>R?R@R|RARD((sgD:\SG_ServerCode\ServerPython\ZoneServerGroup\map1_8G\MapServer\MapServerData\Script\Player\ChPlayer.pytOnQueryMapNPCCntInfoÖs@                           cCs#tjƒj|ƒ}|jƒdS(N(RRRR8(RRRR    ((sgD:\SG_ServerCode\ServerPython\ZoneServerGroup\map1_8G\MapServer\MapServerData\Script\Player\ChPlayer.pytQueryWorldTicks
cCsÈtjƒ}|sdStjƒ}|jƒ|j|_|j|_|j    |_
|j |_ |j |_|j|_|j|_tjtjƒjƒƒ|_|r·tj||ƒn tj|ƒdS(N(RtGetCurrentTimeRGttagServerDateTimeRítyeartYeartmonthtMonthtdaytDaythourtHourtminutetMinutetsecondtSecondt microsecondt    MicSecondtChangeTimeNumToStrtCrossMgrtGetSSServerMgrt GetCrossTimetCrossServerTimeR
R tSendFackPackOnline(R    t
serverTimetserverDateTime((sgD:\SG_ServerCode\ServerPython\ZoneServerGroup\map1_8G\MapServer\MapServerData\Script\Player\ChPlayer.pyRs"  
        cCstjƒ}|sdStjƒ}tjƒjtjƒ|_    tjƒjtj
ƒ|_ tjƒjtj ƒ|_ tjƒjtjƒ|_|j|_|j|_|j|_|j|_|j|_|j|_|j|_tjƒ|_t j!||ƒdS(N("RRMRGttagMCOpenServerDayR¹tGetEventTrigMgrRÌRÏt Def_ServerDayRTtDef_IsMixServert IsMixServertDef_MixServerDaytMixDaytDef_OpenServerWeekdayt OpenWeekdayROtNowYearRQtNowMonthRStNowDayRUtNowHourRWt    NowMinuteRYt    NowSecondR[t NowMicSecondt GetWeekOfYeart
WeekOfYearR
R (R    RcR[((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( RRRtPYPlayerNormalMoveRƒR…RaRÁR>R¼tGetEmptyPlaceInAreaRˆR¿(RR[RR    RÓRÔt    resultPos((sgD:\SG_ServerCode\ServerPython\ZoneServerGroup\map1_8G\MapServer\MapServerData\Script\Player\ChPlayer.pyt PYPlayerMovePs$ 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)(+RR>tDirt
ClientPosXt
ClientPosYt    SeverPosXt    SeverPosYR'RtGetClientMoveTickRR­RaRÁRRƒR…R7tMoveDistCalcTickt MoveDistSumtSetClientMoveTicktPyNotifyPlayerMoveRbR3RcR t DoFBCanMoveR(R)R*RR7R8R,R¤R¢tminRRtGetSpeedR9R:R(R    R[RtmoveDirt
clientPosXt
clientPosYtsendPack_SeverPosXtsendPack_SeverPosYR2tmoveTypet lastMoveTickR3tdisttcalcTicktdistSumtspeedt passCalcTicktneedTickt checkNeedTick((sgD:\SG_ServerCode\ServerPython\ZoneServerGroup\map1_8G\MapServer\MapServerData\Script\Player\ChPlayer.pyRwhsr                               $  
$  
 
     # cCstjƒ}|jƒ|jƒ|_tj|_||_||_    ||_
||_ ||_ |j ƒ|_||_tj||tdƒdS(Ni(RGttagMCPYPlayerMoveRíR¤RYR3t    gotPlayerRXR~RR€RR‚RŠtSpeedRRRR(R    R‹RŒRRÓRÔRRH((sgD:\SG_ServerCode\ServerPython\ZoneServerGroup\map1_8G\MapServer\MapServerData\Script\Player\ChPlayer.pyR‡Ös 
                         cCsEtjƒ}|jƒ||_||_||_tj||ƒdS(s»Í¨ÖªÇ°¶ËÏòij¸öµãÒÆ¶¯
                ÕâÀïǰ¶Ë¿ÉÄÜÐèÒªÕë¶Ôij´ÎÒÆ¶¯×ö¶îÍâ´¦Àí£¬±ÈÈçÒÆ¶¯µ½Ä³¸öµãºóÐèÒª×Ô¶¯Õ½¶·µÈ
                ËùÒÔÕâÀïÖ»×ö֪ͨǰ¶Ë¿ÉÒÔÏòij¸öµãÒÆ¶¯£¬×îÖÕÒÆ¶¯ÓÉǰ¶Ë·¢Æð
    N(RGttagMCNotifyPlayerMoveRíR„R†tNPCIDR
R (R    RÓRÔtnpcIDRH((sgD:\SG_ServerCode\ServerPython\ZoneServerGroup\map1_8G\MapServer\MapServerData\Script\Player\ChPlayer.pytNotifyPlayerMoveçs 
            cCstjƒj|ƒ}|j|jtj}tj|ƒ}||}|dkrmt    j    |ƒ}|j
ƒntj ||ƒdS(Ni( RRRtLostHPtLostHPExRÏtDef_PerPointValueR0R1RtSetDeadRõ(RRRR    tlostHPtcurHPtupdHPRD((sgD:\SG_ServerCode\ServerPython\ZoneServerGroup\map1_8G\MapServer\MapServerData\Script\Player\ChPlayer.pyt OnRoleLostHPüs
  cCsdS(N((RRR((sgD:\SG_ServerCode\ServerPython\ZoneServerGroup\map1_8G\MapServer\MapServerData\Script\Player\ChPlayer.pytOnSelectRealmDifficultyscCstjƒj|ƒ}|j}|j}|tjkr:dS|tjkrX|jƒ}nt    j
ƒj ||ƒ}t ||||j ƒƒdS(N(RRRtRecTypetRecIDRÏtDef_GameRecTypeListtDef_ViewGameRecSelfListRR¹RŽRtSyncGameRecInfot GetDataList(RRRR    trecTypetrecIDt recTypeIDMgr((sgD:\SG_ServerCode\ServerPython\ZoneServerGroup\map1_8G\MapServer\MapServerData\Script\Player\ChPlayer.pyt OnViewGameRecs        cCs;g}xÛ|D]Ó}|sq ntjƒ}|jƒ|_|jƒ|_|jƒ|_|jƒ|_    |j
ƒ|_ |j ƒ|_ |jƒ|_|jƒ|_|jƒ|_|jƒ|_t|jƒ|_|j|ƒq Wtjƒ}|jƒ||_||_||_t|jƒ|_tj ||ƒdS(N(!RGt tagSCGameRectGetTimetTimet    GetValue1tValue1t    GetValue2tValue2t    GetValue3tValue3t    GetValue4tValue4t    GetValue5tValue5t    GetValue6tValue6t    GetValue7tValue7t    GetValue8tValue8t GetUserDatatUserDataRCt UserDataLenR¼ttagSCGameRecInfoRíR©RªtRecListRGR
R (R    R¯R°t recDataListRzRštrecR[((sgD:\SG_ServerCode\ServerPython\ZoneServerGroup\map1_8G\MapServer\MapServerData\Script\Player\ChPlayer.pyR­*s2   
            (÷R;R3RRR¼RRyRR>RÖRdR RXRžR0RZR·RvRRÏR
RGR"R5R9R<R3RŠRGR˜RERiRHR\R:RœRCRR$RËRTRRRSRURPRWRORaRbRVRcRdRQRjRoReRRURLRrR8RJRhRlR@t
SkillShellRRnRR’R™RBR‘RÍRKR0R(RŽR“R`R]RŸR”R_R^RŒR¹RËR—tGameServerRefreshRyRÄRwt    PyMongoDBRR‰R‡R•R‹RžRRšR›RœR.RR·RRÍR^R®tdatetimeRtmathtreRtRR
R R'R,RFR/RRR§R R¿RÖRÀR×RæR>R¡RéR7R-R+R.R9RLR:RMR!R`RqRƒR‚RŒR‹R R£R¡R…RÊRÜR³RñR RçRRR4RRAR+RURQRZRbRmRoRnRrRpR‹RRR®RkR¾R/RÆRÊR•R—RÚRÞRßRáRàRåRäRèRçR÷RðRRR”RXRgR`RhR5RTRDRFRERORKRYRTRWRVR`R…R‡RÝR˜R†R–RØRËRmR¥RfRÖRrR*R-R.RERKRLRRRzR„R…RwR‡RŸR§R¨R²R­(((sgD:\SG_ServerCode\ServerPython\ZoneServerGroup\map1_8G\MapServer\MapServerData\Script\Player\ChPlayer.pyt<module>sæ                                                                                                                                                     Š         Ú    9    #     1            
    &            /    A         ,        
        :            
         
    ?    E    
                         %    2 !    $    :    K    +    $ 6                                          0         -        "        
                     "                                      
    !    )    "    #     +    ?                             A                    J    #    Œ    $                                            (    
    @    /    
    &        n