hxp
2025-10-20 59aaff60814142409602243225808f8422b9a330
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
®Ýõhc@s¬
ddlZddlZddlZddlZddlZddlZddlZddlZddlZddl    Z    ddl
Z
ddl Z ddl Z ddl Z ddlZddlZddlZddlZddlZddlZddlZddlZddlZddlZddlZddlZddlZddlZddlZddlZddlZddlZddl Z ddl!Z!ddl"Z"ddl#Z#ddl$Z$ddl%Z%ddl&Z&ddl'Z'ddl(Z(ddl)Z)ddl*Z*ddl+Z+ddl,Z,ddl-Z-ddl.Z.ddl/Z/ddl0Z0ddl1Z1ddl2Z2ddl3Z3ddl4Z4ddl5Z5ddl6Z6ddl7Z7ddl8Z8ddl9Z9ddl:Z:ddl;Z;ddl<Z<ddl=Z=ddl>Z>ddl?Z?ddl@Z@ddlAZAddlBZBddlCZCddlDZDddlEZEddlFZFddlGZGddlHZHddlIZIddlJZJddlKZKddlLZLddlMZMddlNZNddlOZOddlPZPddlQZQddlRZRddlSZSddlTZTddlUZUddlVZVddlWZWddlXZXddlYZYddlZZZddl[Z[ddl\Z\ddl]Z]ddl^Z^ddl_Z_ddl`Z`ddlaZaddlbZbddlcZcddldZdddleZeddlfZfddlgZgddlhZhddliZiddljZjddlkZkddllZlddlmZmddlnZnddloZoddlpZpddlqZqddlrZrddlsZsddltZtddluZuddlvmwZwddlxZxddlyZyddlzZzddl{Z{ddl|Z|ddl}Z}ddl~Z~ddlZddl€Z€ddlZddl‚Z‚ddlƒ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œ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ªd*„Z«e¬d+„Z­d,„Z®d-„Z¯d.„Z°d/„Z±d0„Z²d1„Z³d2„Z´d3„Zµ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@„ZÂdA„ZÃdB„ZÄdC„ZÅdD„ZÆdE„ZÇdF„ZÈdG„ZÉdH„ZÊdI„ZËdJ„ZÌeÍe¬dK„ZÎdL„ZÏdMe¬dN„ZÐdO„ZÑdMe¬dP„ZÒdQ„ZÓdR„ZÔdS„ZÕdT„ZÖdU„Z×ddMdV„ZØddWe¬dMdX„ZÙdY„ZÚdZ„ZÛd[„ZÜd\„ZÝd]„ZÞd^„Zßd_„Zàd`„Záda„Zâdb„Zãdc„Zädd„ZåeÍde„Zædf„Zçdg„Zèdh„ZédWdi„Zêdj„Zëdk„Zìdl„Zídm„Zîdn„Zïdo„Zðdp„Zñdq„Zòdr„Zóds„ZôdtZõduZödv„Z÷dw„Zødx„Zùdy„Zúdz„ZûdMd{„Züd|„Zýd}„Zþd~„Zÿd„ZdS(€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 cCs'tj||ƒrdStj|ƒdS(N(tFBLogictPlayerLoginInFBChecktPlayerEventCountertUpdatePlayerLoginTime(R    R((sgD:\SG_ServerCode\ServerPython\ZoneServerGroup\map1_8G\MapServer\MapServerData\Script\Player\ChPlayer.pytOnAllServerInitOK®s c 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(R R!RR    ((sgD:\SG_ServerCode\ServerPython\ZoneServerGroup\map1_8G\MapServer\MapServerData\Script\Player\ChPlayer.pyt OnChangeJobásc    CsJtjƒj|ƒ}t|ƒtj|ƒdksI|jƒtjkr_t    |t
j |ƒn|j t
j dƒtj|ƒ}|jƒt|ƒtj|ƒtj|ƒrÁtj|ƒntj|ƒ|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 GetCrossMapIDtCrossRealmPlayertDoExitCrossRealmt
PetControltDoLogic_PetLoadMapOKt
SetVisibletTruetSetSightt RefreshViewtDef_PlayerSight_DefaulttGameServer_QueryPlayerResultRtlen(R R!RR    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
RebornPosYtGetStatetStateR3tHPtGetHPExtHPExtGetXPtXPtGetHPRestoreSettingtHPRestoreSettingtGetMPRestoreSettingtMPRestoreSettingt 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.pyR1sÊ cCsš|jtjdƒt|ƒt|ƒ|jƒtjƒrM|jt    ƒnt
||ƒtjƒrŒ|jt ƒt j ||jƒƒn|jƒdS(Ni(R9RtDef_PlayerKey_LoadMapIsLogintSync_PyServerDataTimeToClienttSync_OpenServerDaytSync_ClientPlayerLoginRt IsCrossServertSetForbiddenSyncClientStateREt__DoPlayerLoginServertFalseRt SetCrossMapIDRˆtBalanceServer_PlayerLoginInitOK(R    R((sgD:\SG_ServerCode\ServerPython\ZoneServerGroup\map1_8G\MapServer\MapServerData\Script\Player\ChPlayer.pyt DoPlayerLogin™s
 
 
 
cCsr|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
j|ƒt||ƒt
j|ƒt
j|ƒtj|ƒtj|ƒtj    |ƒt|ƒt j!|ƒt"|ƒt#|ƒt$j%|ƒt&j|ƒt'j|ƒt(j)|ƒt*j+|ƒt,j-|ƒt.j/|ƒt0j|ƒt1j2|ƒt3j4|ƒt5j6|ƒt7j8|ƒt9j|ƒt:j;|ƒt<j|ƒt=j>|ƒt?j||ƒt@jA|ƒtBj>|ƒtCj>|ƒtDj|ƒtEj|ƒt
jF|ƒt
jG|ƒtHj|ƒtIj|ƒtJj|ƒtKj|ƒtLj|ƒtMj|ƒtNj|ƒtOj|ƒtPj|ƒtQj|ƒtRj|ƒtSj|ƒtTj|ƒtUj|ƒtVjW|ƒtXjY|ƒtZj[|ƒt\j|ƒt]j|ƒt^j|ƒt_j|ƒt`j|ƒtaj|ƒtbj|ƒtcj|ƒtdj|ƒtej|ƒtfj|ƒtgj|ƒthj|ƒtij|ƒtjj|ƒtkj|ƒtlj|ƒtmj|ƒtn|ƒt(jo|ƒtpj|ƒtqj|ƒtrj|ƒts|ƒttj|ƒtuj|ƒtvj|ƒtw|ƒtxj|ƒtyj|ƒ|jzt j{ƒ}|rTt||t j}|ƒn|jzt j~ƒ}|r‚t||t j|ƒn|jzt j€ƒ}|r°t||t j|ƒn|jzt j‚ƒ}|rÞt||t jƒ|ƒn|jzt j„ƒ}|r t||t j…|ƒn|jzt j†ƒ}|r:t||t j‡|ƒn|jˆdƒ|j‰dƒt
jŠ|ƒtj|ƒdS(s2 Íæ¼ÒµÇ¼ÐèÒª´¦ÀíµÄÄÚÈÝ£¬±¾·þ¼°¿ç·þ·þÎñÆ÷·Ö¿ª
    Nièi(‹t SetLoginTimeRtGetCurrentDataTimeStrtInitPlayerPackRtDoPlayerLoginInMaptDataRecordPacktDR_PlayerLogint EventReporttWriteEvent_loginRtGetPlayerLeaveServerSecondRtDef_PlayerOfflineProtectTimetNomalDictSetPropertyt Def_Player_Dict_PlayChangeLineIDt Def_Player_Dict_FuncChangeLineIDt Def_Player_Dict_HighChangeLineIDR?Rt__FirstLoginOnEntert
TurnAttackRtSyncGuideStatet ItemControlertUpdPlayerServerGroupIDtSyncOnLineTimeTotaltSyncTrainRealmLVtPlayerGodWeapontOnLogintPlayerPrestigeSyst__DoMixServerFirstLogintPlayerBillboardtBillboardOnLogint__SyncPlayerInfoExtGiveDownloadPatchAwardt PlayerLVAwardtSync_LVAwardGetRecordInfot
PlayerCointPlayerGoldGiftt GameFuncCommtSync_FuncOpenStatet PlayerSignDaytSignDayOnLogint PlayerHorsetPlayerHorseLogint
PlayerFaQitPlayerFaQiLogint PlayerLianTitPlayerTreasuretOnTreasureLogintPlayerLoginDayAwardtOnLoginNotifyLoginDayAwardtOpenServerCampaigntOnOpenServerCampaignLogintFBCommont    FBOnLogintPlayerGoldInvestt PlayerSuccesst SuccOnLogint PlayerCharmt
PlayerLoveRt PlayerFamilyt
PlayerCoatt OnLogin_CoattPlayerCrossRealmPKtPlayerCrossChampionshiptPlayerLuckyCloudBuyt PlayerArenatNotifyPlayerAllCurrencytNotifyUseMoneyTotaltCrossActCTGBillboardtCrossActAllRechargetPlayerCostRebatetPlayerActTotalRechargetPlayerActRechargeRebateGoldtPlayerActRechargePrizetPlayerActGrowupBuytPlayerSpringSaletPlayerFlashGiftbagtPlayerDailyGiftbagtPlayerFlashSaletPlayerActBuyOnetPlayerActFamilyCTGAssisttPlayerActCollectWordstChItemtSync_ItemDayUseCntt
PlayerRunetPlayerRuneLogintFunctionNPCCommontShopItemOnLogintPlayerFreeGoodstPlayerBossReborntPlayerWeekPartytPlayerActBuyCountGiftt PlayerActTasktPlayerActYunshitPlayerActLunhuidiantPlayerActLoginNewtPlayerFeastWeekPartytPlayerFeastLogintPlayerFeastWishtPlayerFeastTraveltPlayerActLogintPlayerActLianqitPlayerActGodGifttPlayerActManyDayRechargetPlayerActSingleRechargetPlayerActTurntabletSyncPackDownloadAwardtDoFuncOpenLogict
PlayerDogztPlayerWishingWelltPlayerLuckyTreasuretSyncLittleHelpertPlayerFBtGY_Query_BossFirstKilltPlayerTongTianLingtSync_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_RechargeDayAwardtSetStatetSetCountryLastWeekHornortDoGMForbidenTalkOnLogin(R    RtleaveServerSecondtgameNoticeAwardStatetshareGameAwardStatetgoodGameAwardStatetlikeGameAwardStatet
awardState((sgD:\SG_ServerCode\ServerPython\ZoneServerGroup\map1_8G\MapServer\MapServerData\Script\Player\ChPlayer.pyR´sö
 
 
 
 
 
 
 
 
 
      cCsbtjd|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|ƒ|jƒ|jtjƒ}t|gƒ}tjƒj|jƒddd|t|ƒƒdS(s     Íæ¼Ò×îÖյǼ³É¹¦´¦Àí£¬ ÓÉ  GameServerRefresh GameSever_PlayerInitOK  µ÷ÓÃ
        ¸Ãº¯ÊýΪµØÍ¼×îÖյǼ³É¹¦²Å»áÖ´Ðе½£¬ÒÔºóһЩ¹¦ÄÜÀàµÄµÇ¼´¦Àí½¨Òé¾ùдµ½ÕâÀï
        ¾ÉµÄ¹¦ÄÜÏȲ»¶¯( __DoPlayerLoginServer º¯ÊýÖеŦÄÜ)£¬Èç¹ûÓеǼÏà¹ØµÄbugÔÙ¿¼ÂÇÊÇ·ñÒÆ¶¯µ½´Ëº¯Êý
    sMapServer->DoPlayerRealLoginOKitPlayerRealLoginOKN( RRRRt PyMongoMaint GetUserCtrlDBRt
PlayerHerot
PlayerMailt    PlayerHJGtPlayerXiangongt PlayerGubaotPlayerShentongtPlayerZhanlingt
PlayerTaskt
PlayerTreetPlayerGoldRushtPlayerActFamilyGCZt
PlayerTalkt SyncADCntInfotUpdatePlayerNametPlayerActivityt
PlayerLLMJtSendDBQueryRecharget GetDictByKeyRt!Def_PlayerKey_MixServerFirstLoginRRRItGetIDRJ(R    RtisMixServerFirstLogintmsg((sgD:\SG_ServerCode\ServerPython\ZoneServerGroup\map1_8G\MapServer\MapServerData\Script\Player\ChPlayer.pytDoPlayerRealLoginOKÓs2             
 
.cCsHtjƒ}|jƒ|jƒ|_|jƒ|_tj||ƒdS(N(RNttagMCPlayerInfotCleartIsAdulttGetCreateRoleTimetCreateRoleTimeRR(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ƒ}x0|D](\}}tj||jƒg|ƒqÂWtj|ƒtj|ƒtj|tjdƒdS(NsÍæ¼ÒÊǵÚÒ»´Î½øÈëÓÎÏ·iit MailLVAwardi(R¾R‘RtDef_Player_Dict_FirstLoginRRR%tWriteEvent_Entryt SetFightPointR2tSetHPtGetMaxHPR^R@R†R#t DR_FirstLoginRPtGetIPRRRt SendMailByKeyRR«tOnPlayerFirstLoginR´tInitGoldEnergyR)(R    tplayerIDtmailListt 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ƒtj|dgƒtjddƒ}tjddƒ}tjdd    ƒ}tjdd
ƒ}    td ||    ƒ}
|\} } g} x¥|D]\}}}tjƒj|ƒ}|sÑq¡n|jd ƒ}|jƒ}|tj krq¡n|j!dƒ}|sq¡n||
kr=|||gg} q¡Pq¡Wi|d 6|d6|
d6}|| }tj d|
|f|ƒt j"d|g|d| d| d|ƒt#j$|dt%ƒdS(Ns'±¾´ÎºÏ·þÒѾ­µÇ¼¹ý. lastMixServerDay=%ss9Íæ¼ÒºÏ·þÊ׵Ǵ¦Àí! lastMixServerDay=%s,mixServerWorldLV=%sis    ÐºŲ»¸øºÏ·þ½±Àø!t    MixServerit MixServerMailiiii–itMixServerWorldLVtLastMixServerDayt ItemWorldLVs3    ·¢ËͺϷþ²¹³¥Óʼþ: itemWorldLV=%s,addItemList=%st
MixServer1tgoldtsilvertdetailtisAll(&Rt GetGameWorldtGetGameWorldDictByKeyt ShareDefinetDef_Notify_WorldKey_IsMixServerRt$Def_Notify_WorldKey_LastMixServerDayR‘RtDef_PDict_MixLoginDaytDebugLogt(Def_Notify_WorldKey_LastMixServerWorldLVRRR)R^R9R½RBt ResetDaySignR>tDoResetCTGCountRqtResetShopItemBuyCountRRt
GetFuncCfgtmaxt GetGameDatatGetItemByTypeIDtGetEffectByIndext GetEffectIDtDef_Effect_ItemAddLVtGetEffectValueRÐR8t"UpdatePlayerBillboardOnLeaveServerRE(R    t isMixServerRÓtlastMixServerDayt    playerDaytmixServerWorldLVRÖtworldLVMailItemListt mailMoneyListt worldLVDownt itemWorldLVRÝRÞtworldLVItemListtitemIDt    itemCounttisBindtitemDatatcurEfftcurEffIDtlvLimitt
detailDictt addItemList((sgD:\SG_ServerCode\ServerPython\ZoneServerGroup\map1_8G\MapServer\MapServerData\Script\Player\ChPlayer.pyR75s\      
(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.pytClearPlayerDeadInfoyscCsg|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_PackDetel„s cCsÆtjƒ}|jƒg|_|jƒ}xrt|jƒƒD]^}|j|ƒ}tjƒ}|j    ƒ|_
|j ƒ|_ |j ƒ|_|jj|ƒq>Wt|jƒ|_tj||ƒdS(N(RNttagMCPlayerSkillsRÃtSkillstGetSkillManagertranget GetSkillCounttGetSkillByIndexttagPlayerSkillt
GetSkillIDtSkillIDt GetRemainTimet
RemainTimetGetProficiencyt ProficiencytappendRJtCountRR(R    tsendPackt skillManagertitcurSkillt    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.pyR<Ès
cCsQtjƒ}|jƒ|jƒ|_|jƒ|_d|_tj    ||ƒdS(Nic(
t ChNetSendPackttagClearObjBuffRÃtGetGameObjTypetObjTypeR¾tObjIDtBuffTypeRR(R    t
clientPack((sgD:\SG_ServerCode\ServerPython\ZoneServerGroup\map1_8G\MapServer\MapServerData\Script\Player\ChPlayer.pyR*Òs 
    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#|ƒt$j%|ƒtj&|j'ƒƒtt(_)dS(Ni(*t
SetCanMoveRt    SetInitOKt SetMapLoadOKRDt SetCanAttackt__CheckClearBuffOnMapChangeRtGetMapt GetMapFBTypeR5tfbtNullt SkillCommontAddBuffBySkillType_NoRefurbishRtDef_SkillID_LimitSuperBufft GetSightLevelR¾RtSetPlayerSightLeveltGetSightRFR=tChangePlayerSighRRRtGetOnlinePlayert ReCalcAllAttrREtSetProcessEquipDurgTickt SetLoginTickR9tDef_PlayerKey_CalcOLTimeTicktRefreshRebornPointtSavePlayerMessionInDataServerR%tWriteEvent_FightPowertRemoveLeaveServerPlayerInfoRt
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 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.pyRN5scCstjtƒ||ƒdS(N(Rt GetPsycoFunct__Func_PlayerLogin(R R((sgD:\SG_ServerCode\ServerPython\ZoneServerGroup\map1_8G\MapServer\MapServerData\Script\Player\ChPlayer.pyt PlayerLoginCscCsµtjƒj|ƒ}y_t||ƒt||ƒ|jtƒ|jƒt||ƒt    ||ƒt
j ||ƒWn:|j t jƒddl}tjd|jƒƒnXdS(NiÿÿÿÿsÍæ¼ÒÉÏÏßÂß¼­´íÎó
%s(RRRR
RR9RtSendToBServerServerInitOKRt__Func_LoadMapOKtGameServerRefreshtGameSever_PlayerInitOKtKickR5tdisWaitForPlayerLoinErrort    tracebacktRaiseExceptiont
format_exc(R RR    Ri((sgD:\SG_ServerCode\ServerPython\ZoneServerGroup\map1_8G\MapServer\MapServerData\Script\Player\ChPlayer.pyRaMs   
   cCstjtƒ||ƒdS(N(RR`t__Func_ChangeMapInit(R R((sgD:\SG_ServerCode\ServerPython\ZoneServerGroup\map1_8G\MapServer\MapServerData\Script\Player\ChPlayer.pyt ChangeMapInitlscCs¶tjƒj|ƒ}t||ƒtj||ƒt|ƒt||ƒ|jƒt    j
||ƒtj ƒj ƒt jkrŽ|jdƒn |jdƒ|jƒ|jtƒdS(Nii(RRRR
RAtPlayerChangeMapUpdateSkillCDR!R"tInitChangeMapPlayerSummonInfoRBtSync_PetInfo_ChangeMapR>R?R5tfbtTeamtGameServer_TeamEnterFBt#BalanceServer_PlayerChangeMapInitOKR9R(R RR    ((sgD:\SG_ServerCode\ServerPython\ZoneServerGroup\map1_8G\MapServer\MapServerData\Script\Player\ChPlayer.pyRlvs
 
     
 
cCs×tj|tjdtdtƒtj|tjƒtj|tjdtƒtj|tj    ƒtj|tj
dtdtƒtj|tj dtdtƒtj|tj ƒt j|ƒt|ƒtj|ƒdS(Nt
defaultMaxtisSync(RtInit_PackCountR5trptEquipRERtrptItemt rptIdentifyRãtrptHerot rptTempSwapt rptTempItemt rptTreasuret
ItemCommontSyncPackBuyCntRR0tCheckGiveBindMoneyTypeItem(R    ((sgD:\SG_ServerCode\ServerPython\ZoneServerGroup\map1_8G\MapServer\MapServerData\Script\Player\ChPlayer.pyR!¸s 
 cCstj}t||ƒS(N(RRCtCheckHasBuffBySkillID(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(( RRîtGetSkillBySkillIDRRRRAt GetBuffTypetGetBuffManagerByBuffTypetGetSkillTypeIDtFindBuffRE(R    R‚t    buffSkilltbuffTypet    buffTuplet    buffStatetbuffSkillTypeIDtcurBuff((sgD:\SG_ServerCode\ServerPython\ZoneServerGroup\map1_8G\MapServer\MapServerData\Script\Player\ChPlayer.pyRs 
 cCsHtjƒ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 ƒ|j%ƒ}|tj&kr.t'j(|t)t)ƒs.t'j*|t)ƒq.nt j+|t ƒt,j-||ƒtj.||ƒt/j0|ƒtj1ƒ}|jƒ}|jƒ}|j2tj3ƒr|j2tj3ƒdkrÏt j |ƒj4ƒn.t5j6||tj7ƒ\}}|j8||ƒt j9|tj3dƒntj|ƒdks@|j:ƒtj kr•|jtj;ƒ}    |    ratj<ntj=}
tj>ƒr‚tj=}
nt?||
|ƒn½|j@||ƒt krRt5j6||tj7ƒ\} } | dkr| dkrtjd||f|j    ƒƒt j |ƒ} | j4ƒqR|j8| | ƒtjd| | f|j    ƒƒntAjB|ƒ|jCƒtjDkr×tEjFtj1ƒjGƒƒtjHkr×|jItjDƒtJjK|tjL|ƒtJjK|tjM|ƒn|jNƒ}|jOƒ|kr |jP|ƒtQ|ƒtjRd|ƒntSjT|ƒtUjV|ƒ|jWƒt S(Ns'Íæ¼Ò¸±±¾Öбä¸ü¹¦ÄÜÏß·ÐéÄâÇеØÍ¼³É¹¦!!!is µØÍ¼¶ÁÈ¡³É¹¦is:Íæ¼ÒµÇÂ¼ÖØÖÃλÖÃʧ°Ü, °ÑÍæ¼Ò´ò»ØÖØÉúµã posX = %s posY = %ss<Íæ¼ÒµÇÂ¼ÖØÖÃλÖÃʧ°Ü, ÉèÖø½½üµã nearPosX = %s nearPosY = %ss½øÈëµØÍ¼Ç¿ÖÆÇл»PKģʽ: %s(XRRRt GetMapLoadOKR¼RtDef_PlayerKey_ResetFBLinePosXtDef_PlayerKey_ResetFBLinePosYRRR9RDRERRFRHRGR t    DoEnterFBt__CheckForbidLoginR;tInitPosRŠRŒRDR¾RERFR2R3tSetPlayerActionR5R6R:RƒR<R9tGetLastMapPlayerVehicletpvHorseRDtPlayerRideHorseUpRtPlayerRideHorseDowntSetIsNeedProcesst PlayerGMOpert DoGMOperLogictDoEnterFBLogicRBRCR>R‘tDef_PDict_IsReBorntSetToBornPlacetGameMaptGetNearbyPosByDistDef_RebornPos_Area_RangetResetPosR)R4RtrebornType_CityR8RR7tCanMoveR RRÙtCampType_NeutralROtGetRecordMapIDRˆtDef_MapID_NeedCampt
SetFactionRXRYtDef_SkillID_JusticetDef_SkillID_EviltGetInitAttackModelR¿t SetAttackModet SyncPKModelRçtPassiveBuffEffMngtOnLoadMapGFPassivet PlayerYinjit    OnLoadMapt
EndLoadMap(R RR    tresetFBLinePosXtresetFBLinePosYt playerVehicletcurMaptposXtposYtisLogint
rebornTypetnearPosXtnearPosYRKtinitAttackModel((sgD:\SG_ServerCode\ServerPython\ZoneServerGroup\map1_8G\MapServer\MapServerData\Script\Player\ChPlayer.pyRd!s˜   
 
 
       *    # $  
 
cCs9tjƒ}|jƒ|jƒ|_tj||ƒdS(N(RNttagMCAttackModeRÃR¿tModeRR(R    R$((sgD:\SG_ServerCode\ServerPython\ZoneServerGroup\map1_8G\MapServer\MapServerData\Script\Player\ChPlayer.pyR®Îs
 
cCstS(N(RE(R    ((sgD:\SG_ServerCode\ServerPython\ZoneServerGroup\map1_8G\MapServer\MapServerData\Script\Player\ChPlayer.pyt__CheckGMCanLoadMapOKÛscCs:|jƒtdtjƒ@dkr&tS|jtjƒdS(Nii(RUtpowRtDef_PysForbidByPyRERgR5t    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(RRRtPointAttrIDListtPointValueListRJt    enumerateRtGetIpyGameDataRŸRçt SetFreePointR‘RtDef_PDict_AddPointValueRR)tNotifyPlayerBasePointtRefreshPlayerAttrState(R R!RR    tpointAttrIDListtpointValueListtneedTotalPointR&tattrIDt curFreePointtaddPointtcurPointtupdPointRK((sgD:\SG_ServerCode\ServerPython\ZoneServerGroup\map1_8G\MapServer\MapServerData\Script\Player\ChPlayer.pyt
OnAddPoints2        &  
 
! 
cCs(tjƒ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ƒntj|dddƒdS(    NsÖØÖüӵã Ã»ÓеãÊýÐèÒªÖØÖÃt LVUPAddPointiiiÿÿÿÿii
i(RRRRtIPY_DatatxrangetGetRolePointCounttGetRolePointByIndext    GetAttrIDRR‘RRËRERçR^RìRR
R R5RxR~tGetItem_FromPack_ByIDtGetAttCheckItemCanUsetGetItemRemainingTimet
ReduceItemtItemDel_ResetAttrPointtItem_ResetAttrPointtDoResetAttrPoint(R R!RR    t
ipyDataMgrtcanResetIDListtcanResetRÑRÔtisFreetneedItemIDListtitemPacktdelIndext
expireTimeRþt    hasEnought itemIndexListt    itemIndextcurItemt isExpireItemt remainingTime((sgD:\SG_ServerCode\ServerPython\ZoneServerGroup\map1_8G\MapServer\MapServerData\Script\Player\ChPlayer.pytOnResetAttrPoint)sT 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‘RRËR"RNttagMCRolePointInfoRÆRÇRJtPointAttrIDCountRR(    R    tsyncAttrIDListRåR RÎ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__CheckPlayerCanMoveR>R¥R‹RtStopMovet    ChangePosRNttagMCMoveByTypeRÃR¾tIDR4R5tMoveTypeRt PyNotifyAllR(R R!RR    R$((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 SetTickByTypeRøR>R¥R‹RRùRúRNt    tagMCRushRÃR¾RüR4R5RRþR(R R!RR    R$((sgD:\SG_ServerCode\ServerPython\ZoneServerGroup\map1_8G\MapServer\MapServerData\Script\Player\ChPlayer.pyt OnPlayerRush s$& 
 
  c     Cs,tjƒj|ƒ}|jtjƒtjkr4dStj|tj    t
j ƒsSt St |ƒscdS|j}|j}|j}|j}|j}||kr¬||kr¬dStjƒj||ƒsä|j|jƒ|jƒƒdS||jdƒdkrdS|jd|ƒ|jƒ}    |    t
jt
jgkr9dStjƒ}
t|||
||||ƒsgdStj||||ƒdkr¥|j|jƒ|jƒƒdStj ||ƒ|j!||ƒ|j"ƒj#ƒ} | dkrçdStj| jƒ| jƒ||ƒdkrdSt%j&|||ƒdS(Nt FightMoveTicki2ii('RRRR‘Rt#Def_Player_Dict_AutoCheckHack_StatetDef_AutoCheck_State_DangertOperControlManagertIsObjCanDoActiontDef_Obj_ActState_ServerActR5toalMoveRRøtStartXtStartYtDestXtDestYt    WorldTickR>R¥R£RŠRŒR¼R9tGetPlayerVehicletpvNullR—t CheckMovePostGetDistRtDelLimitSuperBuffRút    GetPetMgrt GetFightPettNoneRBtFightPetFollowMove( R R!RR    tsendPack_StartXtsendPack_StartYtsendPack_DestXtsendPack_DestYtsendPack_WorldTicktvehicleR·tfightPet((sgD:\SG_ServerCode\ServerPython\ZoneServerGroup\map1_8G\MapServer\MapServerData\Script\Player\ChPlayer.pytPlayerFightMoveÚsT                          *cCso|jƒstS|jƒs tStj|ƒdkr9tStj|tjt    j
ƒsXtSt j |ƒsktSt S(Ni(RRt
GetCanMoveR2R3R    R
RR R5R RtPlayerCanStateTransferRE(R    ((sgD:\SG_ServerCode\ServerPython\ZoneServerGroup\map1_8G\MapServer\MapServerData\Script\Player\ChPlayer.pyRø3s   cCsdStjƒ}tj||||ƒs6|jƒdSt|||||||ƒsXdStj|tjƒ|j    ||ƒdS(N(
RR>RtPlayerMoveCheckClientWorldTicktSync_ClientTickRtChangePlayerActionR5tpaNulltMove(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¥tMoveFailRRRtDef_PlayerMaxMoveDistRE( 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(RRRR5tIPY_CCliectReborntGetTypeRçRRRR?tOnReqCrossServerRebornR tDoFBForbidRebornt
NotifyCodeR7tPlayerReborn_InFB(R RR    R$R»((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 checkHPStateRRt
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.pyR?Ùs  cCsŒ|d}tjƒ}t|||ƒs,dS|jtjƒ}t|||ƒidd6|d6}|j|ƒtjt    j
||gƒdS(NREitResultt ReviveTired( RR>RFR‘RtDef_PDict_IsAddReviveTiredt__DoPlayerReborntupdatetSendMsgToClientServerRãtCrossServerMsg_RebornRet(R    tmsgDatat serverGroupIDRR»tgameMaptisAddReviveTiredRL((sgD:\SG_ServerCode\ServerPython\ZoneServerGroup\map1_8G\MapServer\MapServerData\Script\Player\ChPlayer.pyRHés
  cCsX|d}|dkrdS|d}|d}t||tƒ|rTt||ƒndS(NRKiRERL(t __RebornCostREt__AddReviveTired(R    RRRtresultR»RU((sgD:\SG_ServerCode\ServerPython\ZoneServerGroup\map1_8G\MapServer\MapServerData\Script\Player\ChPlayer.pyRQûs
 
 
cCs`tjƒ}|jƒ|jƒ|_||_|jƒ|_|jƒ|_    t
j ||ƒdS(N( R2ttagPlayerRebornRÃRRRtTypeRŠR‹RŒRRR(R    R»t
rebornInfo((sgD:\SG_ServerCode\ServerPython\ZoneServerGroup\map1_8G\MapServer\MapServerData\Script\Player\ChPlayer.pytSyncPlayerReborn s 
    cCstjtƒ||ƒdS(N(RR`t__Func_PlayerDisconnect(R R((sgD:\SG_ServerCode\ServerPython\ZoneServerGroup\map1_8G\MapServer\MapServerData\Script\Player\ChPlayer.pytPlayerDisconnectscCswtjƒj|ƒ}yt||ƒWn*ddl}tjd|jƒƒnXtjt    |ƒƒ|j
|ƒdS(NiÿÿÿÿsÍæ¼ÒÏÂÏßÂß¼­´íÎó
%s( RRRtDoPlayerDisconnectRiRjRkRt    MapCallDBtGetPackSaveDatat DoDisconnect(R RR    Ri((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 WriteStringRJ(R    t roleSaveDatatallData((sgD:\SG_ServerCode\ServerPython\ZoneServerGroup\map1_8G\MapServer\MapServerData\Script\Player\ChPlayer.pyRa1s
cCstjd|jƒƒtj||ƒ|jtjƒƒtj|ƒtj    |t
j dƒtj    |t
j dƒt j|ƒtj|ƒtj|ƒdS(NsPlayerDisconnect!i(RRRRtPlayerLeaveServert SetLogoffTimeR R#tDR_PlayerDisconnectR)Rt!Def_Player_Dict_RouteServerInitOKtDef_PlayerKey_CrossRegisterMapRBtReCallFightPetR%tWriteEvent_sessionRtOnPlayerLogoff(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( RRRR5tIPY_CSetShutCutDatat
GetSettingtEncodingToUnicodetErrLogR¾RJt
SetSetting(R RR    R$tsetting((sgD:\SG_ServerCode\ServerPython\ZoneServerGroup\map1_8G\MapServer\MapServerData\Script\Player\ChPlayer.pytSetShutcutSettingHV{s   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(RRRtSetNumRtLittleHelperSetNumCountRxRRÙtLittleHelperValueCountthasattrtgetattrRR)t!Def_Player_Dict_LittleHelperValueRç(R R!RR    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}RR~R‘RRNttagMCLittleHelperFuncSetR|RtsetattrR"ttagMCLittleHelperSett FuncSetListRJt 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(RRRt
GuideIndextIsOKRÂRÙRtDef_GuideStateKeyCountRR)tDef_Player_Dict_GuideStateRçRxtSetDictValueByBit(R R!RR    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( RNttagMCGuideStatet
GuideStateRÙRRR"R‘RRJR#RR(R    tguideStatePackR&((sgD:\SG_ServerCode\ServerPython\ZoneServerGroup\map1_8G\MapServer\MapServerData\Script\Player\ChPlayer.pyR/ßs     $cCs)tjƒ}||_tj||ƒdS(N(RNttagMCShowGuidetGuideIDRR(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(RRRtGetPlayerLastActionR4(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( RRRR5tIPY_CSetHPRestoretGetValuetSetHPRestoreSettingR2R3RtPlayerAutoRestoreHP(R RR    R$tcurValue((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( RRRR5tIPY_CSetMPRestoreR¢tSetMPRestoreSettingR2R3RtPlayerAutoRestoreMP(R RR    R$R¥((sgD:\SG_ServerCode\ServerPython\ZoneServerGroup\map1_8G\MapServer\MapServerData\Script\Player\ChPlayer.pyRž0    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( R5tamPeacetamMaxRRçR¿R>tGetAttackModelsRÂt    NPCCommontClearSummonAngry_PlayerR­R®(R    t
attackModet attackModels((sgD:\SG_ServerCode\ServerPython\ZoneServerGroup\map1_8G\MapServer\MapServerData\Script\Player\ChPlayer.pytChangeAttackModeE    s 
cCs;tjƒj|ƒ}|jr$dnd}|j|ƒdS(Nii(RRRtAdultt ChangeAdult(R R!RR    tadult((sgD:\SG_ServerCode\ServerPython\ZoneServerGroup\map1_8G\MapServer\MapServerData\Script\Player\ChPlayer.pyt
PySetAdultg    s cCs\|jƒsdStj|ƒdkr)dStj|ƒtkrBdS|jƒtkrXdStS(Ni(RR2R3RR$RER#(R    ((sgD:\SG_ServerCode\ServerPython\ZoneServerGroup\map1_8G\MapServer\MapServerData\Script\Player\ChPlayer.pytCheckPlayerStopMover    s cCstjtƒ||ƒdS(N(RR`t__Func_PlayerCanResetWorldPos(R R((sgD:\SG_ServerCode\ServerPython\ZoneServerGroup\map1_8G\MapServer\MapServerData\Script\Player\ChPlayer.pytPlayerCanResetWorldPosŽ    scCs)tjƒj|ƒ}tj||ƒdS(N(RRRRtDoPlayerResetWorldPos(R RR    ((sgD:\SG_ServerCode\ServerPython\ZoneServerGroup\map1_8G\MapServer\MapServerData\Script\Player\ChPlayer.pyR¶—    scCs-tjƒj|ƒ}|jƒt|ƒdS(N(RRRt    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 µØÍ¼Çл»Ê§°Ü(
RDRERNttagMCChangeMapFailRÃRRRRR¾(R    R$((sgD:\SG_ServerCode\ServerPython\ZoneServerGroup\map1_8G\MapServer\MapServerData\Script\Player\ChPlayer.pyRº«    s   
cCs&tjƒj|ƒ}t||ƒdS(N(RRRt __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?R5R@RˆRRRtGetNameR¾R tCanPlayerLeaveFBtDoPlayerLeaveFBRt 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(RRRR5tIPY_CChangeLinetGetLineRxR¾RRˆRRRít__CheckCanChangLineRtPlayerChangeLine(    R RR    R$t 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_TickRRARR4R5tpaSitt DoPlayerStandtDef_PlayerChangLine_StatetIsPlayerInFightRtDef_PlayerChangLine_VehicleRE(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(R2R3R4R5R6RR¤trebornType_MainCityRR>R?R@RRROR§RˆtgetR‘RMRAt 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(R‘RRtintttimeRRç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)(R2R3R4R5R6R\RtDef_RebornTypeListRtrebornType_HealthtrebornType_UseItemtGetLocalRebornRRxRˆRæRçRèR‘RRRARRRVRR t OnCanFBRebornRE(R    R»RTRDRÓtrebornCDtcurTimetdeadTime((sgD:\SG_ServerCode\ServerPython\ZoneServerGroup\map1_8G\MapServer\MapServerData\Script\Player\ChPlayer.pyRFj
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(RR?RRRïRRt HaveMoneyExRãtTYPE_Price_Gold_Paper_MoneyRRxRtDef_Cost_ReviveRðR~tFindItemInPackByEffectExtDef_Effect_ReborntDelItemRE( R    R»tisDoCostRIRÓt    rebornCfgt
moneyPricet costMoneyListt    moneyTypetmoneyCntt
rebornItem((sgD:\SG_ServerCode\ServerPython\ZoneServerGroup\map1_8G\MapServer\MapServerData\Script\Player\ChPlayer.pyRV•
s* 
ic
    Cstj}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+ƒƒnt,j-|ƒtj.|t/j0ƒdS(NiitPKConfigiiè(1RtDef_MaxRateValueRR¤R tOnPlayerRebornRERR)RžRÜRötOnResetFBRebornPlacePosRARBRCR‘RMRWRRìR=t IsInPKStatetSetPKStateTickt IsInBossStatetSetBossStateTicktRefreshAllStateR2RÌRÍt    SetProDeft GetMaxProDeftOnPlayerRebornOverRR>R¥RŠRŒRŽRˆRŸtPlayerResetWorldPost GetRebornMapXt GetRebornMapYt    PlayerPett AutoSummonPetR'R5R((
R    R»Rt mapBornPlacetisAddSuperBufftresetHpPercentt
isFBRebornt    validTimeRKRT((sgD:\SG_ServerCode\ServerPython\ZoneServerGroup\map1_8G\MapServer\MapServerData\Script\Player\ChPlayer.pyRN²
sF          
$ %' + 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( RARÞRRßRàRáRâRBRRçRR)RM(R    RRåt buffSkillLV((sgD:\SG_ServerCode\ServerPython\ZoneServerGroup\map1_8G\MapServer\MapServerData\Script\Player\ChPlayer.pyRWó
scCsatjƒ}t|||ƒs"dStjƒsGt||tƒsGdSnt|||||ƒtS(s Íæ¼Ò¸´»î
    N(RR>RFRRVRERN(R    R»RRRRT((sgD:\SG_ServerCode\ServerPython\ZoneServerGroup\map1_8G\MapServer\MapServerData\Script\Player\ChPlayer.pyR7 s  cCs<tjƒjƒ}|tjkr%dStj|||ƒdS(N(RR>R?R5R@R t DoFBOnReborn(R    R»RRã((sgD:\SG_ServerCode\ServerPython\ZoneServerGroup\map1_8G\MapServer\MapServerData\Script\Player\ChPlayer.pyRB s
cCs2tjƒj|ƒ}tj||j|jƒdS(N(RRRRtPlayerEnterCrossServert    DataMapIDR‡(R 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(    RRRR5tIPY_CEnterFbGameEventRˆR†Rt PlayerEnterFB(R RR    R$RÉtclientSendLineID((sgD:\SG_ServerCode\ServerPython\ZoneServerGroup\map1_8G\MapServer\MapServerData\Script\Player\ChPlayer.pyRH s    c
    Csntjƒj|ƒ}|j}|j}|j}|j}|j}|j}    t    ||||||||    ƒdS(N(
RRRRZR‰R‡R‹RtExData1t__Func_WorldTransPort(
R R8RR    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-927DE1ACCC4F378ER'R((ii(RˆRRtTYPE_Player_Tick_WorldTransportRRRRRçRtDef_PackType_TransportTypeRRxRÝRtCheckPlayerTransporttCheckTagCountrytGetTransportPosRAtDef_Transport_Type_MissiontTransportVipLvRestricttPayForTransportR9tDef_PlayerKey_TransTypet
BeginTrans(
R    R&RÉR¸R¹RR'R(RÓt transportType((sgD:\SG_ServerCode\ServerPython\ZoneServerGroup\map1_8G\MapServer\MapServerData\Script\Player\ChPlayer.pyR%h s>&          R/c    Cs&tj||||||||ƒtS(N(RRR(R    RÉR¸R¹R'RÀtcanLockR(((sgD:\SG_ServerCode\ServerPython\ZoneServerGroup\map1_8G\MapServer\MapServerData\Script\Player\ChPlayer.pyR3© s"cCsX|jƒ|krNtjƒj||ƒsNtj||tjƒ\}}qNn||fS(N(RˆRR>R¥R R¡RR¢(R    R4ttransportMapIDt 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(RRìRER
R R5RxR~RÝtTransportPayMoneytTYPE_Price_Gold_PaperRRçRRá(R    R4RþtuseCountRêRítitemListt    costMoney((sgD:\SG_ServerCode\ServerPython\ZoneServerGroup\map1_8G\MapServer\MapServerData\Script\Player\ChPlayer.pyR1à scCsdS(Ni((R    R4((sgD:\SG_ServerCode\ServerPython\ZoneServerGroup\map1_8G\MapServer\MapServerData\Script\Player\ChPlayer.pyR0ö sc    CsŽtj|||ƒ}|gkr%tSxb|D]Z\}}|dkr,tj|||tji|d6ƒtj||dd||ƒq,q,WtS(Nit TransportType(    RR÷RRRtDef_Cost_TransportRtLogin_Interface_GoldRecRE(R    RtmoneyR4t    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(RRRURVRRRFt ExchangeTimeRÝRçRxRátGetOfflineMinutesRtGetPlayerReExpR^tevalR÷RRtDef_Cost_OffLineExptDef_Cost_Reason_SonKeytAddExpRítSetOfflineMinutestSyn_OfflineTimeQueryResult(R t curPackDataRtOfflineExpChangeDictR    tmulIndext exchangeTimetrecListtminVIPLvRât
useMinutest haveMinutestrExptreLVtworldLvExpRatet    redeemExpt moneyInfoListRR>RKt haveMoneyListRt offlineTime((sgD:\SG_ServerCode\ServerPython\ZoneServerGroup\map1_8G\MapServer\MapServerData\Script\Player\ChPlayer.pytPlayerExpExchange sR         
 
!  
cCsdS(N((R R!R((sgD:\SG_ServerCode\ServerPython\ZoneServerGroup\map1_8G\MapServer\MapServerData\Script\Player\ChPlayer.pytReceiveFamilyArrestAwardq scCs#tjƒj|ƒ}t|ƒdS(N(RRRt"Sync_FamilyArrestAwardReceiveState(R R!RR    ((sgD:\SG_ServerCode\ServerPython\ZoneServerGroup\map1_8G\MapServer\MapServerData\Script\Player\ChPlayer.pyt"QueryFamilyArrestAwardReceiveState s
cCsEtjƒ}|jƒ|jtjƒ}||_tj||ƒdS(N(    RNt tagFamilyArrestAwardReceiveStateRÃR‘Rt&Def_Player_Dict_FamilyArrestAwardStatet ReceiveStateRR(R    tawardReceiveStatetstate((sgD:\SG_ServerCode\ServerPython\ZoneServerGroup\map1_8G\MapServer\MapServerData\Script\Player\ChPlayer.pyRaŠ s  
    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’RR)R“R”R•R–R›RœRRžt
ADCntOnDay(R    R£R¤R§((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|ƒn»|tjkr2tj|ƒnœ|tjkrTtj||ƒnz|tjkrytj |||ƒnU|tj!kr›t"j#||ƒn3|tj$krÀt%j&|||ƒn|tj'kråt(j)|||ƒné|tj*kr
t+j,|||ƒnÄ|tj-kr/t.j/|||ƒnŸ|tj0krQt1j2||ƒn}|tj3krpt4||ƒn^|tj5krt6j7|ƒn?|tj8kr±t9j:||ƒn|tj;krÖt<j=|||ƒnø|tj>krût<j?|||ƒnÓ|tj@kr tAjB|||ƒn®|tjCkrEtDjE|||ƒn‰|tjFkrjtDjG|||ƒnd|tjHkrŒtIjJ||ƒnB|tjKkr®tLjM||ƒn |tjNkrÓtOjP|||ƒnû|tjQkrøtRjS|||ƒnÖ|tjTkrtUjV|||ƒn±|tjWkr?tXjY||ƒn|tjZkrat[j\||ƒnm|tj]kr†t^j_|||ƒnH|tj`kr«tajb|||ƒn#|tjckrÐtdje|||ƒnþ|tjfkrõtgjh|||ƒnÙ|tjikrtjjk||ƒn·|tjlkr<tmjn|||ƒn’|tjokratpjq|||ƒnm|tjrkrƒtjs||ƒnK|tjtkr¢tujv|ƒn,|tjwkr¾tx|ƒn|tjykràtzj{||ƒnî|tj|krt}j~||ƒnÌ|tjkr$tj€||ƒnª|tjkrFt‚jƒ||ƒnˆ|tj„krkt…j†|||ƒnc|tj‡krŸtˆ||tj‰tŠj‹ddƒƒn/|tjŒkrÓtˆ||tjtŠj‹ddƒƒnû|tjŽkrtˆ||tjtŠj‹ddƒƒnÇ|tjkr;tˆ||tj‘tŠj‹ddƒƒn“|tj’kr¯tj“ƒj”t•j–ƒd}tŠj—ddƒ}    ||    krÎtˆ||tj˜tŠj‹ddƒdƒqÎn|tj™krÎtš||ƒndS(    Ns5PlayerGetReward: rewardType=%s,dataEx=%s,dataExStr=%stGameNoticeRewarditShareGameRewardtGoodGameRewarditOpenServerDailyAwardi(›RRRt
RewardTypetDataExt    DataExStrRçRtDef_RewardType_ActivityR¹tGetActivityAwardtDef_RewardType_DailyTasktGetDailyTaskAwardtDef_RewardType_SuccessRRtGetSuccessAwardtDef_RewardType_TreeFreeTimeR³tFreeReduceTreeLVTimetDef_RewardType_ADAwardt OnGetADAwardtDef_RewardType_LLMJLVUpRºt
OnLLMJLVUptDef_RewardType_DayFreeGoldGiftRhtOnGetDailyFreeGiftbagtDef_RewardType_LVAwardR<tGetPlayerLVAwardtDef_RewardType_FirstChargeR?tGetPlayerFirstChargetDef_RewardType_FreeGoodsRstOnGetFreeGoodstDef_RewardType_CostRebateRatOnGetCostRebateAwardtDef_RewardType_TotalRechargeRbtOnGetTotalRechargeAwardtDef_RewardType_ManyDayRechargeR‚tOnGetManyDayRechargeAwardtDef_RewardType_SingleRechargeRƒtOnGetSingleRechargeAwardtDef_RewardType_BossRebornRttGetBossRebornActionAwardtDef_RewardType_DownLoadtGetDownloadAwardtDef_RewardType_WishingWellRˆtDoGetWishingAwardtDef_RewardType_OpenFuncR@tGetFuncOpenAwardtDef_RewardType_WeekPartyActRutGetWeekPartyActionAwardtDef_RewardType_WeekPartyPointtGetWeekPartyPointAwardtDef_RewardType_ActLoginAwardActRtGetLoginAwardActionAwardt Def_RewardType_FeastWeekPartyActR{tGetFeastWeekPartyActionAwardt"Def_RewardType_FeastWeekPartyPointtGetFeastWeekPartyPointAwardtDef_RewardType_FeastLoginR|tGetFeastLoginAwardtDef_RewardType_FeastTravelR~tGetFeastTravelAwardtDef_RewardType_ActLoginAwardNewRztOnGetActLoginAwardtDef_RewardType_ActBuyCountGiftRvtOnGetBuyCountGiftAwardtDef_RewardType_ActTaskRwtOnGetActTaskAwardt#Def_RewardType_CACTGBillboardDabiaoR_tGetDabiaoAwardtDef_RewardType_CAAllRechargeR`tGetCrossActAllRechargeAwardt!Def_RewardType_CrossYaomoBossHurttPlayerCrossYaomoBosstGetCrossYaomoBossHurtAwardtDef_RewardType_BuyOneRjtGetBuyOneFreeAwardtDef_RewardType_FamilyCTGAssistRktGetFamilyCTGAssistAwardtDef_RewardType_FamilyGCZRµtGetFamilyGCZAwardtDef_RewardType_TiandaoTreeR®tGetTiandaoTreeAwardtDef_RewardType_TreasureCntAwardRItGetTreasureCntAwardtDef_RewardType_LunhuidianAwardRytGetLunhuidianAwardt!Def_RewardType_HistoryChargeAwardtOnGetHistoryRechargeAwardtDef_RewardType_OnlineRechargeTHR>tOnGetOnlineRechargeTHtDef_RewardType_CreateRoletOnGetCreateRoleAwardtDef_RewardType_CustomAwardRtOnGetCustomAwardtDef_RewardType_RealmLVUpTaskR6tGetRealmLVUpTaskAwardtDef_RewardType_DailyPackBuyGifttGetDailyPackBuyGifttDef_RewardType_TaskR²t GetTaskAwardtDef_RewardType_ZhanlingR±tGetZhanlingRewardR”tOnGiveAwardByClientR’RRR–R•R˜R—RšR™RœRáRâRãtDef_Notify_WorldKey_ServerDayRìR›RžtOnGetRechargeDayAward(
R R!Rt playerManagerR    t
rewardTypetdataExt    dataExStrt openServerDaytopenServerDayLimit((sgD:\SG_ServerCode\ServerPython\ZoneServerGroup\map1_8G\MapServer\MapServerData\Script\Player\ChPlayer.pytPlayerGetReward¶ sà              %%%% +cCstjd|ƒ}|sdS|jƒ}|jtj|ƒ}||krhtjd|||fƒdS|d7}tj    |tj||ƒ|j
ƒ}|j ƒ}tjd||||fƒt ||gƒ|rêt j||ƒn|rtj||ddtigƒndS(NtADAwards-½ñÈÕ¸Ã¹ã¸æ½±ÀøÒÑ´ïÉÏÏÞ! adID=%s,adCnt=%s > %sis:ÁìÈ¡¹ã¸æ½±Àø! adID=%s,adCnt=%s,adMapID=%s,awardItemList=%stevent(RRÉt GetADCntMaxR‘RtDef_PDict_ADCntRRçRR)tGetADAwardItemListt
GetADMapIDR·ROt
AddFBADCntR0tGivePlayerItemOrMailR(R    tadIDtipyDatatadCntMaxtadCntt awardItemListtadMapID((sgD:\SG_ServerCode\ServerPython\ZoneServerGroup\map1_8G\MapServer\MapServerData\Script\Player\ChPlayer.pyRza 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ÙRR)R"R·(R    t syncADIDListRåR RßRÞ((sgD:\SG_ServerCode\ServerPython\ZoneServerGroup\map1_8G\MapServer\MapServerData\Script\Player\ChPlayer.pyRhy s  c
Cs!|sItjƒ}gt|jƒƒD]}|j|ƒjƒ^q%}n|}g}xt|D]l}|jtj|ƒ}| r‘|dkr‘q\nt
j ƒj t jƒ}||_||_|j|ƒq\W|sÖdSt
j ƒj t jƒ}    |d |    _t|    jƒ|    _tj||    ƒdS(Niÿ(RRØRÙRäRåRæR‘RRÙRtObjPoolt
GetPoolMgrtacquireRNt tagSCADInfotADIDtADCntR"ttagSCADInfoListt
ADInfoListRJR#RR(
R    RçRåR&tadIDListt
adInfoListRÞRátadInfoR8((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_CTGRealTotalRRRRWRçRRçRR~t GiveAwardItemRR)R“(
R    RÐt    realTotaltawardCoinRecordt    awardCoinRât 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~RõRRRR)RŽ(R    ((sgD:\SG_ServerCode\ServerPython\ZoneServerGroup\map1_8G\MapServer\MapServerData\Script\Player\ChPlayer.pyRÁ¶ s 
cCs?tjƒ}|jƒ|jtjƒ|_tj||ƒdS(N(    RNttagMCCreateRoleAwardStateRÃR‘RRýR”RR(R    R$((sgD:\SG_ServerCode\ServerPython\ZoneServerGroup\map1_8G\MapServer\MapServerData\Script\Player\ChPlayer.pyRŽà s
 
cCsj|j|ƒr*tjd||fƒdStj|||ƒsCdStj||dƒt||dƒdS(Ns)ÒÑÁìÈ¡¹ý¸Ã½±Àø! rewardType=%s, dictKey=%si(R‘RRçR~RõRR)R“(R    RÐtdictKeytawardCfgt    eventName((sgD:\SG_ServerCode\ServerPython\ZoneServerGroup\map1_8G\MapServer\MapServerData\Script\Player\ChPlayer.pyRÌÊ scCs<tjƒ}|jƒ||_||_tj||ƒdS(N(RNttagMCPlayerRewardGetRecordRÃRntRewardGetRecordRR(R    RÐtrewardGetRecordR$((sgD:\SG_ServerCode\ServerPython\ZoneServerGroup\map1_8G\MapServer\MapServerData\Script\Player\ChPlayer.pyR“Ú 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    AreaSkillRXtHPPackagePercent( RRRRJtDataRURVRÝRÈRR)RtDef_PDict_AutoFightSetting(R R!RR    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(NRRiRRXRs%s(RURVRÙR‘RR
R"RNttagMCAutoFightSettingRÃR    RJtSizeRR( R    R R RR RRRRRRR$((sgD:\SG_ServerCode\ServerPython\ZoneServerGroup\map1_8G\MapServer\MapServerData\Script\Player\ChPlayer.pytSync_AutoFightSettings:
 
 
 
 
 cCs#tjƒj|ƒ}|sdSdS(N(RRR(R R!RR    ((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    NPCIDListRJt BaseExceptionRxt
isinstancetlistRR>RˆR¬t
GetNPCInfoR5t GetMapCopyPlayerManagerByFbIndextGetPlayerCountt SyncNPCInfotGameServer_QueryPlayerByIDtqueryType_NPCInfoRJ(R R!RR    ttickTypettagMapIDt    tagLineIDt queryNPCStrt    npcIDListR[t npcInfoDictt    gameWorldRÏt    playerCnttsendMsg((sgD:\SG_ServerCode\ServerPython\ZoneServerGroup\map1_8G\MapServer\MapServerData\Script\Player\ChPlayer.pytOnQueryMapNPCInfo5sN                                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(RRRRtCheckPlayerTickRRRçR‰R‡RRJRRxRR RR>RˆR¬t GetNPCCntInfotSyncNPCCntInfoR%tqueryType_NPCCntRJ( R R!RR    R(R)R*R+R[R,R/((sgD:\SG_ServerCode\ServerPython\ZoneServerGroup\map1_8G\MapServer\MapServerData\Script\Player\ChPlayer.pytOnQueryMapNPCCntInfous@                           cCs#tjƒj|ƒ}|jƒdS(N(RRRR&(R R!RR    ((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|_tjƒ|_tj||ƒdS(N(RtGetCurrentTimeRNttagServerDateTimeRÃtyeartYeartmonthtMonthtdaytDaythourtHourtminutetMinutetsecondtSecondt microsecondt    MicSecondtGetCrossServerTimeStrtCrossServerTimeRR(R    t
serverTimetserverDateTime((sgD:\SG_ServerCode\ServerPython\ZoneServerGroup\map1_8G\MapServer\MapServerData\Script\Player\ChPlayer.pyR®s  
       cCsîtjƒ}|sdStjƒ}tjƒjtjƒ|_    tjƒjtj
ƒ|_ tjƒjtj ƒ|_ tjƒjtjƒ|_|j|_|j|_|j|_|j|_|j|_|j|_|j|_tjƒ|_t j!||ƒtj"ƒ}tj#ƒ}|j$ƒ|j%tj&ƒ|_    |j%tj'ƒ|_ |j%tj(ƒ|_ |j%tj)ƒ|_|j|_|j|_|j|_|j|_|j|_|j|_|j|_tjƒ|_t j!||ƒdS(N(*RR8RNttagMCOpenServerDayt    DBDataMgrtGetEventTrigMgrR¢Rãt Def_ServerDayR?tDef_IsMixServert IsMixServertDef_MixServerDaytMixDaytDef_OpenServerWeekdayt OpenWeekdayR:tNowYearR<tNowMonthR>tNowDayR@tNowHourRBt    NowMinuteRDt    NowSecondRFt NowMicSecondt GetWeekOfYeart
WeekOfYearRRRáttagOpenServerDayRÃRâRÍRät Def_Notify_WorldKey_MixServerDayt%Def_Notify_WorldKey_OpenServerWeekday(R    RJR8tgwtpackData((sgD:\SG_ServerCode\ServerPython\ZoneServerGroup\map1_8G\MapServer\MapServerData\Script\Player\ChPlayer.pyRÆsD           
       cCstjƒj|ƒ}|jtjƒtjkr4dSt|||ƒsÿ|jƒ|j    ƒ}}tj
ƒj ||ƒt krìt j||dƒ}|jƒ|krÑ|j    ƒ|krÑtjd||fƒdS|jƒ}|j    ƒ}n|j||ƒndS(NisÍæ¼Ò×ø±ê¿¨ËÀ %s %s(RRRR‘RRRtPYPlayerNormalMoveRŠRŒR>R¥RER tGetEmptyPlaceInAreaRxR£(R R8RR    R¸R¹t    resultPos((sgD:\SG_ServerCode\ServerPython\ZoneServerGroup\map1_8G\MapServer\MapServerData\Script\Player\ChPlayer.pyt PYPlayerMoveþs $ tPYMoveDistCalcTickt PYMoveDistSumc CsÙt|ƒ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|ƒ|j+ƒj,ƒ}|rÕ|    dks¬||j-ƒdkrÕt.j/|||ƒ|j0tj1ƒqÕntS(Nii2smove ·¢°üÌ«¿ì ÊÕ°ü%s - ÉÏÒ»´Î%ss
ÒÆ¶¯Õϰ­µãiÞis)ÒÆ¶¯¾àÀë¹ý´ó£¬ Íæ¼Ò×ø±ê %s-%s  ÊÕ°ü %s-%siáõt PyMoveCheckiigY@sU    dist=%s,distSum=%s,speed=%s,needTick=%s, ËùÐèÒÆ¶¯Ê±¼äÒì³£ passCalcTick(%s) < (%s)i,(2RøREtDirt
ClientPosXt
ClientPosYt    SeverPosXt    SeverPosYRRýtGetClientMoveTickRRçR>R¥RRŠRŒR9tMoveDistCalcTickt MoveDistSumtSetClientMoveTicktPyNotifyPlayerMoveR?R5R@R t DoFBCanMoveRRR—RR%R&RR¾R¼tminRRìtGetSpeedR'R(RúRRt GetActionTickRBRt SetCurActiont    laNPCNull(R    R8RtmoveDirt
clientPosXt
clientPosYtsendPack_SeverPosXtsendPack_SeverPosYRtmoveTypet lastMoveTickR tdisttcalcTicktdistSumtspeedt passCalcTicktneedTickt checkNeedTickR!((sgD:\SG_ServerCode\ServerPython\ZoneServerGroup\map1_8G\MapServer\MapServerData\Script\Player\ChPlayer.pyRds|                               $  
$  
 
     # "cCstjƒ}|jƒ|jƒ|_tj|_||_||_    ||_
||_ ||_ |j ƒ|_||_tj||tdƒdS(Ni(RNttagMCPYPlayerMoveRÃR¾R6R5t    gotPlayerR5RkRlRmRnRoRwtSpeedRýRRþR(R    R{R|R}R¸R¹R€R$((sgD:\SG_ServerCode\ServerPython\ZoneServerGroup\map1_8G\MapServer\MapServerData\Script\Player\ChPlayer.pyRtŽs 
                         cCsÀ|jƒ}tjddƒ}|jtjƒ}||krZtjd||f|ƒdStjddƒ}|svdSt    j
|tj|ƒtjd||f|ƒt    j d|g|ƒdS(Nt
DownRewardis:ÒÑ·¢·ÅÏÂÔØ²¹¶¡°ü½±Àø! curAwardNum(%s) == patchAwardNum(%s)is3·¢·Å²¹¶¡°üÏÂÔØ½±Àø: curAwardNum=%s,patchAwardNum=%stDownloadPatchAward( RRRìR‘RtDef_PDict_DownloadPatchAwardRRçRRR)RÐ(R    RÓt patchAwardNumt curAwardNumRâ((sgD:\SG_ServerCode\ServerPython\ZoneServerGroup\map1_8G\MapServer\MapServerData\Script\Player\ChPlayer.pyR;Ÿs  c Csk|jƒ}tjddƒ}|jtjƒ}||krZtjd||f|ƒdStjddƒ}|svdS|dkrÉt    |ƒ}t
j |t j |ƒ}||krÉtj|dƒdSntj|tj|ƒtjd||f|ƒ|dkr$tjd|jƒg|ƒn9x6|D].\}}    }
tj|||    dt j gƒq+Wt|ƒdS(    NRŒis7ÒÑÁìÈ¡·Ö°ü½±Àø! curAwardNum(%s) == downloadAwardNum(%s)iitGeRen_chenxin_998371s4ÁìÈ¡·Ö°üÏÂÔØ½±Àø: curAwardNum=%s,downloadAwardNum=%stSubpackageDownload(RRRìR‘RtDef_PDict_DownloadAwardStateRRçRRJR~tGetItemPackSpaceR5RxRRAR)RÐR¾R0tGivePlayerItemR…( R    RÑRÓtdownloadAwardNumRRât    needSpacet    packSpaceRþtitemCntR((sgD:\SG_ServerCode\ServerPython\ZoneServerGroup\map1_8G\MapServer\MapServerData\Script\Player\ChPlayer.pyR±s.      #
cCsWtjddƒ}tjƒ}|jƒ|jtjƒ|k|_t    j
||ƒdS(NRŒi( RRìRNttagMCPackDownloadRecordRÃR‘RR“tRecordRR(R    R–R$((sgD:\SG_ServerCode\ServerPython\ZoneServerGroup\map1_8G\MapServer\MapServerData\Script\Player\ChPlayer.pyR…Ðs  
cCsEtjƒ}|jƒ||_||_||_tj||ƒdS(s»Í¨ÖªÇ°¶ËÏòij¸öµãÒÆ¶¯
                ÕâÀïǰ¶Ë¿ÉÄÜÐèÒªÕë¶Ôij´ÎÒÆ¶¯×ö¶îÍâ´¦Àí£¬±ÈÈçÒÆ¶¯µ½Ä³¸öµãºóÐèÒª×Ô¶¯Õ½¶·µÈ
                ËùÒÔÕâÀïÖ»×ö֪ͨǰ¶Ë¿ÉÒÔÏòij¸öµãÒÆ¶¯£¬×îÖÕÒÆ¶¯ÓÉǰ¶Ë·¢Æð
    N(RNttagMCNotifyPlayerMoveRÃR‹RtNPCIDRR(R    R¸R¹tnpcIDR$((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_PerPointValueR2R3RtSetDeadRÌ(R R!RR    tlostHPtcurHPtupdHPRK((sgD:\SG_ServerCode\ServerPython\ZoneServerGroup\map1_8G\MapServer\MapServerData\Script\Player\ChPlayer.pyt OnRoleLostHPîs
  cCsdS(N((R R!R((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_ViewGameRecSelfListRRMt GetGameRecMgrtGetRecTypeIDMgrtSyncGameRecInfot GetDataList(R R!RR    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(!RNt tagSCGameRectGetTimetTimet    GetValue1tValue1t    GetValue2tValue2t    GetValue3tValue3t    GetValue4tValue4t    GetValue5tValue5t    GetValue6tValue6t    GetValue7tValue7t    GetValue8tValue8t GetUserDatatUserDataRJt UserDataLenR"ttagSCGameRecInfoRÃR©RªtRecListR#RR(R    R±R²t recDataListRTtrecDatatrecR8((sgD:\SG_ServerCode\ServerPython\ZoneServerGroup\map1_8G\MapServer\MapServerData\Script\Player\ChPlayer.pyR¯s2   
            (R=R5RRR RRXR RDR¬RAR RmR~R0RqR›RURBR    RãRRNR#R8R<R?RBRR6RVRKR4RQR¹RORˆRRRsRYRZR@RtRuR{R~R|R}RRIRoRR%RMR¯RiRgRhRaRjReRlRbRdR€RRkRcR‚RƒRfRŒR®R[R‰RãR_R`RR„RR@R2R\RQR>RTR‡RWR‹RFt
SkillShellR¯R°RR±R³RºRHR²R±RUR2R*R®R´RzRvRyRµRxRwR¬RMR¸ReRhRft    PyMongoDBRR©R¶R«RR.R­RètdatetimeRètmathtreRcRR
RR)R.RMR1RRRÁR:R-R7R    RR)R<R*R"R=RNRbRaRmRlR!RƒRRdR®RÁR“RÖRóRÌRÿRR"RøR/RERRCR?RHRQR\R^R]RaR_R{R„RŠR”R/RœR RœRžR°R´RµR·R¶R»RºR¾R½RÍRÆRæRìRRFRVRNRWR7RBRR RR)R%R3R.R1R0R:R_R`RbRaRiRÕRzRhR·RÎRÁRŽRÌR“RRRR0R6R7RRRgRqRrRdRtR;RR…RŸR§R¨R´R¯(((sgD:\SG_ServerCode\ServerPython\ZoneServerGroup\map1_8G\MapServer\MapServerData\Script\Player\ChPlayer.pyt<module>sü                                                                                                                                                                 #    Š        ÿ     )            0    D         ,        
        >            
        
    B    A    
        ­                 %    2 !    $    :    Y    +    ' 6                                          =            "        
                     "                                      
    !    )    "    #     +    A                             A                    X                        #    «                                    (    
    @    /    
        8        x