hxp
2025-08-25 b7154533a3f9db72d0dfc28f21b19ee4aadf1b51
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
9¬hc@sT 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`ddlaZaddlbZbddlcZcddldZdddleZeddlfZfddlgZgddlhZhddliZiddljZjddlkZkddllZlddlmZmddlnZnddloZoddlpZpddlqZqddlrZrddlsZsddltZtddluZuddlvZvddlwZwddlxZxddlyZyddlzZzddl{Z{ddl|Z|ddl}Z}ddl~Z~ddlZddl€Z€ddlZddl‚Z‚ddlƒZƒddl„Z„ddl…Z…ddl†Z†ddl‡mˆZˆddl‰Z‰ddlŠZŠddl‹Z‹ddlŒZŒddlZddlŽZŽddl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´d%„Zµd&„Z¶d'„Z·d(„Z¸gd)„Z¹d*„Zºd+„Z»d,„Z¼d-„Z½d.„Z¾e¿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ÛdK„ZÜdL„ZÝdM„ZÞdN„Zßeàe¿dO„ZádP„ZâdQe¿dR„ZãdS„ZädQe¿dT„ZådU„ZædV„ZçdW„ZèdX„ZédY„ZêddQdZ„Zëdd[e¿dQd\„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ùd[dj„Zúdk„Zûdl„Züdm„Zýdn„Zþdo„Zÿdp„Zdq„Zdr„Zds„Zdt„ZduZdvZdw„Zdx„Zdy„Z    dz„Z
d{„Z dQd|„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    Csltjƒj|ƒ}t|ƒtj|ƒdksI|jƒtjkr_t    |t
j |ƒn|j t
j dƒtj|ƒ}|jƒt|ƒtj|ƒtj|ƒrÁtj|ƒn|jt
jƒ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 GetDictByKeytDef_PlayerKey_ClientCustomScenetPlayerFBtDoExitCustomScenet
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.pyR1!sÊ 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 IsCrossServertSetForbiddenSyncClientStateRIt__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ƒrttj||ƒt||ƒtj    |ƒt
j |ƒt j ||ƒdStj|ƒ}|tjdkrýtj|tjdƒtj|tjdƒtj|tjdƒtj|ƒrýtj|dƒqýnt|ƒtj|ƒt|ƒtj|ƒtj|ƒtj|ƒtj||ƒt |ƒt!|ƒt||ƒtj"|ƒtj#|ƒt$j%|ƒt&j%|ƒt
j |ƒt'|ƒt(j)|ƒt*||ƒt+|ƒt,|ƒt-|ƒt j ||ƒt.j/|ƒt0j1||ƒt2j3|ƒt4j%|ƒt5j%|ƒt6j7|ƒt8j9|ƒtj|ƒj:|ƒt;j<|ƒt=j>|ƒt?j@|ƒtAj|ƒtBjC|ƒtDjE|ƒtFjG|ƒtHjI|ƒtJj%|ƒtKjL|ƒtMj%|ƒtNjO|ƒtPj|ƒtQjR|ƒtSj||ƒtTjU|ƒtVjW|ƒtXjY|ƒtZjR|ƒt[jR|ƒt\j|ƒt]j%|ƒtj^|ƒtj_|ƒt`|ƒtaj|ƒtbj|ƒtcj|ƒtdj|ƒtej|ƒtfj|ƒtgj|ƒthj|ƒtij|ƒtjj|ƒtkj|ƒtlj|ƒtmj|ƒtnj|ƒtojp|ƒtqjr|ƒtsj|ƒttju|ƒtvjw|ƒtxj|ƒtyjz|ƒt0j{||ƒt|j%|ƒt}j%|ƒt~j|ƒtj%|ƒt€j%|ƒtj|ƒt‚j|ƒtƒj|ƒt„j|ƒt…j|ƒt†j%|ƒt‡j|ƒtˆj|ƒt‰j|ƒtŠj%|ƒt‹j|ƒtŒj|ƒtj|ƒtŽj|ƒtj|ƒtj|ƒt‘j|ƒt’j|ƒt“j|ƒt”|ƒt6j•|ƒt–j|ƒt—j%|ƒt˜j%|ƒt™|ƒtšj%|ƒt›jœ|ƒtj|ƒtžj|ƒtŸ|ƒt j|ƒt¡j|ƒ|j¢tj£ƒ}|rét¤|tj¥|ƒn|j¢tj¦ƒ}|rt¤|tj§|ƒn|j¢tj¨ƒ}|rEt¤|tj©|ƒn|j¢tjªƒ}|rst¤|tj«|ƒn|j¢tj¬ƒ}|r¡t¤|tj­|ƒn|j¢tj®ƒ}|rÏt¤|tj¯|ƒn|j°dƒ|j±dƒtj²|ƒtj    |ƒdS(s2 Íæ¼ÒµÇ¼ÐèÒª´¦ÀíµÄÄÚÈÝ£¬±¾·þ¼°¿ç·þ·þÎñÆ÷·Ö¿ª
    Nièi(³t SetLoginTimeRtGetCurrentDataTimeStrtInitPlayerPackRt SkillCommont PlayerLoginMergeServerSkillLogictDoPlayerLoginInMaptDataRecordPacktDR_PlayerLogint EventReporttWriteEvent_loginRFtDoLogic_PetInfo_OnLoginRtGetPlayerLeaveServerSecondRtDef_PlayerOfflineProtectTimetNomalDictSetPropertyt Def_Player_Dict_PlayChangeLineIDt Def_Player_Dict_FuncChangeLineIDt Def_Player_Dict_HighChangeLineIDR?R t__FirstLoginOnEntert
TurnAttackRtSyncGuideStatet ItemControlertUpdPlayerServerGroupIDtPlayerLoginCheckLearnSkilltPlayerLoginUpdateSkillCDt__Sync_ClientSkillR<tSyncOnLineTimeTotaltSyncTrainRealmLVtPlayerGodWeapontOnLogintPlayerPrestigeSyst__DoMixServerFirstLogintPlayerBillboardtBillboardOnLogint__Sync_PlayerOfflinet__SyncPlayerInfoExtGiveDownloadPatchAwardt SyncPKModelt    PlayerPettOnPlayerPetLogintPlayerGameWallowtCalc_Wallow_OfflineTimet PlayerLVAwardtSync_LVAwardGetRecordInfot
PlayerCointPlayerGoldGiftt GameFuncCommtSync_FuncOpenStatet PlayerSignDaytSignDayOnLogintNotifyPlayerDeadTimetUpdatePlayerNametSync_UpdatePlayerNameCountt PlayerHorsetPlayerHorseLogint
PlayerFaQitPlayerFaQiLogint PlayerLianTitPlayerTreasuretOnTreasureLogintPlayerLoginDayAwardtOnLoginNotifyLoginDayAwardtOpenServerCampaigntOnOpenServerCampaignLogint    NPCCommontSyncCollNPCTimetPlayerActivitytFBCommont    FBOnLogintPlayerGoldInvestt PlayerSuccesst SuccOnLogint PlayerCharmt
PlayerLoveR"t PlayerFamilytPlayerDienstgradtSync_AllDienstgradOnLogint PlayerRecovertRecoverOnLogint
PlayerCoatt OnLogin_CoattPlayerCrossRealmPKtPlayerCrossChampionshiptPlayerLuckyCloudBuyt PlayerArenatNotifyPlayerAllCurrencytNotifyUseMoneyTotaltNotifyPlayerBasePointtCrossActCTGBillboardtCrossActAllRechargetPlayerCostRebatetPlayerActTotalRechargetPlayerActRechargeRebateGoldtPlayerActRechargePrizetPlayerActGrowupBuytPlayerSpringSaletPlayerFlashGiftbagtPlayerDailyGiftbagtPlayerFlashSaletPlayerActBuyOnetPlayerActFamilyCTGAssisttPlayerActCollectWordstChItemtSync_ItemDayUseCntt
PlayerRunetPlayerRuneLogintPlayerFamilyRedPackettPlayerFeastRedPackettDoPlayerOnLogintFunctionNPCCommontShopItemOnLogintPlayerOnlinePrizetPlayerEquipDecomposet PlayerLogintDoLogic_CheckWallowtPlayerFreeGoodstPlayerBossReborntPlayerActBossTrialtPlayerActHorsePetFeasttPlayerWeekPartytPlayerActBuyCountGiftt PlayerActTasktPlayerActYunshitPlayerActLunhuidiantPlayerActLoginNewtPlayerFeastWeekPartytPlayerFeastLogintPlayerFeastWishtPlayerFeastTraveltPlayerActLogintPlayerActGarbageSortingtPlayerActXianXiaMJtPlayerActGubaotPlayerActHorsePetTraintPlayerActLianqitPlayerActGodGifttPlayerActManyDayRechargetPlayerActSingleRechargetPlayerActTurntabletSyncPackDownloadAwardtDoFuncOpenLogict
PlayerDogztPlayerWishingWelltPlayerLuckyTreasuretSyncLittleHelperRDt
SkillShelltNotifyElementSkillInfotGY_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Æs2
 
 
 
 
 
 
 
 
 
 
 
 
      cCsKtjd|jƒƒtjƒr%nÓtjƒj|ƒtj|ƒtj|ƒt    j|ƒt
j|ƒt j|ƒt j|ƒt j|ƒtj|ƒtj|ƒtj|ƒtj|ƒ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 PlayerChatBoxt
PlayerFacetPlayerXiangongt PlayerGubaotPlayerShentongtPlayerZhanlingt
PlayerTaskt
PlayerTreetPlayerMineAreat PlayerGuajitPlayerActFamilyGCZt
PlayerTalktSendDBQueryRechargeRBRt!Def_PlayerKey_MixServerFirstLoginRRRMtGetIDRN(R    RtisMixServerFirstLogintmsg((sgD:\SG_ServerCode\ServerPython\ZoneServerGroup\map1_8G\MapServer\MapServerData\Script\Player\ChPlayer.pytDoPlayerRealLoginOK s.               
.cCsHtjƒ}|jƒ|jƒ|_|jƒ|_tj||ƒdS(N(RRttagMCPlayerInfotCleartIsAdulttGetCreateRoleTimetCreateRoleTimeRR(R    t playerInfoEx((sgD:\SG_ServerCode\ServerPython\ZoneServerGroup\map1_8G\MapServer\MapServerData\Script\Player\ChPlayer.pyRE4s  
cCs|jƒ}|jtjƒr"dStjd|ƒtj|dƒtj    |tj
|ƒƒ|j ƒdkr}t j |ƒntj|jƒ|jƒ|ƒtjddƒ}x0|D](\}}tj||jƒg|ƒqµWtj|ƒtj|tjdƒdS(NsÍæ¼ÒÊǵÚÒ»´Î½øÈëÓÎÏ·iit MailLVAwardi(RäRºRtDef_Player_Dict_FirstLoginRRR+tWriteEvent_EntryR2tSetHPtGetMaxHPRbRPR®R)t DR_FirstLoginRTtGetIPRRRt SendMailByKeyRRÔtOnPlayerFirstLoginR0(R    tplayerIDtmailListt mailTypeKeyt mailItemList((sgD:\SG_ServerCode\ServerPython\ZoneServerGroup\map1_8G\MapServer\MapServerData\Script\Player\ChPlayer.pyR4=s    c
Csçtjƒjtjƒ}|s"dS|jƒ}tjƒjtjƒ}|jtj    ƒ}||kr|tj
d||ƒdStjƒjtj ƒ}tj d||f|ƒt j|tj    |ƒ|jƒdkrêtj d|ƒdS|jtjdƒtj|dƒtj|dgƒtjddƒ}tjddƒ}tjdd    ƒ}tjdd
ƒ}    td ||    ƒ}
|\} } g} x¥|D]\}}}tjƒj|ƒ}|sÄq”n|jd ƒ}|jƒ}|tjkrôq”n|jdƒ}|sq”n||
kr0|||gg} q”Pq”Wi|d 6|d6|
d6}|| }tj d|
|f|ƒt j d|g|d| d| d|ƒt!j"|dt#ƒt$j%|ƒt&j%|ƒt'j%|ƒt(j%|ƒ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_LastMixServerWorldLVRRR0RbR9RãRNtDoResetCTGCountRtResetShopItemBuyCountRRt
GetFuncCfgtmaxt GetGameDatatGetItemByTypeIDtGetEffectByIndext GetEffectIDtDef_Effect_ItemAddLVtGetEffectValueRõRBt"UpdatePlayerBillboardOnLeaveServerRIR—tOnMixFirstLoginR¥R¦R§(R    t isMixServerR÷tlastMixServerDayt    playerDaytmixServerWorldLVRútworldLVMailItemListt mailMoneyListt worldLVDownt itemWorldLVRRtworldLVItemListtitemIDt    itemCounttisBindtitemDatatcurEfftcurEffIDtlvLimitt
detailDictt addItemList((sgD:\SG_ServerCode\ServerPython\ZoneServerGroup\map1_8G\MapServer\MapServerData\Script\Player\ChPlayer.pyRAhsb     
(    cCs0tj|tjdƒtj|tjdƒdS(Ni(RR0RtDef_Player_Dict_PlayerDeadCnttDef_Player_Dict_DeadTime(R    ((sgD:\SG_ServerCode\ServerPython\ZoneServerGroup\map1_8G\MapServer\MapServerData\Script\Player\ChPlayer.pytClearPlayerDeadInfoµscCsKtjƒ}tjdƒ}tjdƒ}t|||ƒt||ƒdS(NtPlayerLoginNotify_TimeSecttPlayerLoginNotify_Dict(RtGetCurrentTimet ReadChConfigtGetEvalChConfigtDoNotifyByTimeSecttDoNotifyByDict(R    RtcurTimetnotifyByTimeSectt notifyByDict((sgD:\SG_ServerCode\ServerPython\ZoneServerGroup\map1_8G\MapServer\MapServerData\Script\Player\ChPlayer.pytPlayerLoginNotifyÀs   cCsLxE|D]=}tj||dƒs)qntj||d|dƒqWdS(Niii(Rt IsAtActTimeRt
NotifyCode(R    R5t
notifyInfot    curNotify((sgD:\SG_ServerCode\ServerPython\ZoneServerGroup\map1_8G\MapServer\MapServerData\Script\Player\ChPlayer.pyR3Ós cCs\tjƒ}xI|D]A}|j|dƒ|dkrtj||d|dƒqqWdS(Niiii(RRRRR:(R    R;t    gameWorldR<((sgD:\SG_ServerCode\ServerPython\ZoneServerGroup\map1_8G\MapServer\MapServerData\Script\Player\ChPlayer.pyR4ás  cCsg|jƒ}x*tjD]}|j|ƒ}|jƒqWx'tjjƒD]}tj||ƒqIWdS(N(    tGetItemManagerRt Def_PlayerLoginInitPackIndexListtGetPackt Sync_RefreshtDef_VPackCnt_DicttkeysR7tSync_VPackItem_Refresh(R    t itemManagert    packIndextrolePack((sgD:\SG_ServerCode\ServerPython\ZoneServerGroup\map1_8G\MapServer\MapServerData\Script\Player\ChPlayer.pyt__Sync_PackDetelís cCsÆtjƒ}|jƒg|_|jƒ}xrt|jƒƒD]^}|j|ƒ}tjƒ}|j    ƒ|_
|j ƒ|_ |j ƒ|_|jj|ƒq>Wt|jƒ|_tj||ƒdS(N(RRttagMCPlayerSkillsRétSkillstGetSkillManagertranget GetSkillCounttGetSkillByIndexttagPlayerSkillt
GetSkillIDtSkillIDt GetRemainTimet
RemainTimetGetProficiencyt ProficiencytappendRNtCountRR(R    tsendPackt skillManagertitcurSkillt    skillInfo((sgD:\SG_ServerCode\ServerPython\ZoneServerGroup\map1_8G\MapServer\MapServerData\Script\Player\ChPlayer.pyR;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<1s
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 
    cCstjƒrdSdS(N(RR(R    R((sgD:\SG_ServerCode\ServerPython\ZoneServerGroup\map1_8G\MapServer\MapServerData\Script\Player\ChPlayer.pyRDJs %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 SetMapLoadOKRHt SetCanAttackt__CheckClearBuffOnMapChangeRtGetMapt GetMapFBTypeR5tfbtNullR&tAddBuffBySkillType_NoRefurbishRtDef_SkillID_LimitSuperBufft GetSightLevelRäRtSetPlayerSightLeveltGetSightRJR=tChangePlayerSighRRRtGetOnlinePlayert ReCalcAllAttrRItSetProcessEquipDurgTickt SetLoginTickR9tDef_PlayerKey_CalcOLTimeTicktRefreshRebornPointtSavePlayerMessionInDataServerR+tWriteEvent_FightPowertRemoveLeaveServerPlayerInfoRt
PyGameDatatg_needRefreshMapServerState(R    RtolPlayer((sgD:\SG_ServerCode\ServerPython\ZoneServerGroup\map1_8G\MapServer\MapServerData\Script\Player\ChPlayer.pyR(zs8        
 
     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( RRqRŒR1R2titemst    BuffSkilltDelBuffBySkillIDR RVRtClearBuffOnMapChangeList(R    RtcurMapIDt
fbBuffDictt
buffIDListtbuffIDt    mapIDList((sgD:\SG_ServerCode\ServerPython\ZoneServerGroup\map1_8G\MapServer\MapServerData\Script\Player\ChPlayer.pyRpÁscCsdS(N((R    ((sgD:\SG_ServerCode\ServerPython\ZoneServerGroup\map1_8G\MapServer\MapServerData\Script\Player\ChPlayer.pyR€×scCstjtƒ||ƒdS(N(Rt GetPsycoFunct__Func_PlayerLogin(R R((sgD:\SG_ServerCode\ServerPython\ZoneServerGroup\map1_8G\MapServer\MapServerData\Script\Player\ChPlayer.pyR“åscCsµtjƒj|ƒ}y_t||ƒt||ƒ|jtƒ|jƒt||ƒt    ||ƒt
j ||ƒWn:|j t jƒddl}tjd|jƒƒnXdS(NiÿÿÿÿsÍæ¼ÒÉÏÏßÂß¼­´íÎó
%s(RRRR
R"RlRtSendToBServerServerInitOKRt__Func_LoadMapOKtGameServerRefreshtGameSever_PlayerInitOKtKickR5tdisWaitForPlayerLoinErrort    tracebacktRaiseExceptiont
format_exc(R RR    R˜((sgD:\SG_ServerCode\ServerPython\ZoneServerGroup\map1_8G\MapServer\MapServerData\Script\Player\ChPlayer.pyR‘ïs   
   cCstjtƒ||ƒdS(N(RRt__Func_ChangeMapInit(R R((sgD:\SG_ServerCode\ServerPython\ZoneServerGroup\map1_8G\MapServer\MapServerData\Script\Player\ChPlayer.pyt ChangeMapInitscCs¶tjƒj|ƒ}t||ƒtj||ƒt|ƒt||ƒ|jƒt    j
||ƒtj ƒj ƒt jkrŽ|jdƒn |jdƒ|jƒ|jtƒdS(Nii(RRRR
R&tPlayerChangeMapUpdateSkillCDR%R(tInitChangeMapPlayerSummonInfoRFtSync_PetInfo_ChangeMapRqRrR5tfbtTeamtGameServer_TeamEnterFBt#BalanceServer_PlayerChangeMapInitOKRlR(R RR    ((sgD:\SG_ServerCode\ServerPython\ZoneServerGroup\map1_8G\MapServer\MapServerData\Script\Player\ChPlayer.pyR›s
 
     
 
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_PackCountR5trptEquipRIRtrptItemt rptIdentifyRtrptHerot rptTempSwapt rptTempItemt rptTreasuret
ItemCommontSyncPackBuyCntRHR7tCheckGiveBindMoneyTypeItem(R    ((sgD:\SG_ServerCode\ServerPython\ZoneServerGroup\map1_8G\MapServer\MapServerData\Script\Player\ChPlayer.pyR%Zs 
 cCstj}t||ƒS(N(RRutCheckHasBuffBySkillID(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(( RRtGetSkillBySkillIDRRRR&t GetBuffTypetGetBuffManagerByBuffTypetGetSkillTypeIDtFindBuffRI(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 GetMapLoadOKRBRtDef_PlayerKey_ResetFBLinePosXtDef_PlayerKey_ResetFBLinePosYRRR9RHRIRRJRLRKR t    DoEnterFBt__CheckForbidLoginRntInitPosRŽRRvRäRwRxR2R3tSetPlayerActionR5R6RmR²RoRltGetLastMapPlayerVehicletpvHorseRWtPlayerRideHorseUpRtPlayerRideHorseDowntSetIsNeedProcesst PlayerGMOpert DoGMOperLogictDoEnterFBLogicRFRGRqRºtDef_PDict_IsReBorntSetToBornPlacetGameMaptGetNearbyPosByDistDef_RebornPos_Area_RangetResetPosR0R4RtrebornType_CityR8RR7tCanMoveR RRÝtCampType_NeutralRetGetRecordMapIDRŒtDef_MapID_NeedCampt
SetFactionRˆR‰tDef_SkillID_JusticetDef_SkillID_EviltGetInitAttackModelRÃt SetAttackModeRGR tPassiveBuffEffMngtOnLoadMapGFPassivet PlayerYinjit    OnLoadMapt
EndLoadMap(R RR    tresetFBLinePosXtresetFBLinePosYt playerVehicletcurMaptposXtposYtisLogint
rebornTypetnearPosXtnearPosYROtinitAttackModel((sgD:\SG_ServerCode\ServerPython\ZoneServerGroup\map1_8G\MapServer\MapServerData\Script\Player\ChPlayer.pyR“Ãs˜   
 
 
       *    # $  
 
cCs9tjƒ}|jƒ|jƒ|_tj||ƒdS(N(RRttagMCAttackModeRéRÃtModeRR(R    RX((sgD:\SG_ServerCode\ServerPython\ZoneServerGroup\map1_8G\MapServer\MapServerData\Script\Player\ChPlayer.pyRGys
 
cCstS(N(RI(R    ((sgD:\SG_ServerCode\ServerPython\ZoneServerGroup\map1_8G\MapServer\MapServerData\Script\Player\ChPlayer.pyt__CheckGMCanLoadMapOK†scCs:|jƒtdtjƒ@dkr&tS|jtjƒdS(Nii(RYtpowRtDef_PysForbidByPyRIR–R5t    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(RRRtPointAttrIDListtPointValueListRNt    enumerateRtGetIpyGameDataR£R t SetFreePointRºRtDef_PDict_AddPointValueRR0RytRefreshPlayerAttrState(R R!RR    tpointAttrIDListtpointValueListtneedTotalPointRZtattrIDt curFreePointtaddPointtcurPointtupdPointRO((sgD:\SG_ServerCode\ServerPython\ZoneServerGroup\map1_8G\MapServer\MapServerData\Script\Player\ChPlayer.pyt
OnAddPoint¯s2        &  
 
! 
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ùRIR RbRRR>R@R5R§R­tGetItem_FromPack_ByIDtGetAttCheckItemCanUsetGetItemRemainingTimet
ReduceItemtItemDel_ResetAttrPointtItem_ResetAttrPointtDoResetAttrPoint(R R!RR    t
ipyDataMgrtcanResetIDListtcanResetRþRtisFreetneedItemIDListtitemPacktdelIndext
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(RRRRRR    RºRRùRVRRttagMCRolePointInfoRôRõRNtPointAttrIDCountRR(    R    tsyncAttrIDListRR RûRüRþRt    pointInfo((sgD:\SG_ServerCode\ServerPython\ZoneServerGroup\map1_8G\MapServer\MapServerData\Script\Player\ChPlayer.pyRys 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__CheckPlayerCanMoveRqRÔRR‘tStopMovet    ChangePosRRttagMCMoveByTypeRéRätIDRgRhtMoveTypeRt PyNotifyAllR(R R!RR    RX((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%RqRÔRR‘R&R'RRt    tagMCRushRéRäR)RgRhRR+R(R R!RR    RX((sgD:\SG_ServerCode\ServerPython\ZoneServerGroup\map1_8G\MapServer\MapServerData\Script\Player\ChPlayer.pyt OnPlayerRushKs$& 
 
  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    WorldTickRqRÔRÒRŽRRBR9tGetPlayerVehicletpvNullRÆt CheckMovePostGetDistRtDelLimitSuperBuffR't    GetPetMgrt GetFightPettNoneRFtFightPetFollowMove( 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
GetCanMoveR2R3R6R7RR8R5R9RtPlayerCanStateTransferRI(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(
RRqRtPlayerMoveCheckClientWorldTicktSync_ClientTickRAtChangePlayerActionR5tpaNulltMove(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ÔtMoveFailRRBRtDef_PlayerMaxMoveDistRI( R    tcheckObjRåtstartXtstartYtdestXtdestYtsendPlayerMoveFailtobjPosXtobjPosYtmoveDist((sgD:\SG_ServerCode\ServerPython\ZoneServerGroup\map1_8G\MapServer\MapServerData\Script\Player\ChPlayer.pyRA0s     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 tDoFBForbidRebornR:R7tPlayerReborn_InFB(R RR    RXRé((sgD:\SG_ServerCode\ServerPython\ZoneServerGroup\map1_8G\MapServer\MapServerData\Script\Player\ChPlayer.pytPlayerClickRebornfs      cCstj|ƒ}|s&tjdƒdSt||dtƒs?dSi|jƒd6|d6}tjtj    |ƒtjd||f|jƒƒdS(Nsµ±Ç°ÎÞ¿ç·þµØÍ¼!t checkHPStateRVt
RebornTypes(¿ç·þÖÐÇëÇó¸´»î, crossMapID=%s,msgDict=%s(
RR?RR t__CheckCanRebornRRtSendMsgToCrossServerRtClientServerMsg_Reborn(R    Rét
crossMapIDtmsgDict((sgD:\SG_ServerCode\ServerPython\ZoneServerGroup\map1_8G\MapServer\MapServerData\Script\Player\ChPlayer.pyRl„s  cCsŒ|d}tjƒ}t|||ƒs,dS|jtjƒ}t|||ƒidd6|d6}|j|ƒtjt    j
||gƒdS(NRqitResultt ReviveTired( RRqRrRºRtDef_PDict_IsAddReviveTiredt__DoPlayerReborntupdatetSendMsgToClientServerRtCrossServerMsg_RebornRet(R    tmsgDatat serverGroupIDRRétgameMaptisAddReviveTiredRP((sgD:\SG_ServerCode\ServerPython\ZoneServerGroup\map1_8G\MapServer\MapServerData\Script\Player\ChPlayer.pyRt”s
  cCsX|d}|dkrdS|d}|d}t||tƒ|rTt||ƒndS(NRwiRqRx(t __RebornCostRIt__AddReviveTired(R    R~RtresultRéR((sgD:\SG_ServerCode\ServerPython\ZoneServerGroup\map1_8G\MapServer\MapServerData\Script\Player\ChPlayer.pyR}¦s
 
 
cCs`tjƒ}|jƒ|jƒ|_||_|jƒ|_|jƒ|_    t
j ||ƒdS(N( RettagPlayerRebornRéRRVtTypeRŽ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.pytPlayerDisconnectÆscCswtjƒj|ƒ}yt||ƒWn*ddl}tjd|jƒƒnXtjt    |ƒƒ|j
|ƒdS(NiÿÿÿÿsÍæ¼ÒÏÂÏßÂß¼­´íÎó
%s( RRRtDoPlayerDisconnectR˜R™RšRt    MapCallDBtGetPackSaveDatat DoDisconnect(R RR    R˜((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 WriteStringRN(R    t roleSaveDatatallData((sgD:\SG_ServerCode\ServerPython\ZoneServerGroup\map1_8G\MapServer\MapServerData\Script\Player\ChPlayer.pyRÜs
cCs·tjd|jƒƒtj||ƒ|jtjƒƒtj|ƒt    j
|ƒt j |ƒtj |tjdƒtj |tjdƒtj|ƒtj|ƒtj|ƒdS(NsPlayerDisconnect!i(RRRRtPlayerLeaveServert SetLogoffTimeR$R)tDR_PlayerDisconnectR‘tCalcOnlineTimeROtUpdateFirstGoldTimeR0Rt!Def_Player_Dict_RouteServerInitOKtDef_PlayerKey_CrossRegisterMapRFtReCallFightPetR+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äRNt
SetSetting(R RR    RXtsetting((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(RRRtSetNumRtLittleHelperSetNumCountR¦RRtLittleHelperValueCountthasattrtgetattrRR0t!Def_Player_Dict_LittleHelperValueR (R R!RR    tsetNumRZtvalue((sgD:\SG_ServerCode\ServerPython\ZoneServerGroup\map1_8G\MapServer\MapServerData\Script\Player\ChPlayer.pytOnSetLittleHelperH    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(RRR«RFR¬RºR¯RRttagMCLittleHelperFuncSetRªR­tsetattrRVttagMCLittleHelperSett FuncSetListRNt FuncSetCountRR(R    t funcSetListR°tfuncSetRZR±tsetPack((sgD:\SG_ServerCode\ServerPython\ZoneServerGroup\map1_8G\MapServer\MapServerData\Script\Player\ChPlayer.pyR²W    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ðRRtDef_GuideStateKeyCountRR0tDef_Player_Dict_GuideStateR R¦tSetDictValueByBit(R R!RR    t
guideIndextisOKR±RZ((sgD:\SG_ServerCode\ServerPython\ZoneServerGroup\map1_8G\MapServer\MapServerData\Script\Player\ChPlayer.pyt OnSetGuideOKy    s         cCsutjƒ}g|_x7ttjƒD]&}|jj|jtj|ƒƒq%Wt    |jƒ|_
t j ||ƒdS(N( RRttagMCGuideStatet
GuideStateRRR½RVRºR¾RNRWRR(R    tguideStatePackRZ((sgD:\SG_ServerCode\ServerPython\ZoneServerGroup\map1_8G\MapServer\MapServerData\Script\Player\ChPlayer.pyR6Ž    s     $cCs)tjƒ}||_tj||ƒdS(N(RRttagMCShowGuidetGuideIDRR(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    RXtcurValue((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    RXRÓ((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( R5tamPeacetamMaxRR RÃRqtGetAttackModelsRðRbtClearSummonAngry_PlayerRÜRG(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(R R!RR    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¾R2R3RRQRIRP(R    ((sgD:\SG_ServerCode\ServerPython\ZoneServerGroup\map1_8G\MapServer\MapServerData\Script\Player\ChPlayer.pytCheckPlayerStopMove!
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ãF
scCs-tjƒj|ƒ}|jƒt|ƒdS(N(RRRt    ExitEventtNotifyChangeMapFail(R RR    ((sgD:\SG_ServerCode\ServerPython\ZoneServerGroup\map1_8G\MapServer\MapServerData\Script\Player\ChPlayer.pytPlayerChangeMapFailCallbackQ
s
 
cCsM|jtƒtjƒ}|jƒtj||ƒtjd|j    ƒƒdS(Ns µØÍ¼Çл»Ê§°Ü(
RHRIRRttagMCChangeMapFailRéRRRRRä(R    RX((sgD:\SG_ServerCode\ServerPython\ZoneServerGroup\map1_8G\MapServer\MapServerData\Script\Player\ChPlayer.pyRçZ
s   
cCs&tjƒj|ƒ}t||ƒdS(N(RRRt __Func_ExitFB(R RR    ((sgD:\SG_ServerCode\ServerPython\ZoneServerGroup\map1_8G\MapServer\MapServerData\Script\Player\ChPlayer.pytExitFBu
s cCs‘tjƒjƒtjkr=|jƒtjddƒkr=dStjd|j    ƒ|j
ƒƒt j |ƒspdSt j ||ƒtj|ƒdS(NtMapLineisÍæ¼Ò = %s , Ö÷¶¯À뿪¸±±¾(RRqRrR5RsRŒ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_CChangeLinetGetLineR¦RäRRŒRRRt__CheckCanChangLineRtPlayerChangeLine(    R RR    RXt 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_TickRR:RR4R5tpaSitt DoPlayerStandtDef_PlayerChangLine_StatetIsPlayerInFightR?tDef_PlayerChangLine_VehicleRI(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_MainCityRRqRrRsRRReRÖRŒtgetRºRyR&t 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ºRR,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)(R2R3R4R5R6RˆRtDef_RebornTypeListRtrebornType_HealthtrebornType_UseItemtGetLocalRebornRR¦RŒRRRRºR,RR:RRR‚RR t OnCanFBRebornRI(R    RéR€RpR÷trebornCDR5tdeadTime((sgD:\SG_ServerCode\ServerPython\ZoneServerGroup\map1_8G\MapServer\MapServerData\Script\Player\ChPlayer.pyRr 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 HaveMoneyExRtTYPE_Price_Gold_Paper_MoneyRR¦RtDef_Cost_ReviveRR­tFindItemInPackByEffectExtDef_Effect_ReborntDelItemRI( R    RétisDoCostRuR÷t    rebornCfgt
moneyPricet costMoneyListt    moneyTypetmoneyCntt
rebornItem((sgD:\SG_ServerCode\ServerPython\ZoneServerGroup\map1_8G\MapServer\MapServerData\Script\Player\ChPlayer.pyR‚D 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 tOnPlayerRebornRIRR0RÍR    R"tOnResetFBRebornPlacePosR&RtRuRºRyRƒRRR=t IsInPKStatetSetPKStateTickt IsInBossStatetSetBossStateTicktRefreshAllStateR2RñRòt    SetProDeft GetMaxProDeftOnPlayerRebornOverRRqRÔRŽRR’RŒRÎtPlayerResetWorldPost GetRebornMapXt GetRebornMapYRHt AutoSummonPetRTR5RU(
R    RéRt mapBornPlacetisAddSuperBufftresetHpPercentt
isFBRebornt    validTimeROR€((sgD:\SG_ServerCode\ServerPython\ZoneServerGroup\map1_8G\MapServer\MapServerData\Script\Player\ChPlayer.pyRza 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( R&R RR R RRRtRR RR0Ry(R    RRt buffSkillLV((sgD:\SG_ServerCode\ServerPython\ZoneServerGroup\map1_8G\MapServer\MapServerData\Script\Player\ChPlayer.pyRƒ¢ scCsatjƒ}t|||ƒs"dStjƒsGt||tƒsGdSnt|||||ƒtS(s Íæ¼Ò¸´»î
    N(RRqRrRR‚RIRz(R    RéRR@RAR€((sgD:\SG_ServerCode\ServerPython\ZoneServerGroup\map1_8G\MapServer\MapServerData\Script\Player\ChPlayer.pyR7° s  cCs<tjƒjƒ}|tjkr%dStj|||ƒdS(N(RRqRrR5RsR t DoFBOnReborn(R    RéRR((sgD:\SG_ServerCode\ServerPython\ZoneServerGroup\map1_8G\MapServer\MapServerData\Script\Player\ChPlayer.pyRnÅ 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    RXRötclientSendLineID((sgD:\SG_ServerCode\ServerPython\ZoneServerGroup\map1_8G\MapServer\MapServerData\Script\Player\ChPlayer.pyRJ÷ s    c
    Csntjƒj|ƒ}|j}|j}|j}|j}|j}|j}    t    ||||||||    ƒdS(N(
RRRR†RR‹RR‘tExData1t__Func_WorldTransPort(
R RkRR    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-927DE1ACCC4F378ERRRS(ii(RŒR-RtTYPE_Player_Tick_WorldTransportR/R0RRR RtDef_PackType_TransportTypeRCR¦R
RtCheckPlayerTransporttCheckTagCountrytGetTransportPosR:tDef_Transport_Type_MissiontTransportVipLvRestricttPayForTransportR9tDef_PlayerKey_TransTypet
BeginTrans(
R    RQRöRæRçRRRRSR÷t transportType((sgD:\SG_ServerCode\ServerPython\ZoneServerGroup\map1_8G\MapServer\MapServerData\Script\Player\ChPlayer.pyRP s>&          R/c    Cs&tj||||||||ƒtS(N(RR<R(R    RöRæRçRRRætcanLockRS((sgD:\SG_ServerCode\ServerPython\ZoneServerGroup\map1_8G\MapServer\MapServerData\Script\Player\ChPlayer.pyR^X s"cCsX|jƒ|krNtjƒj||ƒsNtj||tjƒ\}}qNn||fS(N(RŒRRqRÔRÏRÐRRÑ(R    R_ttransportMapIDt transportPosXt transportPosY((sgD:\SG_ServerCode\ServerPython\ZoneServerGroup\map1_8G\MapServer\MapServerData\Script\Player\ChPlayer.pyRYs 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(RRRIR>R@R5R§R­R
tTransportPayMoneytTYPE_Price_Gold_PaperRR RR(R    R_R"tuseCountRRtitemListt    costMoney((sgD:\SG_ServerCode\ServerPython\ZoneServerGroup\map1_8G\MapServer\MapServerData\Script\Player\ChPlayer.pyR\ scCsdS(Ni((R    R_((sgD:\SG_ServerCode\ServerPython\ZoneServerGroup\map1_8G\MapServer\MapServerData\Script\Player\ChPlayer.pyR[¥ sc    CsŽtj|||ƒ}|gkr%tSxb|D]Z\}}|dkr,tj|||tji|d6ƒtj||dd||ƒq,q,WtS(Nit TransportType(    RR#RRRtDef_Cost_TransportRtLogin_Interface_GoldRecRI(R    R-tmoneyR_t    moneyList((sgD:\SG_ServerCode\ServerPython\ZoneServerGroup\map1_8G\MapServer\MapServerData\Script\Player\ChPlayer.pyRe³ 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(RRR1R2RRRqt ExchangeTimeR
RR¦RåtGetOfflineMinutesRtGetPlayerReExpRbtevalR#RRtDef_Cost_OffLineExptDef_Cost_Reason_SonKeytAddExpRtSetOfflineMinutestSyn_OfflineTimeQueryResult(R t curPackDataRtOfflineExpChangeDictR    tmulIndext exchangeTimetrecListtminVIPLvRæt
useMinutest haveMinutestrExptreLVtworldLvExpRatet    redeemExpt moneyInfoListR-RiROt haveMoneyListR.t 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.pytReceiveFamilyArrestAward  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"QueryFamilyArrestAwardReceiveState0 s
cCsEtjƒ}|jƒ|jtjƒ}||_tj||ƒdS(N(    RRt tagFamilyArrestAwardReceiveStateRéRºRt&Def_Player_Dict_FamilyArrestAwardStatet ReceiveStateRR(R    tawardReceiveStatetstate((sgD:\SG_ServerCode\ServerPython\ZoneServerGroup\map1_8G\MapServer\MapServerData\Script\Player\ChPlayer.pyRŒ9 s  
    cCs”tjƒ}|j|ƒ}tj|tjƒsMtj|dtjgƒdS|j    }t
|ƒ}tjƒj |j ƒddd|t |ƒƒdS(NtGeRen_chenxin_676165itPlayerGetReward(RRRR­tCheckPackHasSpaceR5R§RR:t
RewardTypeRRMRäRN(R R!Rt playerManagerR    t
rewardTypet
resultName((sgD:\SG_ServerCode\ServerPython\ZoneServerGroup\map1_8G\MapServer\MapServerData\Script\Player\ChPlayer.pytClientPlayerGetRewardE s      c
Cs÷tjƒ}|j|ƒ}|j}|j}|j}tjd|||fƒ|tjkrrt    j
||ƒn|tj kr‘t    j |ƒnb|tj kr³tj||ƒn@|tjkrÒtj|ƒn!|tjkrñtj|ƒn|tjkrtj||ƒnà|tjkr5tj||ƒn¾|tjkrWtj||ƒnœ|tjkr|t j!|||ƒnw|tj"kr¡t#j$|||ƒnR|tj%krÆt&j'|||ƒn-|tj(krët)j*|||ƒn|tj+kr t,j-||ƒnæ|tj.kr,t/||ƒnÇ|tj0krKt1j2|ƒn¨|tj3krmt4j5||ƒn†|tj6kr’t7j8|||ƒna|tj9kr·t7j:|||ƒn<|tj;krÜt<j=|||ƒn|tj>krt?j@|||ƒnò|tjAkr&t?jB|||ƒnÍ|tjCkrHtDjE||ƒn«|tjFkrjtGjH||ƒn‰|tjIkrtJjK|||ƒnd|tjLkr´tMjN|||ƒn?|tjOkrÙtPjQ|||ƒn|tjRkrûtSjT||ƒnø|tjUkrtVjW||ƒnÖ|tjXkrBtYjZ|||ƒn±|tj[krgt\j]|||ƒnŒ|tj^kr‰t_j`||ƒnj|tjakr®tbjc|||ƒnE|tjdkrÓtejf|||ƒn |tjgkrøthji|||ƒnû|tjjkrtkjl||ƒnÙ|tjmkr?tnjo|||ƒn´|tjpkrdtqjr|||ƒn|tjskr†tjt||ƒnm|tjukr¥tvjw|ƒnN|tjxkrÁty|ƒn2|tjzkrãt{j|||ƒn|tj}krt~j||ƒnî|tj€kr'tj||ƒnÌ|tj‚krItƒj„||ƒnª|tj…krnt†j‡|||ƒn…|tjˆkrt‰jŠ||ƒnc|tj‹krÄtŒ||tjtŽjddƒƒn/|tjkrøtŒ||tj‘tŽjddƒƒnû|tj’kr,tŒ||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(ŸRRRR–tDataExt    DataExStrR RtDef_RewardType_ActivityRdtGetActivityAwardtDef_RewardType_ActivityPlacetGetActivityPlaceRewardtDef_RewardType_GuajiRßtOnGetGuajiAwardtDef_RewardType_DayFreeGoldGiftRƒtOnGetDailyFreeGiftbagtDef_RewardType_FamilyDayAwardRltGetFamilyDayAwardtDef_RewardType_LVAwardRLtGetPlayerLVAwardtDef_RewardType_GoldGiftFirstROtGetPlayerGoldGiftFirsttDef_RewardType_FreeGoodsR•tOnGetFreeGoodstDef_RewardType_CostRebateR|tOnGetCostRebateAwardtDef_RewardType_TotalRechargeR}tOnGetTotalRechargeAwardtDef_RewardType_ManyDayRechargeRªtOnGetManyDayRechargeAwardtDef_RewardType_SingleRechargeR«tOnGetSingleRechargeAwardtDef_RewardType_BossRebornR–tGetBossRebornActionAwardtDef_RewardType_DownLoadtGetDownloadAwardtDef_RewardType_WishingWellR°tDoGetWishingAwardtDef_RewardType_OpenFuncRPtGetFuncOpenAwardtDef_RewardType_WeekPartyActR™tGetWeekPartyActionAwardtDef_RewardType_WeekPartyPointtGetWeekPartyPointAwardtDef_RewardType_ActLoginAwardActR£tGetLoginAwardActionAwardt Def_RewardType_FeastWeekPartyActRŸtGetFeastWeekPartyActionAwardt"Def_RewardType_FeastWeekPartyPointtGetFeastWeekPartyPointAwardtDef_RewardType_FeastLoginR tGetFeastLoginAwardtDef_RewardType_FeastTravelR¢tGetFeastTravelAwardtDef_RewardType_ActLoginAwardNewRžtOnGetActLoginAwardtDef_RewardType_ActBuyCountGiftRštOnGetBuyCountGiftAwardtDef_RewardType_ActTaskR›tOnGetActTaskAwardt#Def_RewardType_CACTGBillboardDabiaoRztGetDabiaoAwardtDef_RewardType_CAAllRechargeR{tGetCrossActAllRechargeAwardt!Def_RewardType_CrossYaomoBossHurttPlayerCrossYaomoBosstGetCrossYaomoBossHurtAwardtDef_RewardType_GubaoItemEffRÙtGetGubaoItemEffAwardtDef_RewardType_SuccessScoreRhtGetSuccessScoreAwardtDef_RewardType_BuyOneR…tGetBuyOneFreeAwardtDef_RewardType_FamilyCTGAssistR†tGetFamilyCTGAssistAwardtDef_RewardType_FamilyGCZRàtGetFamilyGCZAwardtDef_RewardType_TiandaoTreeRØtGetTiandaoTreeAwardtDef_RewardType_TreasureCntAwardR\tGetTreasureCntAwardtDef_RewardType_LunhuidianAwardRtGetLunhuidianAwardt!Def_RewardType_HistoryChargeAwardtOnGetHistoryRechargeAwardtDef_RewardType_OnlineRechargeTHRNtOnGetOnlineRechargeTHtDef_RewardType_CreateRoletOnGetCreateRoleAwardtDef_RewardType_CustomAwardR¸tOnGetCustomAwardtDef_RewardType_RealmLVUpTaskR@tGetRealmLVUpTaskAwardtDef_RewardType_DailyPackBuyGifttGetDailyPackBuyGifttDef_RewardType_TaskRÜt GetTaskAwardtDef_RewardType_ZhanlingRÛtGetZhanlingRewardtDef_RewardType_MineTreasureRÞtGetMineTreasureAwardR½tOnGiveAwardByClientR»RRR¿R¾RÁRÀRÃRÂRÅRRRtDef_Notify_WorldKey_ServerDayRRÄRÇtOnGetRechargeDayAward(
R R!RR—R    R˜tdataExt    dataExStrt openServerDaytopenServerDayLimit((sgD:\SG_ServerCode\ServerPython\ZoneServerGroup\map1_8G\MapServer\MapServerData\Script\Player\ChPlayer.pyR”a sä              %%%% +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ÆRRR‡RRR RR­t GiveAwardItemRR0R¼(
R    R˜t    realTotaltawardCoinRecordt    awardCoint awardItemListt dayAwardDictt needCoinStrRhtneedCoin((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­RRRRR0R·(R    ((sgD:\SG_ServerCode\ServerPython\ZoneServerGroup\map1_8G\MapServer\MapServerData\Script\Player\ChPlayer.pyRñ!s 
cCs?tjƒ}|jƒ|jtjƒ|_tj||ƒdS(N(    RRttagMCCreateRoleAwardStateRéRºRRR˜RR(R    RX((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­RRR0R¼(R    R˜tdictKeytawardCfgt    eventName((sgD:\SG_ServerCode\ServerPython\ZoneServerGroup\map1_8G\MapServer\MapServerData\Script\Player\ChPlayer.pyRþ5scCs<tjƒ}|jƒ||_||_tj||ƒdS(N(RRttagMCPlayerRewardGetRecordRéR–tRewardGetRecordRR(R    R˜trewardGetRecordRX((sgD:\SG_ServerCode\ServerPython\ZoneServerGroup\map1_8G\MapServer\MapServerData\Script\Player\ChPlayer.pyR¼Es  
        cCsŒtjƒj|ƒ}t|jƒ}tjdƒ\}}}|jddg|ƒ}d}    x:t|ƒD],\}
} t    j
|t j |    |
f| ƒqhW|jddg|ƒ} d}    x:t| ƒD],\}
} t    j
|t j |    |
f| ƒqÄW|jddg|ƒ} d}    x:t| ƒD],\}
} t    j
|t j |    |
f| ƒq Wd}    |j|    dƒ} t    j
|t j |    df| ƒdS(NtAutoFightSettingt
BasicSkillit    AreaSkillRˆtHPPackagePercent( RRRRutDataR1R2R
RöRR0RtDef_PDict_AutoFightSetting(R R!RR    t settingDicttBasicSkillCounttAreaSkillCounttBuffSkillCounttBasicSkillListtKeyt
ValueIndextValuet AreaSkillListt BuffSkillList((sgD:\SG_ServerCode\ServerPython\ZoneServerGroup\map1_8G\MapServer\MapServerData\Script\Player\ChPlayer.pytOnSaveAutoFightSettingPs&$$$ 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(NRRiRRˆRs%s(R1R2RRºRRRVRRttagMCAutoFightSettingRéRRNtSizeRR( R    RR R!RR#R"R$R%R&R'RX((sgD:\SG_ServerCode\ServerPython\ZoneServerGroup\map1_8G\MapServer\MapServerData\Script\Player\ChPlayer.pytSync_AutoFightSettingns:
 
 
 
 
 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_QueryMapNPCInfoR-R/R R0RR‹t    NPCIDListRut BaseExceptionR¦t
isinstancetlistRRqRŒRbt
GetNPCInfoR5t GetMapCopyPlayerManagerByFbIndextGetPlayerCountt SyncNPCInfotGameServer_QueryPlayerByIDtqueryType_NPCInfoRN(R R!RR    ttickTypettagMapIDt    tagLineIDt queryNPCStrt    npcIDListR‹t npcInfoDictR=R—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(RRRR.tCheckPlayerTickRR/R RR‹R0RuR1R¦R2R3RRqRŒRbt GetNPCCntInfotSyncNPCCntInfoR8tqueryType_NPCCntRN( R R!RR    R;R<R=R>R‹R?RA((sgD:\SG_ServerCode\ServerPython\ZoneServerGroup\map1_8G\MapServer\MapServerData\Script\Player\ChPlayer.pytOnQueryMapNPCCntInfoàs@                           cCs#tjƒj|ƒ}|jƒdS(N(RRRRS(R R!RR    ((sgD:\SG_ServerCode\ServerPython\ZoneServerGroup\map1_8G\MapServer\MapServerData\Script\Player\ChPlayer.pytQueryWorldTicks
cCs£tjƒ}|sdStjƒ}|jƒ|j|_|j|_|j    |_
|j |_ |j |_|j|_|j|_tjƒ|_tj||ƒdS(N(RR0RRttagServerDateTimeRétyeartYeartmonthtMonthtdaytDaythourtHourtminutetMinutetsecondtSecondt microsecondt    MicSecondtGetCrossServerTimeStrtCrossServerTimeRR(R    t
serverTimetserverDateTime((sgD:\SG_ServerCode\ServerPython\ZoneServerGroup\map1_8G\MapServer\MapServerData\Script\Player\ChPlayer.pyRs  
       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(*RR0RRttagMCOpenServerDayt    DBDataMgrtGetEventTrigMgrRÐRt Def_ServerDayRPtDef_IsMixServert IsMixServertDef_MixServerDaytMixDaytDef_OpenServerWeekdayt OpenWeekdayRKtNowYearRMtNowMonthROtNowDayRQtNowHourRSt    NowMinuteRUt    NowSecondRWt NowMicSecondt GetWeekOfYeart
WeekOfYearRRRttagOpenServerDayRéRRÿRt Def_Notify_WorldKey_MixServerDayt%Def_Notify_WorldKey_OpenServerWeekday(R    R[RktgwtpackData((sgD:\SG_ServerCode\ServerPython\ZoneServerGroup\map1_8G\MapServer\MapServerData\Script\Player\ChPlayer.pyR1sD           
       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ºRR4R5tPYPlayerNormalMoveRŽRRqRÔRIRÏtGetEmptyPlaceInAreaR¦RÒ(R RkRR    RæRçt    resultPos((sgD:\SG_ServerCode\ServerPython\ZoneServerGroup\map1_8G\MapServer\MapServerData\Script\Player\ChPlayer.pyt PYPlayerMoveis $ 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%RItDirt
ClientPosXt
ClientPosYt    SeverPosXt    SeverPosYR>R*tGetClientMoveTickRR RqRÔRRŽRR9tMoveDistCalcTickt MoveDistSumtSetClientMoveTicktPyNotifyPlayerMoveRrR5RsR t DoFBCanMoveR?R@RÆRRRRSRBRäRBtminRRtGetSpeedRTRUR'RDREt GetActionTickRFRGt SetCurActiont    laNPCNull(R    RkRtmoveDirt
clientPosXt
clientPosYtsendPack_SeverPosXtsendPack_SeverPosYRLtmoveTypet lastMoveTickRMtdisttcalcTicktdistSumtspeedt passCalcTicktneedTickt checkNeedTickRN((sgD:\SG_ServerCode\ServerPython\ZoneServerGroup\map1_8G\MapServer\MapServerData\Script\Player\ChPlayer.pyRus|                               $  
$  
 
     # "cCstjƒ}|jƒ|jƒ|_tj|_||_||_    ||_
||_ ||_ |j ƒ|_||_tj||tdƒdS(Ni(RRttagMCPYPlayerMoveRéRäRiR5t    gotPlayerRhR|R}R~RR€RˆtSpeedR*RR+R(R    RŒRRŽRæRçR‘RX((sgD:\SG_ServerCode\ServerPython\ZoneServerGroup\map1_8G\MapServer\MapServerData\Script\Player\ChPlayer.pyR…ùs 
                         cCsÀ|jƒ}tjddƒ}|jtjƒ}||krZtjd||f|ƒdStjddƒ}|svdSt    j
|tj|ƒtjd||f|ƒt    j d|g|ƒdS(Nt
DownRewardis:ÒÑ·¢·ÅÏÂÔØ²¹¶¡°ü½±Àø! curAwardNum(%s) == patchAwardNum(%s)is3·¢·Å²¹¶¡°üÏÂÔØ½±Àø: curAwardNum=%s,patchAwardNum=%stDownloadPatchAward( RRRRºRtDef_PDict_DownloadPatchAwardRR RRR0Rõ(R    R÷t patchAwardNumt curAwardNumR ((sgD:\SG_ServerCode\ServerPython\ZoneServerGroup\map1_8G\MapServer\MapServerData\Script\Player\ChPlayer.pyRF
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(RRRRºRtDef_PDict_DownloadAwardStateRR RRNR­tGetItemPackSpaceR5R§RR:R0RõRäR7tGivePlayerItemR­( R    RR÷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( RRRRttagMCPackDownloadRecordRéRºRR¤tRecordRR(R    R§RX((sgD:\SG_ServerCode\ServerPython\ZoneServerGroup\map1_8G\MapServer\MapServerData\Script\Player\ChPlayer.pyR­;s  
cCsEtjƒ}|jƒ||_||_||_tj||ƒdS(s»Í¨ÖªÇ°¶ËÏòij¸öµãÒÆ¶¯
                ÕâÀïǰ¶Ë¿ÉÄÜÐèÒªÕë¶Ôij´ÎÒÆ¶¯×ö¶îÍâ´¦Àí£¬±ÈÈçÒÆ¶¯µ½Ä³¸öµãºóÐèÒª×Ô¶¯Õ½¶·µÈ
                ËùÒÔÕâÀïÖ»×ö֪ͨǰ¶Ë¿ÉÒÔÏòij¸öµãÒÆ¶¯£¬×îÖÕÒÆ¶¯ÓÉǰ¶Ë·¢Æð
    N(RRttagMCNotifyPlayerMoveRéRR‘tNPCIDRR(R    RæRçtnpcIDRX((sgD:\SG_ServerCode\ServerPython\ZoneServerGroup\map1_8G\MapServer\MapServerData\Script\Player\ChPlayer.pytNotifyPlayerMoveDs 
            cCstjƒj|ƒ}|j|jtj}tj|ƒ}||}|dkrmt    j    |ƒ}|j
ƒntj ||ƒdS(Ni( RRRtLostHPtLostHPExRtDef_PerPointValueR2R3RtSetDeadRñ(R R!RR    tlostHPtcurHPtupdHPRO((sgD:\SG_ServerCode\ServerPython\ZoneServerGroup\map1_8G\MapServer\MapServerData\Script\Player\ChPlayer.pyt OnRoleLostHPYs
  cCsdS(N((R R!R((sgD:\SG_ServerCode\ServerPython\ZoneServerGroup\map1_8G\MapServer\MapServerData\Script\Player\ChPlayer.pytOnSelectRealmDifficultyns(R=R5RRRÏRRˆR RWRbR&R RˆR­R7tChEquipRRÊR1RFR6RtPlayerAutoCheckOnlineRJRRRR)RBRUR‘RLRORRRHR@RlR^R>RgRdReR°RhRmR•RoR’RsRtRPR–R™RŸR¢R R¡R£R\RŠRŒRR+R`RÝR„R‚RƒR|R…R€R‡R}RR¤R¥R¦R§R¨R©R†R~RªR«R˜R—RRµRÚRRuR±RRzR{R¹R¬R¶R@ReRvRƒRNRjR¯RqRDRYR³RÙRÚR¸RÛRÝR[RÜRßRkR2R*RßR×RÖRØRÞRžRšRRàRœR›RÕR^R”R”R’t    PyMongoDBRRÒRáRÔRR5tdatetimeRtmathtreRRR
RR)R.RQR1R"RRçRER4RAR-R8R3R4RHR;R<R]RDR(RpR€R“R‘RœR›R%R²R°R“RGRïRÂRR RyR,R2ROR%R\RIRARoRlRtR}RˆRŠR‰RR‹R©R²R²RÂR6RÊRÎR R¢RÝRáRâRäRãRèRçRëRêRúRóRRRFRrR‚RzRƒR7RnRIRKRJRTRPR^RYR\R[ReRŠR‹RRŒRšR”RRñR·RþR¼R(R+R,RBRHRIRRRxR‚RƒRuR…RFR¼R­R°R¸R¹(((sgD:\SG_ServerCode\ServerPython\ZoneServerGroup\map1_8G\MapServer\MapServerData\Script\Player\ChPlayer.pyt<module>s                                                                                                                                                                                &    Š        ÿH    '            +    M                      ,        
        0    G            
        
    B    A    
        ¶                 %    2 !    $    :    Y    +    ' 6                                          A            "        
                     "                                      
    !    )    "    #     +    A                             A                    X                         «                           (    
    @    /    
        8        x