gwj
16 小时以前 08638959e983486d5ae67d7ccd94e751d78d7671
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
98
99
100
101
102
103
104
105
106
107
108
109
110
111
112
113
114
115
116
117
118
119
120
121
122
123
124
125
126
127
128
129
130
131
132
133
134
135
136
137
138
139
140
141
142
143
144
145
146
147
148
149
150
151
152
153
154
155
156
157
158
159
160
161
162
163
164
165
166
167
168
169
170
171
172
173
174
175
176
177
178
179
180
181
182
183
184
185
186
187
188
189
190
191
192
193
194
195
196
197
198
199
200
201
202
203
204
205
206
207
208
209
210
211
212
213
214
215
216
217
218
219
220
221
222
223
224
225
226
227
228
229
230
231
232
233
234
235
236
237
238
239
240
241
242
243
244
245
246
247
248
249
250
251
252
253
254
255
256
257
258
259
260
261
262
263
264
265
266
267
268
269
270
271
272
273
274
275
276
277
278
279
280
281
282
283
284
285
286
287
288
289
290
291
292
293
294
295
296
297
298
299
300
301
302
303
304
305
306
307
308
309
310
311
312
313
314
315
316
317
318
319
320
321
322
323
324
325
326
327
328
329
330
331
332
333
334
335
336
337
338
339
340
341
342
343
344
345
346
347
348
349
350
351
352
353
354
355
356
357
358
359
360
361
362
363
364
365
366
367
368
369
370
371
372
373
374
375
376
377
378
379
380
381
382
383
384
385
386
387
388
389
390
391
392
393
394
395
396
397
398
399
400
401
402
403
404
405
406
407
408
409
410
411
412
413
414
415
416
417
418
419
420
421
422
423
424
425
426
427
428
429
430
431
432
433
434
435
436
437
438
439
440
441
442
443
444
445
7ûÞic@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@ddlAZAddlBZBddlCZCddlDZDddlEZEddlFZFddlGZGddlHZHddlImJZJddlKZKddlLZLddlMZMddlNZNddlOZOddlPZPddlQZQddlRZRddlSZSddlTZTddlUZUddlVZVddlWZWddlXZXddlYZYddlZZZddl[Z[ddl\Z\ddl]Z]ddl^Z^ddl_Z_d„Z`d„Zad„Zbd„Zcd„Zdd„Zed    „Zfd
„Zgd „Zhd d „Zid„Zjd„Zkd„Zlemd d„Znd„Zod„Zpd„Zqd„Zrd„Zsd„Ztd„Zud„Zvd„Zwd„Zxd„Zyd„Zzd„Z{d„Z|d „Z}d!„Z~d"„Zd#„Z€d$„Zd%„Z‚d&„Zƒd'„Z„d(„Z…d)„Z†d*„Z‡gd+„Zˆd,„Z‰d-„ZŠd.„Z‹d/„ZŒd0„Zemd1„ZŽd2„Zd3„Zd4„Z‘d5„Z’d6„Z“d7„Z”d8„Z•d9„Z–d:„Z—d;„Z˜d<„Z™d=d>„Zšd?„Z›d@„ZœdA„ZdB„ZždC„ZŸdD„Z dE„Z¡dF„Z¢dG„Z£dH„Z¤dI„Z¥dJ„Z¦dK„Z§dL„Z¨dM„Z©dN„ZªdO„Z«dP„Z¬dQ„Z­dR„Z®dS„Z¯demdT„Z±dU„Z²d emdV„Z³dW„Z´d emdX„ZµdY„Z¶dZ„Z·d[„Z¸d\„Z¹d]„Zºdd d^„Z»dd=emd d_„Z¼d`„Z½da„Z¾db„Z¿dc„ZÀdd„ZÁde„ZÂdf„ZÃdg„ZÄdh„ZÅddi„ZÆdj„ZÇdk„ZÈdl„ZÉdm„ZÊdn„ZËd=do„ZÌdp„ZÍdq„ZÎdr„ZÏds„ZÐdt„ZÑdu„ZÒdv„ZÓddw„ZÔdx„ZÕdy„ZÖdzZ×d{ZØd|„ZÙd}„ZÚd d~„ZÛd„ZÜd€„ZÝd„ZÞd d d‚„ZßdS(ƒiÿÿÿÿN(tRecvPackToMapDBcCsdS(N((ttick((sgD:\SG_ServerCode\ServerPython\ZoneServerGroup\map1_8G\MapServer\MapServerData\Script\Player\ChPlayer.pyt
InitPlayervscCs6tj|ƒ|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.pytInitLoginPlayers cCstj||ƒrdSdS(N(tFBLogictPlayerLoginInFBCheck(R    R((sgD:\SG_ServerCode\ServerPython\ZoneServerGroup\map1_8G\MapServer\MapServerData\Script\Player\ChPlayer.pytOnAllServerInitOK‹scCsÊ|jtjdƒtjƒj|jƒƒt|ƒt|ƒ|j    ƒt
|ƒt j ƒrp|j tƒntj|ƒt||ƒt j ƒr¼|j tƒtj||jƒƒn|jƒdS(Ni(tSetDictRtDef_PlayerKey_LoadMapIsLogint CrossPlayertGetCrossPlayerMgrt RegistPlayert GetPlayerIDtSync_PyServerDataTimeToClienttSync_OpenServerDaytSync_ClientPlayerLogintSyncSettingDatat    GameWorldt IsCrossServertSetForbiddenSyncClientStatetTruetPlayerEventCountertUpdatePlayerLoginTimet__DoPlayerLoginServertFalset PlayerControlt SetCrossMapIDtGetMapIDtBalanceServer_PlayerLoginInitOK(R    R((sgD:\SG_ServerCode\ServerPython\ZoneServerGroup\map1_8G\MapServer\MapServerData\Script\Player\ChPlayer.pyt DoPlayerLogin±s
 
 
 
 
cCs|jtjƒƒt|ƒtjƒrTt||ƒtj|ƒtj    |ƒdSt
j |ƒ}|t j dkrÝt
j|t jdƒt
j|t jdƒt
j|t jdƒt
j|ƒrÝt
j|dƒqÝnt|ƒtj|ƒt|ƒtj|ƒt||ƒt
j|ƒt
j|ƒtj|ƒtj    |ƒtj|ƒt|ƒt j|ƒt!j|ƒt"j#|ƒt$j%|ƒt&j'|ƒt(j)|ƒt*j+|ƒt,j|ƒt-j.|ƒt
j/|ƒt
j0|ƒt1j|ƒt2j|ƒt3j|ƒt4j5|ƒt6j7|ƒt8j|ƒt9j|ƒt:j|ƒt;j|ƒt<j|ƒt=|ƒt"j>|ƒt?|ƒt@j|ƒtA|ƒtBj|ƒ|jCt jDƒ}|rçtE|t jF|ƒn|jCt jGƒ}|rtE|t jH|ƒn|jCt jIƒ}|rCtE|t jJ|ƒn|jCt jKƒ}|rqtE|t jL|ƒn|jCt jMƒ}|rŸtE|t jN|ƒn|jCt jOƒ}|rÍtE|t jP|ƒn|jQdƒ|jRdƒt
j|ƒtj|ƒdS(s2 Íæ¼ÒµÇ¼ÐèÒª´¦ÀíµÄÄÚÈÝ£¬±¾·þ¼°¿ç·þ·þÎñÆ÷·Ö¿ª
    Nièi(St SetLoginTimeRtGetCurrentDataTimeStrtInitPlayerPackRtDoPlayerLoginInMaptDataRecordPacktDR_PlayerLogint EventReporttWriteEvent_loginR tGetPlayerLeaveServerSecondRtDef_PlayerOfflineProtectTimetNomalDictSetPropertyt Def_Player_Dict_PlayChangeLineIDt Def_Player_Dict_FuncChangeLineIDt Def_Player_Dict_HighChangeLineIDt GetCrossMapIDR!t__FirstLoginOnEntert
TurnAttackRtSyncGuideStatet ItemControlertSyncOnLineTimeTotaltSyncTrainRealmLVtPlayerPrestigeSystOnLogintPlayerBillboardtBillboardOnLogint__SyncPlayerInfoExt
PlayerCointPlayerGoldGiftt GameFuncCommtSync_FuncOpenStatet PlayerSignDaytSignDayOnLogint PlayerHorsetPlayerHorseLogintPlayerTreasuretOnTreasureLogintFBCommont    FBOnLogintPlayerGoldInvestt PlayerSuccesst SuccOnLogintNotifyPlayerAllCurrencytNotifyUseMoneyTotaltPlayerActBuyOnetPlayerActFamilyCTGAssisttPlayerActCollectWordstChItemtSync_ItemDayUseCnttFunctionNPCCommontShopItemOnLogintPlayerActBuyCountGiftt PlayerActTasktPlayerActLianqitPlayerActManyDayRechargetPlayerActSingleRechargetSyncPackDownloadAwardtDoFuncOpenLogictSyncLittleHelpertPlayerFBtSync_CreateRoleAwardInfotPlayerCustomAwardtNomalDictGetPropertytDef_PDict_GameNoticeAwardStatetSync_RewardGetRecordInfotDef_RewardType_GameNoticetDef_PDict_ShareGameAwardStatetDef_RewardType_ShareGametDef_PDict_GoodGameAwardStatetDef_RewardType_GoodGametDef_PDict_LikeGameAwardStatetDef_RewardType_LikeGametDef_PDict_OpenSererDailyAwardt#Def_RewardType_OpenServerDailyAwardtDef_PDict_RechargeDayAwardtDef_RewardType_RechargeDayAwardtSetStatetSetCountryLastWeekHornor(R    RtleaveServerSecondtgameNoticeAwardStatetshareGameAwardStatetgoodGameAwardStatetlikeGameAwardStatet
awardState((sgD:\SG_ServerCode\ServerPython\ZoneServerGroup\map1_8G\MapServer\MapServerData\Script\Player\ChPlayer.pyRÑs–
 
 
 
 
 
 
     cCsôtjd|jƒƒtjƒr%n|tjƒj|ƒtj|ƒtj||ƒt    j|ƒt
j|ƒt j|ƒt j|ƒt j|ƒtj|ƒtj|ƒtj|ƒtj|ƒtj|ƒt|ƒtj|ƒtj|ƒtj|ƒtj|ƒtj|ƒtj|ƒtj|ƒtj|ƒtj|ƒtj|ƒtj|ƒtj|ƒt j|ƒt!|ƒt"|dƒ|j#t$j%ƒ}t&|gƒ}tj'ƒj(|j)ƒddd|t*|ƒƒdS(s     Íæ¼Ò×îÖյǼ³É¹¦´¦Àí£¬ ÓÉ  GameServerRefresh GameSever_PlayerInitOK  µ÷ÓÃ
        ¸Ãº¯ÊýΪµØÍ¼×îÖյǼ³É¹¦²Å»áÖ´Ðе½£¬ÒÔºóһЩ¹¦ÄÜÀàµÄµÇ¼´¦Àí½¨Òé¾ùдµ½ÕâÀï
        ¾ÉµÄ¹¦ÄÜÏȲ»¶¯( __DoPlayerLoginServer º¯ÊýÖеŦÄÜ)£¬Èç¹ûÓеǼÏà¹ØµÄbugÔÙ¿¼ÂÇÊÇ·ñÒÆ¶¯µ½´Ëº¯Êý
    sMapServer->DoPlayerRealLoginOKiitPlayerRealLoginOKN(+RtLogRRt PyMongoMaint GetUserCtrlDBRt GMT_BroadCastt PlayerFamilyt
PlayerHerot
PlayerMailt    PlayerHJGt PlayerGubaotPlayerZhanlingt
PlayerTaskt
PlayerTreetPlayerGoldRushtPlayerActFamilyGCZt
PlayerTalkt SyncADCntInfotUpdatePlayerNametPlayerActivityt
PlayerLLMJt PlayerBeautyt PlayerTravelt PlayerMinggetOpenServerActivityt PlayerPresetRtPlayerActLunhuidiantPlayerActHeroAppeartPlayerActTotalRechargetPlayerActTotDayRecharget__OnFixVersiontSyncOnlineStateToCrosst GetDictByKeyRt!Def_PlayerKey_MixServerFirstLogintstrtGetPlayerManagertGameServer_QueryPlayerResulttGetIDtlen(R    RtisMixServerFirstLogintmsg((sgD:\SG_ServerCode\ServerPython\ZoneServerGroup\map1_8G\MapServer\MapServerData\Script\Player\ChPlayer.pytDoPlayerRealLoginOK{sH            
 
 .cCs|jƒ}d}|jtjƒ}|s…|jƒ}|jdƒd}tjd|jddƒƒ}tj    d||f|ƒn||kr©tj    d||ƒd    Stj
d
||f|ƒd }||krt j ƒrtj
d ƒt j|ƒqnd}||krvtj||tjtjtjgƒtj||tjtjtjgƒtj|tj|ƒntj|tj|ƒd    S( sº ÐÞÕýÏßÉÏÍæ¼ÒÊý¾ÝÄÚÈÝ
    Ã¿´ÎÓÐÐèÒªÐÞÕýʱ£¬Ö»Òª¶¨ÒåÒ»¸öеÄϵͳÄÚÈݰ汾ºÅ  sysFixVersion , È»ºóÍæ¼Ò¸ù¾Ý×ÔÉí°æ±¾ºÅ½øÐÐÖð²½ÐÞÕý¼´¿É
    ÕâÑùÖ»Óõ½Ò»¸ökey¼´¿É£¬²»ÐèҪÿ´Î¶¼¶¨ÒåеÄkey
    iìëÂxs is%s00s-tsĬÈÏÊý¾Ý°æ±¾Îª´´½ÇÈÕÆÚ: %s, %ss0Íæ¼Òµ±Ç°Êý¾Ý°æ±¾ºÅÒÑÊÇ×îа汾! playerVersion=%sNsDÍæ¼Òµ±Ç°Êý¾Ý°æ±¾ºÅ²»µÈÓÚϵͳ°æ±¾ºÅ£¬¿ªÊ¼ÐÞÕý! playerVersion=%s != %si´¡Âxs¿ç·þ¹«»áÍæ¼ÒµÇ¼²¹¹ýÌì(RRbRtDef_Player_Dict_FixVersiontGetCreateRoleTimetsplitRtToIntDeftreplacetDebugLogRytDBFamilyt IsFamilyCrossR}t__doPlayerOnDaytChEquipt FixRoleEquipt
AttrID_Atkt
AttrID_Deft AttrID_MaxHPRŽt FixRoleMinggeR R/(R    tplayerIDt sysFixVersiont playerVersiontcreateRoleTimetymdt
fixVersion((sgD:\SG_ServerCode\ServerPython\ZoneServerGroup\map1_8G\MapServer\MapServerData\Script\Player\ChPlayer.pyR•¶s0   
    %%cCsÚi}g}tjƒrbtjƒjƒ}|dkrb||d<||kr_|j|ƒq_qbntjƒ}|dkr™||kr™|j|ƒq™ntj    ƒ}|dkrÐ||krÐ|j|ƒqÐn||fS(NitcrossFamilyServerID(
R¨R©t    DBDataMgrt GetFamilyMgrtGetCurCrossServerIDtappendtGameLogic_QunyingtGetQunyingCrossServerIDtGameLogic_ArenatGetArenaCrossServerID(tdataExt serverIDListR·t crossServerID((sgD:\SG_ServerCode\ServerPython\ZoneServerGroup\map1_8G\MapServer\MapServerData\Script\Player\ChPlayer.pytGetSyncCrossServerIDAndFuncInfoès"  
       cCsBtƒd}||kr4tjd||fƒdSt|ƒdS(Nis9·Ç±¾·þ¹¦ÄÜËùÊô¿ç·þ·þÎñÆ÷²»´¦Àí! connServerID=%s not in %s(RÃRR§tSyncOnlinePlayerToCross(t connServerIDRÁ((sgD:\SG_ServerCode\ServerPython\ZoneServerGroup\map1_8G\MapServer\MapServerData\Script\Player\ChPlayer.pytOnMainServer_Conn_CrossServers   
icCsä|jƒ}tjƒ}|j|ƒ}|s1dStj|ƒ|tjkr]tj    |ƒn|tj
kr…|j ƒdkr…dSnt ƒd}|sœdS|jƒ}t j||ƒ}i|d6}tjtj|||ƒdS(sˆÍæ¼Ò»ù´¡ÐÅÏ¢±ä¸üͬ²½¸üÐÂÆäËû¹¦ÄÜ£¬¿ÉÒÔÊÓΪͬ²½µ½ÒÔǰµÄGameServer
    ³ýÁËÏà¹Ø»ù´¡Öµ±ä»¯Í¬²½Í⣬ÉÏÏÂÏß״̬±ä¸üÒ²»á¸½´ø»ù´¡ÐÅÏ¢µÄͬ²½
    NiitbaseInfo(RRRtFindCrossPlayerR}tRefreshFamilyMembertIPY_PlayerDefinetCDBPlayerRefresh_PlayerNameR<tUpdatePlayerBillboardNametCDBPlayerRefresh_LVtGetLVRÃtPlayerViewCachetGetPlayerBaseViewInfotCrossMsgtSendToCrossServert ShareDefinetS2C_PlayerBaseInfo(R    t refreshTypeR±tcrossPlayerMgrt crossPlayerRÁRÇtdataMsg((sgD:\SG_ServerCode\ServerPython\ZoneServerGroup\map1_8G\MapServer\MapServerData\Script\Player\ChPlayer.pytOnPlayerBaseInfoChange s&      cCs't}|d}t||||ƒdS(NRÇ(RtUpdCrossPlayerFromMainServer(RØt fromServerIDR±tisOnlineRÇ((sgD:\SG_ServerCode\ServerPython\ZoneServerGroup\map1_8G\MapServer\MapServerData\Script\Player\ChPlayer.pyRÔ=s
cCstjƒ}|j|ƒ}|s3|j|ƒ}ntj||| ƒ}|j||ƒtj|ƒ|s‰tj    |ƒ|j
|ƒn|S(N( RRRÈRRÏtUpdPlayerBaseViewInfotUpdByViewCacheR}RÉtOnCrossPlayerLogoutt DeletePlayer(RÛR±RÇRÜRÖR×tcurCache((sgD:\SG_ServerCode\ServerPython\ZoneServerGroup\map1_8G\MapServer\MapServerData\Script\Player\ChPlayer.pyRÚCs   cCsdtjƒ}xQt|jƒƒD]=}|j|ƒ}tj|ƒsIqnt|dt|ƒqWdS(Ni(RRštxranget OnlineCounttOnlineAttIsNormalPlayerR–R(ttoCrossServerIDt playerManagertiR    ((sgD:\SG_ServerCode\ServerPython\ZoneServerGroup\map1_8G\MapServer\MapServerData\Script\Player\ChPlayer.pyRÄYs c
Cs­|jƒ}tjƒ}|s.|j|ƒntƒ\}}|sGdS|rY|g}ntj|ƒ}i|d6|d6|d6}    |    j|ƒtj    t
j |    ||ƒdS(NRÜt
isLoginoutRÇ( RRRRàRÃRÏRÐtupdateRÑRÒRÓtS2C_OnlineState(
R    RÜRéRæR±RÖRÁRÀRÇRØ((sgD:\SG_ServerCode\ServerPython\ZoneServerGroup\map1_8G\MapServer\MapServerData\Script\Player\ChPlayer.pyR–cs    cCsŠ|d}|d}t||||ƒ}tjƒjƒ}d|kr†|d}||kr†|rstj|ƒqƒtj|ƒq†ndS(sbÊÕµ½ÓÎÏ··þÍæ¼ÒÔÚÏß״̬ͬ²½
    ¿ç·þÊÕµ½ÔÚÏß״̬ͬ²½Ê±¶¼ÊÓΪÔÚ¿ç·þÉÏÏߣ¬ÐèÒª´¦Àí¿ç·þÔÚÏß/ÉÏÏßµÄÂß¼­
    ²»È»ÔÚ¿ç·þά»¤ÓÎÏ··þ²»Î¬»¤µÄÇé¿öÏ£¬µÈ¿ç·þÖØ¿ªºó£¬ÓÎÏ··þÖØÐÂͬ²½ÔÚÏßÍæ¼Ò£¬´ËʱÈç¹û¿ç·þ²»´¦ÀíµÇ¼Âß¼­£¬»áÉÙͬ²½·â°ü
    È繫»á£¬¿ç·þά»¤Ö®ºóµÇ¼µÄÍæ¼Ò»áÈ¡²»µ½¹«»áÊý¾Ý£¬µÈ¿ç·þÖØ¿ªºó£¬ÐèÊÓΪµÇÂ¼ÖØÐÂͬ²½
    Óë¿ç·þÖØÁ¬Ò»ÑùµÄµÀÀí£¬¶¼ÊÇÖØÐÂͬ²½ËùÓÐÐÅÏ¢
    RÜRÇR·N(RÚRt GetGameWorldt GetServerIDR}tOnCrossPlayerLoginRß(RØRÛR±RÜRÇR×t curServerIDR·((sgD:\SG_ServerCode\ServerPython\ZoneServerGroup\map1_8G\MapServer\MapServerData\Script\Player\ChPlayer.pyRë}s
 
 
 
cCsHtjƒ}|jƒ|jƒ|_|jƒ|_tj||ƒdS(N(tChPyNetSendPackttagMCPlayerInfotCleartIsAdultR£tCreateRoleTimet NetPackCommont SendFakePack(R    t playerInfoEx((sgD:\SG_ServerCode\ServerPython\ZoneServerGroup\map1_8G\MapServer\MapServerData\Script\Player\ChPlayer.pyR>£s  
cCs…|jƒ}|jtjƒr"dStjd|ƒtj|dƒ|jdƒt    j
|t    j |ƒƒ|j ƒdkrŠt j|ƒntj|jƒ|jƒ|ƒtjddƒ}x'|D]\}}tj|||ƒqÂWtj|jƒƒ}tjddiƒ}|j|iƒ}x-|jƒD]\}}tj|||ƒq.Wtj|ƒtj|ƒtj|tjdƒdS(NsÍæ¼ÒÊǵÚÒ»´Î½øÈëÓÎÏ·iit MailLVAwardii( RœRbRtDef_Player_Dict_FirstLoginRRyR+tWriteEvent_Entryt SetFightPointtGameObjtSetHPtGetMaxHPRÎRAR]R)t DR_FirstLogintGetAccIDtGetIPt IpyGameDataPYtGetFuncEvalCfgRt SendMailByKeytGetAppIDByAccIDtgettitemsR~tOnPlayerFirstLoginR…tInitGoldEnergyR R/(R    R±tmailListt mailTypeKeyt mailItemListtappIDt appIDMailDicttmailDict((sgD:\SG_ServerCode\ServerPython\ZoneServerGroup\map1_8G\MapServer\MapServerData\Script\Player\ChPlayer.pyR4¬s,     c
Csštjƒjtjƒ}|s"dS|jƒ}tjƒjtjƒ}|jtj    ƒ}||kr|tj
d||ƒdStjƒjtj ƒ}tj d||f|ƒt j|tj    |ƒ|jƒdkrêtj d|ƒdS|jtjdƒtj|ƒtj|dƒtjddƒ}tjddƒ}tjddƒ}tjdd    ƒ}    td
||    ƒ}
|\} } g} x¥|D]\}}}tjƒj|ƒ}|s¾qŽn|jd ƒ}|jƒ}|tjkrîqŽn|jdƒ}|s    qŽn||
kr*|||gg} qŽPqŽWi|d 6|d 6|
d6}|| }tj d|
|f|ƒt j d|g|d| d| d|ƒdS(Ns'±¾´ÎºÏ·þÒѾ­µÇ¼¹ý. lastMixServerDay=%ss9Íæ¼ÒºÏ·þÊ׵Ǵ¦Àí! lastMixServerDay=%s,mixServerWorldLV=%sis    ÐºŲ»¸øºÏ·þ½±Àø!t    MixServert MixServerMailiiii–itMixServerWorldLVtLastMixServerDayt ItemWorldLVs3    ·¢ËͺϷþ²¹³¥Óʼþ: itemWorldLV=%s,addItemList=%st
MixServer1tgoldtsilvertdetail(!RRìtGetGameWorldDictByKeyRÓtDef_Notify_WorldKey_IsMixServerRt$Def_Notify_WorldKey_LastMixServerDayRbRtDef_PDict_MixLoginDayR§t(Def_Notify_WorldKey_LastMixServerWorldLVRyR R/RÎRR˜RCt ResetDaySignR?tDoResetCTGCountRRt
GetFuncCfgtmaxt GetGameDatatGetItemByTypeIDtGetEffectByIndext GetEffectIDtDef_Effect_ItemAddLVtGetEffectValueR(R    t isMixServerR±tlastMixServerDayt    playerDaytmixServerWorldLVR tworldLVMailItemListt mailMoneyListt worldLVDownt itemWorldLVRRtworldLVItemListtitemIDt    itemCounttisBindtitemDatatcurEfftcurEffIDtlvLimitt
detailDictt addItemList((sgD:\SG_ServerCode\ServerPython\ZoneServerGroup\map1_8G\MapServer\MapServerData\Script\Player\ChPlayer.pyt__DoMixServerFirstLoginàsX      
(cCs0tj|tjdƒtj|tjdƒdS(Ni(R R/RtDef_Player_Dict_PlayerDeadCnttDef_Player_Dict_DeadTime(R    ((sgD:\SG_ServerCode\ServerPython\ZoneServerGroup\map1_8G\MapServer\MapServerData\Script\Player\ChPlayer.pytClearPlayerDeadInfo!scCsg|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(RðttagMCPlayerSkillsRòtSkillstGetSkillManagertranget GetSkillCounttGetSkillByIndexttagPlayerSkillt
GetSkillIDtSkillIDt GetRemainTimet
RemainTimetGetProficiencyt ProficiencyR»RtCountRõRö(R    tsendPackt skillManagerRètcurSkillt    skillInfo((sgD:\SG_ServerCode\ServerPython\ZoneServerGroup\map1_8G\MapServer\MapServerData\Script\Player\ChPlayer.pyt__Sync_ClientSkillXs 
      cCsnt|ƒ|jƒjƒ|jƒjƒ|jƒjƒ|jƒjƒ|jƒjƒ|jƒjƒdS(N(t__SyncClearBufft GetBuffStatet    Sync_BufftGetDeBuffStatetGetAurat
GetIncBufftGetProcessBuffStatetGetProcessDeBuffState(R    ((sgD:\SG_ServerCode\ServerPython\ZoneServerGroup\map1_8G\MapServer\MapServerData\Script\Player\ChPlayer.pyt__Sync_ClientBuffps
cCsQtjƒ}|jƒ|jƒ|_|jƒ|_d|_tj    ||ƒdS(Nic(
t ChNetSendPackttagClearObjBuffRòtGetGameObjTypetObjTypeRœtObjIDtBuffTypeRõRö(R    t
clientPack((sgD:\SG_ServerCode\ServerPython\ZoneServerGroup\map1_8G\MapServer\MapServerData\Script\Player\ChPlayer.pyR\zs 
    cCs­|jtƒ|jtƒ|jtƒ|jtƒ|jtƒtj|dƒtj|tƒt    ||ƒt
j ƒj ƒt jkr¢tj|tj|ƒn|jƒ|jƒkrÓtj||jƒƒn|jƒdkrøtj|dƒntj||ƒt
jƒr$|jtƒntj|ƒ}|jƒt
jƒrY|jt ƒn|j!|ƒ|j"|ƒ|j#tj$|ƒtj%||ƒt&|ƒt t'_(dS(Ni'i()t
SetCanMoveRt    SetInitOKt SetMapLoadOKt
SetVisiblet SetCanAttackRütSetMaxHPt    SetHPFullt__CheckClearBuffOnMapChangeRtGetMapt GetMapFBTypet IPY_GameWorldtfbtNullt SkillCommontAddBuffBySkillType_NoRefurbishRtDef_SkillID_LimitSuperBufft GetSightLevelRœR tSetPlayerSightLeveltGetSighttSetSightt PlayerStatetChangePlayerSighRRRtGetOnlinePlayert ReCalcAllAttrRtSetProcessEquipDurgTickt SetLoginTickRtDef_PlayerKey_CalcOLTimeTicktRefreshRebornPointtSavePlayerMessionInDataServert
PyGameDatatg_needRefreshMapServerState(R    RtolPlayer((sgD:\SG_ServerCode\ServerPython\ZoneServerGroup\map1_8G\MapServer\MapServerData\Script\Player\ChPlayer.pyR(‰s8       
 
    cCs»tjƒjƒ}tjdƒ}g}xf|jƒD]X\}}| sS||kr4tj|||ƒrŒtjd|ƒ|j    |ƒqŒq4q4Wx$t
j D]}tj|||ƒqšWdS(NtFBBuffsÇеØÍ¼É¾³ý¶àÓàbuff: %s( RRtR"t ReadChConfigtGetEvalChConfigRt    BuffSkilltDelBuffBySkillIDR§R»RtClearBuffOnMapChangeList(R    RtcurMapIDt
fbBuffDictt
buffIDListtbuffIDt    mapIDList((sgD:\SG_ServerCode\ServerPython\ZoneServerGroup\map1_8G\MapServer\MapServerData\Script\Player\ChPlayer.pyRsÅscCsdS(N((R    ((sgD:\SG_ServerCode\ServerPython\ZoneServerGroup\map1_8G\MapServer\MapServerData\Script\Player\ChPlayer.pyR‡ÛscCstjtƒ||ƒdS(N(Rt GetPsycoFunct__Func_PlayerLogin(tindexR((sgD:\SG_ServerCode\ServerPython\ZoneServerGroup\map1_8G\MapServer\MapServerData\Script\Player\ChPlayer.pyt PlayerLoginéscCs²tjƒj|ƒ}y\t||ƒt||ƒ|jtƒ|jƒt||ƒt    ||ƒt
||ƒWn:|j t j ƒddl}tjd|jƒƒnXdS(NiÿÿÿÿsÍæ¼ÒÉÏÏßÂß¼­´íÎó
%s(RRštGetPlayerByIndexR
R$RlRtSendToBServerServerInitOKR t__Func_LoadMapOKR tKickRvtdisWaitForPlayerLoinErrort    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ƒtj    ƒj
ƒt j kr~|j dƒn |j dƒ|jƒ|jtƒdS(Nii(RRšRšR
RxtPlayerChangeMapUpdateSkillCDR'R(tInitChangeMapPlayerSummonInfoRtRuRvtfbtTeamtGameServer_TeamEnterFBt#BalanceServer_PlayerChangeMapInitOKRlR(R˜RR    ((sgD:\SG_ServerCode\ServerPython\ZoneServerGroup\map1_8G\MapServer\MapServerData\Script\Player\ChPlayer.pyR¢s
 
     
 
cCstj|tjdtdtƒtj|tjƒtj|tjdtƒtj|tj    ƒtj|tj
dtdtƒtj|tj dtdtƒtj|tj dtdtƒtj|tj dtdtƒtj|tjƒtj|ƒt|ƒtj|ƒdS(Nt
defaultMaxtisSync(R tInit_PackCountRvtrptEquipRRtrptItemt rptIdentifyRÓtrptHerot
rptMGGuayut rptMGTuiyant rptTempSwapt rptTempItemt rptTreasuret
ItemCommontSyncPackBuyCntRHR7tCheckGiveBindMoneyTypeItem(R    ((sgD:\SG_ServerCode\ServerPython\ZoneServerGroup\map1_8G\MapServer\MapServerData\Script\Player\ChPlayer.pyR'\s 
 cCstj}t||ƒS(N(RRztCheckHasBuffBySkillID(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"tGetSkillBySkillIDRyRRRxt GetBuffTypetGetBuffManagerByBuffTypetGetSkillTypeIDtFindBuffR(R    R¹t    buffSkilltbuffTypet    buffTuplet    buffStatetbuffSkillTypeIDtcurBuff((sgD:\SG_ServerCode\ServerPython\ZoneServerGroup\map1_8G\MapServer\MapServerData\Script\Player\ChPlayer.pyR¸¤s 
 cCs²tjƒj|ƒ}|jƒrÎ|jtjƒ}|jtjƒ}|rÊ|rÊtjd|j    ƒƒ|j
tjdƒ|j
tjdƒ|j t ƒt j|tjƒ|jƒtj||ƒndSt|ƒsÞdStjd|j    ƒƒ|jt ƒ|j|jƒ|jƒƒ|jƒ|jƒkrNt j||jƒƒn|jƒdkrst j|dƒn|jƒ|j t ƒtj|ƒdkr²|jtj ƒn|j!t ƒ|j"t ƒt j#|t ƒt$j%||ƒtj&||ƒtj'ƒ}|jƒ}|jƒ}|j(tj)ƒr§|j(tj)ƒdkr`t j |ƒj*ƒn.t+j,||tj-ƒ\}}|j.||ƒt j/|tj)dƒntj|ƒdksÑ|j0ƒtj kr&|jtj1ƒ}|ròtj2ntj3}    tj4ƒrtj3}    nt5||    |ƒn½|j6||ƒt krãt+j,||tj-ƒ\}
} |
dkr°| dkr°tjd||f|j    ƒƒt j |ƒ} | j*ƒqã|j.|
| ƒtjd|
| f|j    ƒƒn|j7ƒtj8kr[t9j:tj'ƒj;ƒƒtj<kr[|j=tj8ƒt>j?|tj@|ƒt>j?|tjA|ƒn|jBƒ} |jCƒ| kr¤|jD| ƒtE|ƒtjFd| ƒn|jGƒt S(Ns'Íæ¼Ò¸±±¾Öбä¸ü¹¦ÄÜÏß·ÐéÄâÇеØÍ¼³É¹¦!!!is µØÍ¼¶ÁÈ¡³É¹¦is:Íæ¼ÒµÇÂ¼ÖØÖÃλÖÃʧ°Ü, °ÑÍæ¼Ò´ò»ØÖØÉúµã posX = %s posY = %ss<Íæ¼ÒµÇÂ¼ÖØÖÃλÖÃʧ°Ü, ÉèÖø½½üµã nearPosX = %s nearPosY = %ss½øÈëµØÍ¼Ç¿ÖÆÇл»PKģʽ: %s(HRRšRšt GetMapLoadOKR—RtDef_PlayerKey_ResetFBLinePosXtDef_PlayerKey_ResetFBLinePosYRyRRRoRR R~tDef_PlayerSight_Defaultt RefreshViewR t    DoEnterFBt__CheckForbidLoginRntInitPostGetPosXtGetPosYR{RœR|R}RütGetHPtSetPlayerActionRvtpaDieRmRltSetIsNeedProcesst PlayerGMOpert DoGMOperLogictDoEnterFBLogicRtRbtDef_PDict_IsReBorntSetToBornPlacetGameMaptGetNearbyPosByDistDef_RebornPos_Area_RangetResetPosR/tGetPlayerActionRtrebornType_CitytrebornType_SystemRtPlayerRebornByTypetCanMovet
GetFactiontCampType_NeutralRItGetRecordMapIDR"tDef_MapID_NeedCampt
SetFactionRŽRtDef_SkillID_JusticetDef_SkillID_EviltGetInitAttackModelt GetAttackModet SetAttackModet SyncPKModelR§t
EndLoadMap(R˜RR    tresetFBLinePosXtresetFBLinePosYtcurMaptposXtposYtisLogint
rebornTypetnearPosXtnearPosYt playerControltinitAttackModel((sgD:\SG_ServerCode\ServerPython\ZoneServerGroup\map1_8G\MapServer\MapServerData\Script\Player\ChPlayer.pyRœÂs„   
 
      *    #$  
 
cCs9tjƒ}|jƒ|jƒ|_tj||ƒdS(N(RðttagMCAttackModeRòRêtModeRõRö(R    RW((sgD:\SG_ServerCode\ServerPython\ZoneServerGroup\map1_8G\MapServer\MapServerData\Script\Player\ChPlayer.pyRìPs
 
cCstS(N(R(R    ((sgD:\SG_ServerCode\ServerPython\ZoneServerGroup\map1_8G\MapServer\MapServerData\Script\Player\ChPlayer.pyt__CheckGMCanLoadMapOK]scCsP|jƒtdtjƒ@dkr&tStjd|jƒƒ|jt    j
ƒdS(NiisÍæ¼Ò±»·âºÅ½ûÖ¹µÇ¼( t GetAccStatetpowRtDef_PysForbidByPyRRRyRRRvt    disGMKick(R    ((sgD:\SG_ServerCode\ServerPython\ZoneServerGroup\map1_8G\MapServer\MapServerData\Script\Player\ChPlayer.pyRÌus
"c    Cs„tjƒj|ƒ}|j}|j}| sM| sMt|ƒt|ƒkrQdSd}x>t|ƒD]0\}}tjd|ƒs†dS|||7}qdW|j    ƒ}    ||    krËtj
d|    |fƒdS|j |    |ƒx{t|ƒD]m\}}||}
|j t j|ƒ} | |
} tj|t j|| ƒtj
d|| |
| fƒqéWt||ƒtj|ƒ} | jƒdS(Nit    RolePoints3Ê£ÓàµãÊý²»×ã! curFreePoint(%s) < needTotalPoint(%s)s7Íæ¼Ò¼Óµã: attrID=%s,curPoint=%s,addPoint=%s,updPoint=%s(RRšRštPointAttrIDListtPointValueListRt    enumerateRtGetIpyGameDatat GetFreePointR§t SetFreePointRbRtDef_PDict_AddPointValueR R/tNotifyPlayerBasePointtRefreshPlayerAttrState(R˜t
clientDataRR    tpointAttrIDListtpointValueListtneedTotalPointRètattrIDt curFreePointtaddPointtcurPointtupdPointR÷((sgD:\SG_ServerCode\ServerPython\ZoneServerGroup\map1_8G\MapServer\MapServerData\Script\Player\ChPlayer.pyt
OnAddPoint‡s2        &  
 
! 
cCstjƒj|ƒ}tjƒ}gt|jƒƒD]}|j|ƒjƒ^q4}t    }x4|D],}|j
t j |ƒ}|rbt }PqbqbW|s©tjdƒdS|jƒtjddƒk}    |    stjddƒ}
|jƒjtjƒ} d} d} xÓ|
D]Ë}tj|| dƒ\}}|s7q
nx‹|D]ƒ}| j|ƒ}tj|ƒshq>ntj|ƒ\}}|rº|dkr•q>n| s¨|| krÁ|} |} qÁq>|} Pq>W| dkr
Pq
q
W| dkrédStj|| | gdt    t jƒndS(    NsÖØÖüӵã Ã»ÓеãÊýÐèÒªÖØÖÃt LVUPAddPointiiiÿÿÿÿii
i(RRšRšRtIPY_DataRâtGetRolePointCounttGetRolePointByIndext    GetAttrIDRRbRRRR§RÎR RR>R@RvR­RµtGetItem_FromPack_ByIDtGetAttCheckItemCanUsetGetItemRemainingTimet
ReduceItemtItemDel_ResetAttrPoint(R˜R
RR    t
ipyDataMgrtcanResetIDListtcanResetRRtisFreetneedItemIDListtitemPacktdelIndext
expireTimeR1t    hasEnought itemIndexListt    itemIndextcurItemt isExpireItemt remainingTime((sgD:\SG_ServerCode\ServerPython\ZoneServerGroup\map1_8G\MapServer\MapServerData\Script\Player\ChPlayer.pytOnResetAttrPoint¬sR 4        %c    Cs×|sItjƒ}gt|jƒƒD]}|j|ƒjƒ^q%}ng}g}x>|D]6}|jtj|ƒ}|j    |ƒ|j    |ƒq\Wt
j ƒ}||_ ||_ t|ƒ|_tj||ƒdS(N(RRRâRRRRbRRR»RðttagMCRolePointInfoRRRtPointAttrIDCountRõRö(    R    tsyncAttrIDListRR˜R R RRt    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ÿÿÿÿ(RRšRšt__CheckPlayerCanMoveRtRátPosXtPosYtStopMovet    ChangePosRðttagMCMoveByTypeRòRœtIDRgRhtMoveTypeR t PyNotifyAllR(R˜R
RR    RW((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ÿÿÿÿ(RRšRšt GetTickByTypeRtTYPE_Player_Tick_RushtTYPE_Player_Tick_Timet SetTickByTypeR2RtRáR3R4R5R6Rðt    tagMCRushRòRœR8RgRhR R:R(R˜R
RR    RW((sgD:\SG_ServerCode\ServerPython\ZoneServerGroup\map1_8G\MapServer\MapServerData\Script\Player\ChPlayer.pyt OnPlayerRush#s$& 
 
  c     Csªtjƒj|ƒ}tj|tjtjƒs4t    St
|ƒsDdS|j }|j }|j }|j}|j}||kr||krdStjƒj||ƒsÅ|j|jƒ|jƒƒdS||jdƒdkrâdS|jd|ƒ|jƒ}    |    tjtjgkrdStjƒ}
t|||
||||ƒsHdStj||||ƒdkr†|j|jƒ|jƒƒdStj||ƒ|j||ƒdS(Nt FightMoveTicki2i(RRšRštOperControlManagertIsObjCanDoActionRtDef_Obj_ActState_ServerActRvtoalMoveRR2tStartXtStartYtDestXtDestYt    WorldTickRtRáRÜRÎRÏR—RtGetPlayerVehicletpvNulltpvHorset CheckMovePostGetDistR tDelLimitSuperBuffR6( R˜R
RR    tsendPack_StartXtsendPack_StartYtsendPack_DestXtsendPack_DestYtsendPack_WorldTicktvehicleRð((sgD:\SG_ServerCode\ServerPython\ZoneServerGroup\map1_8G\MapServer\MapServerData\Script\Player\ChPlayer.pytPlayerFightMove]sB                            cCso|jƒstS|jƒs tStj|ƒdkr9tStj|tjt    j
ƒsXtSt j |ƒsktSt S(Ni(RÆRt
GetCanMoveRüRÐRCRDRRERvRFR tPlayerCanStateTransferR(R    ((sgD:\SG_ServerCode\ServerPython\ZoneServerGroup\map1_8G\MapServer\MapServerData\Script\Player\ChPlayer.pyR2¨s   cCsdStjƒ}tj||||ƒs6|jƒdSt|||||||ƒsXdStj|tjƒ|j    ||ƒdS(N(
RRtR tPlayerMoveCheckClientWorldTicktSync_ClientTickROtChangePlayerActionRvtpaNulltMove(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(R tPlayerRefreshPosRœRÜRÎRÏRRátMoveFailRRPRtDef_PlayerMaxMoveDistR( R    tcheckObjRðtstartXtstartYtdestXtdestYtsendPlayerMoveFailtobjPosXtobjPosYtmoveDist((sgD:\SG_ServerCode\ServerPython\ZoneServerGroup\map1_8G\MapServer\MapServerData\Script\Player\ChPlayer.pyRO÷s     cCsÓtjƒj|ƒ}tjƒ}|jƒ}tjd||jƒƒtjƒrdtjdƒdSt    j
|ƒr„t ||ƒdSt j ||ƒrªt    j|dƒdSt|||ƒrÏt|||ƒndS(NsÍæ¼Òµã»÷¸´»î: rebornType=%ss¿ç·þ·þÎñÆ÷²»½ÓÊܸ´»îÇëÇó!tReborn_lhs_31379(RRšRšRvtIPY_CCliectReborntGetTypeR§RRR R3tOnReqCrossServerRebornR tDoFBForbidRebornt
NotifyCodeRàtPlayerReborn_InFB(R˜RR    RWRô((sgD:\SG_ServerCode\ServerPython\ZoneServerGroup\map1_8G\MapServer\MapServerData\Script\Player\ChPlayer.pytPlayerClickReborn-s      cCstj|ƒ}|s&tjdƒdSt||dtƒs?dSi|jƒd6|d6}tjtj    |ƒtjd||f|jƒƒdS(Nsµ±Ç°ÎÞ¿ç·þµØÍ¼!t checkHPStatetPlayerIDt
RebornTypes(¿ç·þÖÐÇëÇó¸´»î, crossMapID=%s,msgDict=%s(
R R3RR§t__CheckCanRebornRRtSendMsgToCrossServerRÓtClientServerMsg_Reborn(R    Rôt
crossMapIDtmsgDict((sgD:\SG_ServerCode\ServerPython\ZoneServerGroup\map1_8G\MapServer\MapServerData\Script\Player\ChPlayer.pyRuKs  cCsŒ|d}tjƒ}t|||ƒs,dS|jtjƒ}t|||ƒidd6|d6}|j|ƒtjt    j
||gƒdS(NR|itResultt ReviveTired( RRtR}RbRtDef_PDict_IsAddReviveTiredt__DoPlayerRebornRêtSendMsgToClientServerRÓtCrossServerMsg_RebornRet(R    tmsgDatat serverGroupIDRRôtgameMaptisAddReviveTiredtmsgInfo((sgD:\SG_ServerCode\ServerPython\ZoneServerGroup\map1_8G\MapServer\MapServerData\Script\Player\ChPlayer.pyR[s
  cCsX|d}|dkrdS|d}|d}t||tƒ|rTt||ƒndS(NR‚iR|Rƒ(t __RebornCostRt__AddReviveTired(R    RˆRtresultRôR‹((sgD:\SG_ServerCode\ServerPython\ZoneServerGroup\map1_8G\MapServer\MapServerData\Script\Player\ChPlayer.pyR‡ms
 
 
cCs`tjƒ}|jƒ|jƒ|_||_|jƒ|_|jƒ|_    t
j ||ƒdS(N( RettagPlayerRebornRòRR{tTypeRÎR3RÏR4RõRö(R    Rôt
rebornInfo((sgD:\SG_ServerCode\ServerPython\ZoneServerGroup\map1_8G\MapServer\MapServerData\Script\Player\ChPlayer.pytSyncPlayerReborn}s 
    cCs&tjƒj|ƒ}t||ƒdS(N(RRšRštPlayerDisconnectEx(R˜RR    ((sgD:\SG_ServerCode\ServerPython\ZoneServerGroup\map1_8G\MapServer\MapServerData\Script\Player\ChPlayer.pytPlayerDisconnects cCsbyt||ƒWn*ddl}tjd|jƒƒnXtjt|ƒƒ|j|ƒdS(NiÿÿÿÿsÍæ¼ÒÏÂÏßÂß¼­´íÎó
%s(    tDoPlayerDisconnectRŸRR R¡Rt    MapCallDBtGetPackSaveDatat DoDisconnect(R    RRŸ((sgD:\SG_ServerCode\ServerPython\ZoneServerGroup\map1_8G\MapServer\MapServerData\Script\Player\ChPlayer.pyR”—s cCsOtj|jƒƒ}d}tj|tjƒ}tj|t|ƒ|ƒ}|S(NR¡(    tbase64t    b64decodet GetPackDatatCommFunct    WriteBYTEtIPY_ServerDefinet    gstUpdatet WriteStringR(R    t roleSaveDatatallData((sgD:\SG_ServerCode\ServerPython\ZoneServerGroup\map1_8G\MapServer\MapServerData\Script\Player\ChPlayer.pyR˜£s
cCstjd|jƒƒtj||ƒ|jtjƒƒtj|ƒtj    |t
j dƒtj    |t
j dƒt j|ƒt|dƒtj|ƒdS(NsPlayerDisconnect!i(RRyRR tPlayerLeaveServert SetLogoffTimeR&R)tDR_PlayerDisconnectR/Rt!Def_Player_Dict_RouteServerInitOKtDef_PlayerKey_CrossRegisterMapR+tWriteEvent_sessionR–RtOnPlayerLogoff(R    R((sgD:\SG_ServerCode\ServerPython\ZoneServerGroup\map1_8G\MapServer\MapServerData\Script\Player\ChPlayer.pyR–°s    cCsƒtjƒj|ƒ}tjƒ}|jƒ}tj|ƒs\d}tjd|jƒƒdSt    |ƒdkrrdS|j
|ƒdS(NR¡sSetShutCutData Encoding Errid( RRšRšRvtIPY_CSetShutCutDatat
GetSettingtEncodingToUnicodetErrLogRœRt
SetSetting(R˜RR    RWtsetting((sgD:\SG_ServerCode\ServerPython\ZoneServerGroup\map1_8G\MapServer\MapServerData\Script\Player\ChPlayer.pytSetShutcutSettingHVàs   c Cstjƒj|ƒ}|jƒ}|j}|j}|jddƒ}t|ƒ}tj    ƒ}|j
t j |ƒ}    |    j tƒ}
|
s‹dS|
jƒ} |s°| j|dƒnFd} || krìt| ƒ| krìtjd| ƒdSn|| |<t||ƒdS(Ns R¡ids´æ´¢¸öÊý´ïµ½ÉÏÏÞ! keyMax=%s(RRšRšRtKeyNumtSetDataR¦R™R¸t GetGameRecMgrtGetRecTypeIDMgrRÓtDef_GameRecType_Settingt GetOneRecDataRt GetUserDicttpoptNoneRR®R( R˜R
RR    R±tkeyNumtsetDatatkeyStrt
gameRecMgrt preSetRecMgrtrecDatatdataDicttkeyMax((sgD:\SG_ServerCode\ServerPython\ZoneServerGroup\map1_8G\MapServer\MapServerData\Script\Player\ChPlayer.pyt OnSettingDataús,             
 R¡c CsF|jƒ}tjƒ}|jtj|ƒ}|jƒ}|sCdS|jƒ}g}|rd|gn    |jƒ}xŽ|D]†}||kr–||}    nd}    t    j
|dƒ}
|
dkrÀqwnt j ƒ} |
| _|    | _t| jƒ| _|j| ƒqwW|s dSt jƒ} || _t| jƒ| _tj|| ƒdS(NR¡(RR¸R´RµRÓR¶R·R¸RCRR¥RºRðttagSCSettingDataR²R³RtDataLenR»ttagSCSettingDataInfotSettingDataListtDataCntRõRö( R    R½R±R¾R¿RÀRÁtsettingDataListt syncKeyListR¼R»tsDataRk((sgD:\SG_ServerCode\ServerPython\ZoneServerGroup\map1_8G\MapServer\MapServerData\Script\Player\ChPlayer.pyRs8                      cCsÿtjƒj|ƒ}|j}|tjkrKtjd||jƒƒdSx­tdtj    dƒD]•}t
|d|ƒs¡tjd||f|jƒƒqbnt |d|ƒ}t j |tj||f|ƒtjd|||f|jƒƒqbWdS(Ns!СÖúÊÖ²»Ö§³Ö¸ÃÉèÖñàºÅ! setNum=%sisValue%ss+СÖúÊÖ²»Ö§³Ö¸ÃÖµ±àºÅÉèÖÃ! setNum=%s,value%ss"СÖúÊÖÖµÉèÖÃ: setNum=%s,value%s=%s(RRšRštSetNumRtLittleHelperSetNumCountR®RRâtLittleHelperValueCountthasattrtgetattrR R/t!Def_Player_Dict_LittleHelperValueR§(R˜R
RR    tsetNumRètvalue((sgD:\SG_ServerCode\ServerPython\ZoneServerGroup\map1_8G\MapServer\MapServerData\Script\Player\ChPlayer.pytOnSetLittleHelperDs      'cCsg}xÈttjdƒD]³}d}xŽtdtjdƒD]v}|jtj||fƒ}|skq=n|s‰tjƒ}||_    nt
|d|ƒr=t |d||ƒq=q=W|r|j |ƒqqW|sÛdStj ƒ}||_t|jƒ|_tj||ƒdS(NisValue%s(RâRRÍRºRÎRbRÑRðttagMCLittleHelperFuncSetRÌRÏtsetattrR»ttagMCLittleHelperSett FuncSetListRt FuncSetCountRõRö(R    t funcSetListRÒtfuncSetRèRÓtsetPack((sgD:\SG_ServerCode\ServerPython\ZoneServerGroup\map1_8G\MapServer\MapServerData\Script\Player\ChPlayer.pyR^Ss*       cCstjƒj|ƒ}|j}|j}|dkr |s?dntddƒd}x1ttjƒD] }t    j
|tj ||ƒqbWtj d||fƒnj|dtjkrÈtj d|ƒdStj d||fƒ|rëdnd}tj|tj ||ƒdS(    Niÿiiiis"ÉèÖÃÈ«²¿Òýµ¼×´Ì¬: isOK=%s,value=%ss0ÉèÖÃÒýµ¼Ê§°Ü, ³¬¹ý×î´óÖ§³Ö¼Ç¼λ£¡ guideIndex=%ss"ÉèÖÃÒýµ¼³É¹¦ guideIndex=%s,isOK=%s(RRšRšt
GuideIndextIsOKRýRâRtDef_GuideStateKeyCountR R/tDef_Player_Dict_GuideStateR§R®tSetDictValueByBit(R˜R
RR    t
guideIndextisOKRÓRè((sgD:\SG_ServerCode\ServerPython\ZoneServerGroup\map1_8G\MapServer\MapServerData\Script\Player\ChPlayer.pyt OnSetGuideOKus         cCsutjƒ}g|_x7ttjƒD]&}|jj|jtj|ƒƒq%Wt    |jƒ|_
t j ||ƒdS(N( RðttagMCGuideStatet
GuideStateRâRRßR»RbRàRRVRõRö(R    tguideStatePackRè((sgD:\SG_ServerCode\ServerPython\ZoneServerGroup\map1_8G\MapServer\MapServerData\Script\Player\ChPlayer.pyR6Šs     $cCs)tjƒ}||_tj||ƒdS(N(RðttagMCShowGuidetGuideIDRõRö(R    tguideIDt    showGuide((sgD:\SG_ServerCode\ServerPython\ZoneServerGroup\map1_8G\MapServer\MapServerData\Script\Player\ChPlayer.pyt    ShowGuide”s     cCsKtjƒj|ƒ}|sdS|jƒ}|jƒ}||krGdSdS(N(RRšRštGetPlayerLastActionRÝ(R˜RR    t
lastActiont    curAction((sgD:\SG_ServerCode\ServerPython\ZoneServerGroup\map1_8G\MapServer\MapServerData\Script\Player\ChPlayer.pytOnPlayerChangeActionŸs   cCs‚tjƒj|ƒ}tjƒ}|jƒ}|dksE|dkrIdS|j|ƒtj|ƒdkr~t    j
||ƒndS(Niid( RRšRšRvtIPY_CSetHPRestoretGetValuetSetHPRestoreSettingRüRÐR tPlayerAutoRestoreHP(R˜RR    RWtcurValue((sgD:\SG_ServerCode\ServerPython\ZoneServerGroup\map1_8G\MapServer\MapServerData\Script\Player\ChPlayer.pytHPRestoreSetting½s   cCs‚tjƒj|ƒ}tjƒ}|jƒ}|dksE|dkrIdS|j|ƒtj|ƒdkr~t    j
||ƒndS(Niid( RRšRšRvtIPY_CSetMPRestoreRòtSetMPRestoreSettingRüRÐR tPlayerAutoRestoreMP(R˜RR    RWRõ((sgD:\SG_ServerCode\ServerPython\ZoneServerGroup\map1_8G\MapServer\MapServerData\Script\Player\ChPlayer.pytMPRestoreSettingÛs   cCsÔ|tjks|tjkr3tjd|ƒdS|jƒ|krZtjd|ƒdStjƒjƒ}|td|ƒ@sštjd||fƒdS|tjkr¹t    j
|ƒn|j |ƒt |ƒdS(Ns*±ä¸üPKģʽÒì³££¬²»´æÔÚ¸Ãģʽ!attackMode=%ss PKģʽÏàͬ£¬²»±ä¸ü!attackMode=%sis3±¾µØÍ¼½ûÖ¹Çл»¸Ãģʽ£¡attackModels=%s,changeMode=%s( RvtamPeacetamMaxRR§RêRttGetAttackModelsRýt    NPCCommontClearSummonAngry_PlayerRëRì(R    t
attackModet attackModels((sgD:\SG_ServerCode\ServerPython\ZoneServerGroup\map1_8G\MapServer\MapServerData\Script\Player\ChPlayer.pytChangeAttackModeðs 
cCs;tjƒj|ƒ}|jr$dnd}|j|ƒdS(Nii(RRšRštAdultt 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ÆRüRÐR RZRRY(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.pytPlayerCanResetWorldPos9    scCs)tjƒj|ƒ}tj||ƒdS(N(RRšRšR tDoPlayerResetWorldPos(R˜RR    ((sgD:\SG_ServerCode\ServerPython\ZoneServerGroup\map1_8G\MapServer\MapServerData\Script\Player\ChPlayer.pyRB    scCs-tjƒj|ƒ}|jƒt|ƒdS(N(RRšRšt    ExitEventtNotifyChangeMapFail(R˜RR    ((sgD:\SG_ServerCode\ServerPython\ZoneServerGroup\map1_8G\MapServer\MapServerData\Script\Player\ChPlayer.pytPlayerChangeMapFailCallbackM    s
 
cCsM|jtƒtjƒ}|jƒtj||ƒtjd|j    ƒƒdS(Ns µØÍ¼Çл»Ê§°Ü(
RoRRðttagMCChangeMapFailRòRõRöRRyRœ(R    RW((sgD:\SG_ServerCode\ServerPython\ZoneServerGroup\map1_8G\MapServer\MapServerData\Script\Player\ChPlayer.pyR V    s   
cCs&tjƒj|ƒ}t||ƒdS(N(RRšRšt __Func_ExitFB(R˜RR    ((sgD:\SG_ServerCode\ServerPython\ZoneServerGroup\map1_8G\MapServer\MapServerData\Script\Player\ChPlayer.pytExitFBq    s cCs‘tjƒjƒtjkr=|jƒtjddƒkr=dStjd|j    ƒ|j
ƒƒt j |ƒspdSt j ||ƒtj|ƒdS(NtMapLineisÍæ¼Ò = %s , Ö÷¶¯À뿪¸±±¾(RRtRuRvRwR"RRRytGetNameRœR tCanPlayerLeaveFBtDoPlayerLeaveFBR t PlayerLeaveFB(R    R((sgD:\SG_ServerCode\ServerPython\ZoneServerGroup\map1_8G\MapServer\MapServerData\Script\Player\ChPlayer.pyR{    s9  c    Cs@tjƒj|ƒ}tjƒ}|jƒ}|dkrWtjd||jƒƒdStjƒrgdS|j    ƒ}d}t
j ddiƒ}||kr´t d||dƒ}nt
j ddƒ}||kr||kr|||krtjd||||f|jƒƒdSt ||ƒs,dStj||ƒdS(Nis%ChangeLine -> ·â°ü´íÎó, ÎÞ´ËÏß· = %sRiisF¸ÃµØÍ¼Ã»Óпª·Å´ËÏß·£¬ÎÞ·¨ÊÖ¶¯Çл»£¡mapID=%s,changLineID=%s,maxLine=%s(RRšRšRvtIPY_CChangeLinetGetLineR®RœRR"RRR!t__CheckCanChangLineR tPlayerChangeLine(    R˜RR    RWt changLineIDtmapIDtactivityLineIDtactivityMapLineDictt mapLineDict((sgD:\SG_ServerCode\ServerPython\ZoneServerGroup\map1_8G\MapServer\MapServerData\Script\Player\ChPlayer.pyt
ChangeLineœ    s,      (    cCsË||jƒtjkr-tj|dƒtS|jƒ}|tjkrXtj    |ƒn#|tj
kr{tj|dƒtStj |ƒržtj|dƒtS|j ƒtj krÇtj|dƒtStS(NtPK_liubo_500807tGeRen_liubo_71563tGeRen_liubo_850801tGeRen_liubo_760310(t GetLoginTickRtDef_PlayerChangLine_TickR RwRRÝRvtpaSitt DoPlayerStandtDef_PlayerChangLine_StatetIsPlayerInFightRLtDef_PlayerChangLine_VehicleR(R    Rt playerAction((sgD:\SG_ServerCode\ServerPython\ZoneServerGroup\map1_8G\MapServer\MapServerData\Script\Player\ChPlayer.pyRÅ    s  cCs/tj|ƒdkr.|jƒtjkr.dS|tjtjgkrJdStj    ƒj
ƒ}|tj kr¼t j ddƒ}tjtj    ƒjƒƒ}||kr¬||S|jddƒS|jtjƒr+tj|tjƒd}|r+|jƒjƒ|jƒjƒkr(t j ddƒdSq+ndS(s ËÀÍö״̬²ÅÑé֤ʱ¼ä£¬±¾·þ¿ç·þͨÓÃ
            ¿ç·þ·þÎñÆ÷ËÀÍöµÄ¸´»îÒ²ÊÇÏÈ·¢µ½±¾·þ£¬Õý³£Çé¿öϱ¾·þÊÇ»î×ŵģ¬ÎÞ·¨ÑéÖ¤
            ËùÒÔ¿É·ñ¸´»îÓÉ¿ç·þ·þÎñÆ÷ËÀÍö״̬ϵÄÍæ¼ÒʵÀýÅжϣ¬¼òµ¥½²¾ÍÊÇÄĸö·þÎñÆ÷ËÀÍöµÄÄĸö·þÎñÆ÷ÅжÏ
            ËùÒԸú¯Êý¿ÉÒÔÖ±½ÓʹÓÃÍæ¼ÒËùÔڵĵØÍ¼ÅжÏ
    itDuplicatesRebornTimeitRebornArguments(RüRÐRÝRvRÒRRÞtrebornType_MainCityRRtRuRwRRRIRäR"RRbR„Rxt 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(RbRR<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)(RüRÐRÝRvRÒR“RtDef_RebornTypeListRtrebornType_HealthtrebornType_UseItemtGetLocalRebornRR®R"R7R8R9RbR<R RwRyRRRR t OnCanFBRebornR(R    RôRŠRzR±trebornCDtcurTimetdeadTime((sgD:\SG_ServerCode\ServerPython\ZoneServerGroup\map1_8G\MapServer\MapServerData\Script\Player\ChPlayer.pyR}
s00  %& c Cs%tj|ƒ}|jƒ}|tjkr¾tjddƒ}|d}tj|tj    |ƒ}|s|t
j d||ƒdS|r!x6|D]+\}}    tj |||    tj ƒs‰dSq‰Wq!nc|tjkr!tj|tjƒ}
|
süt
j d|ƒdS|r!tj||
dtdƒq!ntS(NR-iis%»õ±Ò²»×㣬ÎÞ·¨Ô­µØ¸´»î! moneyPrice=%ss¸´»îµÀ¾ß²»×㣬ÎÞ·¨Ô­µØ¸´»î! tReborn(R R3RRR@RRt HaveMoneyExRÓtTYPE_Price_Gold_Paper_MoneyRR®tPayMoneytDef_Cost_ReviveRARµtFindItemInPackByEffectExtDef_Effect_ReborntDelItemR( R    RôtisDoCostR€R±t    rebornCfgt
moneyPricet costMoneyListt    moneyTypetmoneyCntt
rebornItem((sgD:\SG_ServerCode\ServerPython\ZoneServerGroup\map1_8G\MapServer\MapServerData\Script\Player\ChPlayer.pyR@
s* 
c
    CsYtj}t}|tjkrLtjƒr3t}qttj|tj    dƒn(|tj
krttj|tj    dƒn|j |ƒ|rtj |||ƒn|r¼t j|tj|ƒn|jtjƒrÞt||ƒntjddƒd}tj|ƒrtj|||ƒntj|ƒr@tj|||ƒntj|ƒ}|jƒtj|tj|ƒ|tjƒtj||ƒtj ƒ}    |tjkr¯| sûtj ƒj!|j"ƒ|j#ƒƒ sû|tj
kr|    j$ƒ|j%ƒkr|j&ƒn:|tj
krBtj'||    j$ƒ|    j(ƒ|    j)ƒƒntj*|t+j,ƒdS(NiitPKConfigiiè(-RtDef_MaxRateValueRRÞR tOnPlayerRebornRR R/R×R.RGtOnResetFBRebornPlacePosRxRyRzRbR„RŽRR Rt IsInPKStatetSetPKStateTickt IsInBossStatetSetBossStateTicktRefreshAllStateRüRýRþtOnPlayerRebornOverRRtRáRÎRÏtGetRebornMapIDR"RØtPlayerResetWorldPost GetRebornMapXt GetRebornMapYR]RvR^(
R    RôRt mapBornPlacetisAddSuperBufftresetHpPercentt
isFBRebornt    validTimeR÷RŠ((sgD:\SG_ServerCode\ServerPython\ZoneServerGroup\map1_8G\MapServer\MapServerData\Script\Player\ChPlayer.pyR…]
sB          
$ %' +cCs£tj|tjƒd}|rY|jƒjƒ}|jƒjƒ|kr_|d}q_nd}tj|tj||ƒtj    d|ƒt
j |tj dƒdS(Niis    ¸´»îÆ£ÀÍBUff buffSkillLV=%s( RxR/RR0R1R2R3RyRR§R R/R„(R    RR6t buffSkillLV((sgD:\SG_ServerCode\ServerPython\ZoneServerGroup\map1_8G\MapServer\MapServerData\Script\Player\ChPlayer.pyRŽœ
scCsatjƒ}t|||ƒs"dStjƒsGt||tƒsGdSnt|||||ƒtS(s Íæ¼Ò¸´»î
    N(RRtR}RRRR…(R    RôRRdReRŠ((sgD:\SG_ServerCode\ServerPython\ZoneServerGroup\map1_8G\MapServer\MapServerData\Script\Player\ChPlayer.pyRàª
s  cCs<tjƒjƒ}|tjkr%dStj|||ƒdS(N(RRtRuRvRwR t DoFBOnReborn(R    RôRR4((sgD:\SG_ServerCode\ServerPython\ZoneServerGroup\map1_8G\MapServer\MapServerData\Script\Player\ChPlayer.pyRx¿
s
cCsdS(N((R˜R
R((sgD:\SG_ServerCode\ServerPython\ZoneServerGroup\map1_8G\MapServer\MapServerData\Script\Player\ChPlayer.pytOnEnterCrossServerÑ
scCstjtƒ||ƒdS(N(RR–t__Func_EnterFbGameEvent(R˜R((sgD:\SG_ServerCode\ServerPython\ZoneServerGroup\map1_8G\MapServer\MapServerData\Script\Player\ChPlayer.pytEnterFbGameEventç
scCsPtjƒj|ƒ}tjƒ}|jƒ}|jƒ}tj|||ƒdS(N(    RRšRšRvtIPY_CEnterFbGameEventR"t    GetLineIDR t PlayerEnterFB(R˜RR    RWRtclientSendLineID((sgD:\SG_ServerCode\ServerPython\ZoneServerGroup\map1_8G\MapServer\MapServerData\Script\Player\ChPlayer.pyRlð
s    c
    Csntjƒj|ƒ}|j}|j}|j}|j}|j}|j}    t    ||||||||    ƒdS(N(
RRšRšR‘tMapIDtLineIDR3R4tExData1t__Func_WorldTransPort(
R˜RkRR    tpackTransportTypeRtlineIDRñ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-927DE1ACCC4F378ERwRx(ii(R"R<RtTYPE_Player_Tick_WorldTransportR>R?RRR§RtDef_PackType_TransportTypeRCR®RR tCheckPlayerTransporttCheckTagCountrytGetTransportPosRwtDef_Transport_Type_MissiontTransportVipLvRestricttPayForTransportRtDef_PlayerKey_TransTypet
BeginTrans(
R    RvRRñRòRRwRxR±t transportType((sgD:\SG_ServerCode\ServerPython\ZoneServerGroup\map1_8G\MapServer\MapServerData\Script\Player\ChPlayer.pyRu s>&          c    Cs&tj||||||||ƒtS(N(R RaR(R    RRñRòRwRŸtcanLockRx((sgD:\SG_ServerCode\ServerPython\ZoneServerGroup\map1_8G\MapServer\MapServerData\Script\Player\ChPlayer.pyRƒQ s"cCsX|jƒ|krNtjƒj||ƒsNtj||tjƒ\}}qNn||fS(N(R"RRtRáRÙRÚRRÛ(R    R„ttransportMapIDt transportPosXt transportPosY((sgD:\SG_ServerCode\ServerPython\ZoneServerGroup\map1_8G\MapServer\MapServerData\Script\Player\ChPlayer.pyR~l 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 RR>R@RvR­RµRtTransportPayMoneytTYPE_Price_Gold_PaperRR§RR(R    R„R1tuseCountR$R'titemListt    costMoney((sgD:\SG_ServerCode\ServerPython\ZoneServerGroup\map1_8G\MapServer\MapServerData\Script\Player\ChPlayer.pyRˆ scCsdS(Ni((R    R„((sgD:\SG_ServerCode\ServerPython\ZoneServerGroup\map1_8G\MapServer\MapServerData\Script\Player\ChPlayer.pyR€ž sc    CsŽtj|||ƒ}|gkr%tSxb|D]Z\}}|dkr,tj|||tji|d6ƒtj||dd||ƒq,q,WtS(Nit TransportType(    R RHRRJRtDef_Cost_TransportRtLogin_Interface_GoldRecR(R    RStmoneyR„t    moneyList((sgD:\SG_ServerCode\ServerPython\ZoneServerGroup\map1_8G\MapServer\MapServerData\Script\Player\ChPlayer.pyRЬ s  c    Cs*tjƒrdStjdƒ}tjƒj|ƒ}|j}|j}|jt    |ƒƒ}|svtj
d|ƒdS|d}|j ƒ}    |}
|j ƒ} |    |krÅtj
d|    |fƒdS|
| krìtj
d|
| fƒdSt j|ƒ} |jƒ} d}t    t|dƒƒ}|d}t    |dƒ}t    t|dƒƒ}t j |ƒ}t j|||ƒ}|sdSxe|D]]\}}t j|||tji|
d6|d    6|tj6ƒsˆtj
d
t |fƒdSqˆW|j|ƒt    t| |
dƒƒ}|j|ƒ|jƒdS( NtOfflineSys_ExpChangesÀëÏß¾­Ñé¶Ò»»Ë÷Òý´íÎóindex=%sis=ÀëÏß¹Ò»ú·â°ü¶Ò»»¾­ÑéÒì³££¬Íæ¼ÒvipµÈ¼¶ %s, ÏÔʾµÄvipµÈ¼¶ %s £¬s5ÀëÏß¹Ò»ú·â°ü¶Ò»»¾­ÑéÒì³££¬¶Ò»»Ê±¼ä %s, ÀÛ»ýʱ¼ä %s £¬iit
ChangeTimetIndexs3¸ßЧÁ·¹¦£¬£¬½ðÇ®²»×ã##PlayerControl=%s,,moneyCnt=%s(RRRŒRRšRšR–t ExchangeTimeRR8R®tGetVIPLvtGetOfflineMinutesR tGetPlayerReExpRÎtevalRHRJRtDef_Cost_OffLineExptDef_Cost_Reason_SonKeytAddExpR!tSetOfflineMinutestSyn_OfflineTimeQueryResult(R˜t curPackDataRtOfflineExpChangeDictR    tmulIndext exchangeTimetrecListtminVIPLvtVIPLvt
useMinutest haveMinutestrExptreLVtworldLvExpRatet    redeemExpt moneyInfoListRSRŽR÷t haveMoneyListRTt offlineTime((sgD:\SG_ServerCode\ServerPython\ZoneServerGroup\map1_8G\MapServer\MapServerData\Script\Player\ChPlayer.pytPlayerExpExchangeÁ sR         
 
!  
cCs|jtjƒ}|rDtj|tjdƒt|tjdƒn|jtjƒ}|rˆtj|tjdƒt|tjdƒn|jtj    ƒ}|rÌtj|tj    dƒt|tj
dƒn|jtj ƒ}|rtj|tj dƒt|tj dƒnt |ƒdS(Ni(RbRRcR R/RdReRfRgRlRmRnRot
ADCntOnDay(R    RsRtRw((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||ƒnd|tjkrtj|ƒnE|tjkr5tj|ƒn&|tjkrZtj|||ƒn|tjkr|tj ||ƒnß|tj!kržt"j#||ƒn½|tj$kr½t%||ƒnž|tj&krßt'j(||ƒn||tj)krt*j+|||ƒnW|tj,kr&t-j.||ƒn5|tj/krKt0j1|||ƒn|tj2krjt3j4|ƒnñ|tj5krt6j7|||ƒnÌ|tj8kr´t9j:|||ƒn§|tj;krÙt<j=|||ƒn‚|tj>krþt?j@|||ƒn]|tjAkr#tBjC|||ƒn8|tjDkrHtEjF|||ƒn|tjGkrmtHjI|||ƒnî|tjJkr’tKjL|||ƒnÉ|tjMkr·tNjO|||ƒn¤|tjPkrÜtQjR|||ƒn|tjSkrtTjU|||ƒnZ|tjVkr#t<jW||ƒn8|tjXkr?tY|ƒn|tjZkrat[j\||ƒnú|tj]krƒt^j_||ƒnØ|tj`kr¥t<ja||ƒn¶|tjbkrÇtcjd||ƒn”|tjekrìtfjg|||ƒno|tjhkr#ti||tjjtkjlddƒdƒn8|tjmkrZti||tjntkjlddƒdƒn|tjokr‘ti||tjptkjlddƒdƒnÊ|tjqkrÈti||tjrtkjldd    ƒd
ƒn“|tjskr<tjtƒjutvjwƒd}tkjxd dƒ}    ||    kr[ti||tjytkjld d ƒd ƒq[n|tjzkr[t{||ƒndS( Ns5PlayerGetReward: rewardType=%s,dataEx=%s,dataExStr=%stGameNoticeRewardit
GameNoticetShareGameRewardt    ShareGametGoodGameRewardtGoodGameitLikeGametOpenServerDailyAwardi(|RRšRšt
RewardTypetDataExt    DataExStrR§RtDef_RewardType_ActivityRŠtGetActivityAwardtDef_RewardType_DailyTasktGetDailyTaskAwardtDef_RewardType_SuccessRLtGetSuccessAwardtDef_RewardType_TreeFreeTimeR„tFreeReduceTreeLVTimetDef_RewardType_ADAwardt OnGetADAwardtDef_RewardType_LLMJLVUpR‹t
OnLLMJLVUptDef_RewardType_FamilyTaofaBoxtPlayerFamilyTaofatGetTaofaBoxAwardtDef_RewardType_LineupRecommendR~tGetLineupRecommendAwardtDef_RewardType_OpenFuncRAtGetFuncOpenAwardtDef_RewardType_BeautyLVAwardRŒtGetBeautyLVAwardtDef_RewardType_DownLoadtGetDownloadAwardt'Def_RewardType_OSACelebrationPointAwardRtGetOSACelebrationPointAwardtDef_RewardType_LunhuidianAwardR‘tGetLunhuidianAwardt)Def_RewardType_ActHeroAppearStarFreeAwardR’tGetHeroAppearStarFreeAwardtDef_RewardType_ActSignAwardt PlayerActSigntOnGetActSignAwardt!Def_RewardType_QunyingRankHighestR¼tGetQunyingRankHighestAwardtDef_RewardType_TotalRechargeR“tOnGetTotalRechargeAwardt"Def_RewardType_TotDayRechargeAwardR”tOnGetTotDayRechargeAwardtDef_RewardType_FirstChargeR@tGetPlayerFirstChargetDef_RewardType_ManyDayRechargeRZtOnGetManyDayRechargeAwardtDef_RewardType_SingleRechargeR[tOnGetSingleRechargeAwardtDef_RewardType_ActBuyCountGiftRWtOnGetBuyCountGiftAwardtDef_RewardType_ActTaskRXtOnGetActTaskAwardtDef_RewardType_BuyOneRPtGetBuyOneFreeAwardtDef_RewardType_FamilyCTGAssistRQtGetFamilyCTGAssistAwardtDef_RewardType_FamilyGCZR†tGetFamilyGCZAwardtDef_RewardType_TreasureCntAwardRGtGetTreasureCntAwardt!Def_RewardType_HistoryChargeAwardtOnGetHistoryRechargeAwardtDef_RewardType_CreateRoletOnGetCreateRoleAwardtDef_RewardType_CustomAwardRatOnGetCustomAwardtDef_RewardType_RealmLVUpTaskR:tGetRealmLVUpTaskAwardtDef_RewardType_DailyPackBuyGifttGetDailyPackBuyGifttDef_RewardType_TaskRƒt GetTaskAwardtDef_RewardType_ZhanlingR‚tGetZhanlingRewardRetOnGiveAwardByClientRcRRRgRfRiRhRkRjRmRìRRÓtDef_Notify_WorldKey_ServerDayR RlRotOnGetRechargeDayAward(
R˜R
RRçR    t
rewardTypeRÀt    dataExStrt openServerDaytopenServerDayLimit((sgD:\SG_ServerCode\ServerPython\ZoneServerGroup\map1_8G\MapServer\MapServerData\Script\Player\ChPlayer.pytPlayerGetReward. s´              (((( +c
Cs°tjd|ƒ}|sdS|jƒ}|jtj|ƒ}|rn||krntjd|||fƒdS|d7}tj    |tj||ƒ|j
ƒ}|j ƒ}|j ƒ}tjd|||||fƒt ||gƒ|rtj||ddtigƒn|dkr-tj|tƒno|dkrR|}tj||ƒnJ|dkr}|}    tj||    tjƒn|dkrœtj||ƒntj||ƒdS(    NtADAwards-½ñÈÕ¸Ã¹ã¸æ½±ÀøÒÑ´ïÉÏÏÞ! adID=%s,adCnt=%s > %sisNÁìÈ¡¹ã¸æ½±Àø! adID=%s,adCnt=%s,adAwardType=%s,adAwardValue=%s,awardItemList=%steventiii(RRt GetADCntMaxRbRtDef_PDict_ADCntRR§R R/tGetADAwardItemListtGetADAwardTypetGetADAwardValueRˆR7tGivePlayerItemOrMailRR„tGetTreeEnergyAwardRIt
AddFBADCntRGt
DoTreasuretCostType_ADFreeRtAddTravelEnergyR)t
DR_ADAward(
R    tadIDtipyDatatadCntMaxtadCntt awardItemListt adAwardTypet adAwardValuetadMapIDt treasureType((sgD:\SG_ServerCode\ServerPython\ZoneServerGroup\map1_8G\MapServer\MapServerData\Script\Player\ChPlayer.pyRÈ· s: 
    "    cCs§g}tjƒ}xxt|jƒƒD]d}|j|ƒ}|jƒ}|jtj|ƒsbq%nt    j
|tj|dƒ|j |ƒq%W|r£t ||ƒndS(Ni( RRRâtGetADAwardCounttGetADAwardByIndextGetADIDRbRRR R/R»Rˆ(R    t syncADIDListRR˜RR((sgD:\SG_ServerCode\ServerPython\ZoneServerGroup\map1_8G\MapServer\MapServerData\Script\Player\ChPlayer.pyR²Ý s  c
Cs    |sItjƒ}gt|jƒƒD]}|j|ƒjƒ^q%}n|}g}xh|D]`}|jtj|ƒ}| r‘|dkr‘q\nt
j ƒ}||_ ||_ |j|ƒq\W|sÊdSt
jƒ}    |d |    _t|    jƒ|    _tj||    ƒdS(Niÿ(RRRâR$R%R&RbRRRºRðt tagSCADInfotADIDtADCntR»ttagSCADInfoListt
ADInfoListRRVRõRö(
R    R'RRètadIDListt
adInfoListRRtadInfoRk((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(RbRtDef_PDict_CTGRealTotalRnRRRR8RR§RRµt GiveAwardItemR R/Rd(
R    Rt    realTotaltawardCoinRecordt    awardCoinRt 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( RbRtDef_PDict_CreateRoleAwardStateRR§RµR2RRR R/R`(R    ((sgD:\SG_ServerCode\ServerPython\ZoneServerGroup\map1_8G\MapServer\MapServerData\Script\Player\ChPlayer.pyRú s 
cCs?tjƒ}|jƒ|jtjƒ|_tj||ƒdS(N(    RðttagMCCreateRoleAwardStateRòRbRR:tGetStateRõRö(R    RW((sgD:\SG_ServerCode\ServerPython\ZoneServerGroup\map1_8G\MapServer\MapServerData\Script\Player\ChPlayer.pyR`' s
 
cCsû|jƒ}tjddƒ}|jtjƒ}||krZtjd||f|ƒdStjddƒ}|svdSt    j
|tj|ƒtjd||f|ƒ|dkrÎt j d|j ƒ|ƒntj||ddtigƒt|ƒdS(    Nt
DownRewardis7ÒÑÁìÈ¡·Ö°ü½±Àø! curAwardNum(%s) == downloadAwardNum(%s)is4ÁìÈ¡·Ö°üÏÂÔØ½±Àø: curAwardNum=%s,downloadAwardNum=%stSubpackageDownloadRt PackDownload(RRR RbRtDef_PDict_DownloadAwardStateRR§RR R/RRRœR7RRR\(R    RÀR±tdownloadAwardNumt curAwardNumR((sgD:\SG_ServerCode\ServerPython\ZoneServerGroup\map1_8G\MapServer\MapServerData\Script\Player\ChPlayer.pyRÕ. s    
cCsWtjddƒ}tjƒ}|jƒ|jtjƒ|k|_t    j
||ƒdS(NR=i( RR RðttagMCPackDownloadRecordRòRbRR@tRecordRõRö(R    RARW((sgD:\SG_ServerCode\ServerPython\ZoneServerGroup\map1_8G\MapServer\MapServerData\Script\Player\ChPlayer.pyR\D s  
cCsj|j|ƒr*tjd||fƒdStj|||ƒsCdStj||dƒt||dƒdS(Ns)ÒÑÁìÈ¡¹ý¸Ã½±Àø! rewardType=%s, dictKey=%si(RbRR§RµR2R R/Rd(R    RtdictKeytawardCfgt    eventName((sgD:\SG_ServerCode\ServerPython\ZoneServerGroup\map1_8G\MapServer\MapServerData\Script\Player\ChPlayer.pyRM scCs<tjƒ}|jƒ||_||_tj||ƒdS(N(RðttagMCPlayerRewardGetRecordRòR¼tRewardGetRecordRõRö(R    RtrewardGetRecordRW((sgD:\SG_ServerCode\ServerPython\ZoneServerGroup\map1_8G\MapServer\MapServerData\Script\Player\ChPlayer.pyRd] s  
        cCsŒtjƒj|ƒ}t|jƒ}tjdƒ\}}}|jddg|ƒ}d}    x:t|ƒD],\}
} t    j
|t j |    |
f| ƒqhW|jddg|ƒ} d}    x:t| ƒD],\}
} t    j
|t j |    |
f| ƒqÄW|jddg|ƒ} d}    x:t| ƒD],\}
} t    j
|t j |    |
f| ƒq Wd}    |j|    dƒ} t    j
|t j |    df| ƒdS(NtAutoFightSettingt
BasicSkillit    AreaSkillRŽtHPPackagePercent( RRšRšR›tDataRŒRRRR R/RtDef_PDict_AutoFightSetting(R˜R
RR    t settingDicttBasicSkillCounttAreaSkillCounttBuffSkillCounttBasicSkillListtKeyt
ValueIndextValuet AreaSkillListt BuffSkillList((sgD:\SG_ServerCode\ServerPython\ZoneServerGroup\map1_8G\MapServer\MapServerData\Script\Player\ChPlayer.pytOnSaveAutoFightSettingh 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(NRKRLiRMRŽRNs%s(RŒRRâRbRRPR»RðttagMCAutoFightSettingRòRORtSizeRõRö( R    RRRSRTRQRVRURWRXRYRZRW((sgD:\SG_ServerCode\ServerPython\ZoneServerGroup\map1_8G\MapServer\MapServerData\Script\Player\ChPlayer.pytSync_AutoFightSetting† s:
 
 
 
 
 cCs#tjƒj|ƒ}|sdSdS(N(RRšRš(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(RRšRšt IsNoTimeLimitRt TYPE_Player_Tick_QueryMapNPCInfoR<R>R§R?RrRst    NPCIDListR›t BaseExceptionR®t
isinstancetlistR™RtR"Rþt
GetNPCInfoRvt GetMapCopyPlayerManagerByFbIndextGetPlayerCountt SyncNPCInfotGameServer_QueryPlayerByIDtqueryType_NPCInfoR(R˜R
RR    ttickTypettagMapIDt    tagLineIDt queryNPCStrt    npcIDListR‘t npcInfoDictt    gameWorldRçt    playerCnttsendMsg((sgD:\SG_ServerCode\ServerPython\ZoneServerGroup\map1_8G\MapServer\MapServerData\Script\Player\ChPlayer.pytOnQueryMapNPCInfo¸ sN                                c Cs©tjƒj|ƒ}|sdS|jsTtj|tj|ƒsTtjdƒdSn|j}|j    }|j
}g}|räyt |j
ƒ}Wn&t k
r¶tj d|j
ƒdSXt|tƒsätj dt|ƒƒdSntjd||t|ƒfƒtjƒjƒ}||krjtj||ƒ}    tjd||t|    ƒfƒtj|||    ƒn;dt|||gƒ}
|jtjdd|
t|
ƒƒdS(    Ns#OnQueryMapNPCCntInfo ²éѯ¹ýÓÚÆµ·±£¡s"OnQueryMapNPCCntInfo, npcIDList=%ss0OnQueryMapNPCCntInfo, npcIDList=%s is not list£¡s:OnQueryMapNPCCntInfo tagMapID=%s,tagLineID=%s,npcIDList=%ss5    Í¬µØÍ¼²éѯcurMapID=%s,tagLineID=%s,npcInfoDict=%ss%sitNPCCnt(RRšRšRatCheckPlayerTickRRbR§RrRsRcR›RdR®ReRfR™RtR"Rþt GetNPCCntInfotSyncNPCCntInfoRktqueryType_NPCCntR( R˜R
RR    RnRoRpRqR‘RrRu((sgD:\SG_ServerCode\ServerPython\ZoneServerGroup\map1_8G\MapServer\MapServerData\Script\Player\ChPlayer.pytOnQueryMapNPCCntInfoø s@                           cCs#tjƒj|ƒ}|jƒdS(N(RRšRšR\(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|_tjtjƒjƒƒ|_|r·tj||ƒn tj|ƒdS(N(RtGetCurrentTimeRðttagServerDateTimeRòtyeartYeartmonthtMonthtdaytDaythourtHourtminutetMinutetsecondtSecondt microsecondt    MicSecondtChangeTimeNumToStrtCrossMgrtGetSSServerMgrt GetCrossTimetCrossServerTimeRõRötSendFackPackOnline(R    t
serverTimetserverDateTime((sgD:\SG_ServerCode\ServerPython\ZoneServerGroup\map1_8G\MapServer\MapServerData\Script\Player\ChPlayer.pyR1s"  
        cCs tjƒ}|sdStjƒ}tjƒjtjƒ|_    tjƒjtj
ƒ|_ tjƒjtj ƒ|_ tjƒjtjƒ|_|j|_|j|_|j|_|j|_|j|_|j|_|j|_tjƒ|_tjƒjtj ƒ|_!t"j#||ƒdS(N($RR~RðttagMCOpenServerDayR¸tGetEventTrigMgrRòRÓt Def_ServerDayR…tDef_IsMixServert IsMixServertDef_MixServerDaytMixDaytDef_OpenServerWeekdayt OpenWeekdayR€tNowYearR‚tNowMonthR„tNowDayR†tNowHourRˆt    NowMinuteRŠt    NowSecondRŒt NowMicSecondt GetWeekOfYeart
WeekOfYeartDef_InitOpenServerTimetOpenServerTimeRõRö(R    R”Rk((sgD:\SG_ServerCode\ServerPython\ZoneServerGroup\map1_8G\MapServer\MapServerData\Script\Player\ChPlayer.pyRLs&         cCsätjƒj|ƒ}t|||ƒsà|jƒ|jƒ}}tjƒj||ƒtkrÍt    j
||dƒ}|jƒ|kr²|jƒ|kr²tj d||fƒdS|jƒ}|jƒ}n|j ||ƒndS(NisÍæ¼Ò×ø±ê¿¨ËÀ %s %s( RRšRštPYPlayerNormalMoveRÎRÏRtRáRRÙtGetEmptyPlaceInAreaR®RÜ(R˜RkRR    RñRòt    resultPos((sgD:\SG_ServerCode\ServerPython\ZoneServerGroup\map1_8G\MapServer\MapServerData\Script\Player\ChPlayer.pyt PYPlayerMovess$ tPYMoveDistCalcTickt PYMoveDistSumc Csvt|ƒstS|j}|j}|j}|j}|j}|j}|j}    |j    ƒ}
|    dkr’||
dkr’t
j d||
fƒtSt
j ƒj ||ƒs»t
j dƒtS|jƒ|krL|jƒ|krL|jt|ƒ|jtdƒ|    dkr||
dkrtS|j|ƒt|||||||    ƒtSt
j ƒjƒtjkr†tj||||ƒs†tSn|jƒ} | tjtjgkr®tStj||||ƒsÔ|j ƒtSt
j!|jƒ|jƒ||ƒ} | dkr:t
j d|jƒ|jƒ||f|j"ƒƒtS|j#tƒ} t$|j#tƒ| dƒ}|jt|ƒ|t%j&d    d
ƒkr&|j'ƒ}|| }||}|t%j&d    d ƒd }||krt
j d | |||||f|j"ƒƒtS|jt|ƒ|jtdƒntj(|tj)ƒ|j*||ƒt|||||||    ƒ|j|ƒtS(Nii2smove ·¢°üÌ«¿ì ÊÕ°ü%s - ÉÏÒ»´Î%ss
ÒÆ¶¯Õϰ­µãiÞis)ÒÆ¶¯¾àÀë¹ý´ó£¬ Íæ¼Ò×ø±ê %s-%s  ÊÕ°ü %s-%siáõt PyMoveCheckiigY@sU    dist=%s,distSum=%s,speed=%s,needTick=%s, ËùÐèÒÆ¶¯Ê±¼äÒì³£ passCalcTick(%s) < (%s)(+R2RtDirt
ClientPosXt
ClientPosYt    SeverPosXt    SeverPosYRKR9tGetClientMoveTickRR§RtRáRRÎRÏRtMoveDistCalcTickt MoveDistSumtSetClientMoveTicktPyNotifyPlayerMoveRuRvRwR t DoFBCanMoveRLRMRNR R[R\RPRœR—tminRR tGetSpeedR]R^R6(R    RkRtmoveDirt
clientPosXt
clientPosYtsendPack_SeverPosXtsendPack_SeverPosYRVtmoveTypet lastMoveTickRWtdisttcalcTicktdistSumtspeedt passCalcTicktneedTickt checkNeedTick((sgD:\SG_ServerCode\ServerPython\ZoneServerGroup\map1_8G\MapServer\MapServerData\Script\Player\ChPlayer.pyRª‹sr                               $  
$  
 
     # cCstjƒ}|jƒ|jƒ|_tj|_||_||_    ||_
||_ ||_ |j ƒ|_||_tj||tdƒdS(Ni(RðttagMCPYPlayerMoveRòRœRiRvt    gotPlayerRhR±R²R³R´RµR½tSpeedR9R R:R(R    R¾R¿RÀRñRòRÃRW((sgD:\SG_ServerCode\ServerPython\ZoneServerGroup\map1_8G\MapServer\MapServerData\Script\Player\ChPlayer.pyRºùs 
                         cCsEtjƒ}|jƒ||_||_||_tj||ƒdS(s»Í¨ÖªÇ°¶ËÏòij¸öµãÒÆ¶¯
                ÕâÀïǰ¶Ë¿ÉÄÜÐèÒªÕë¶Ôij´ÎÒÆ¶¯×ö¶îÍâ´¦Àí£¬±ÈÈçÒÆ¶¯µ½Ä³¸öµãºóÐèÒª×Ô¶¯Õ½¶·µÈ
                ËùÒÔÕâÀïÖ»×ö֪ͨǰ¶Ë¿ÉÒÔÏòij¸öµãÒÆ¶¯£¬×îÖÕÒÆ¶¯ÓÉǰ¶Ë·¢Æð
    N(RðttagMCNotifyPlayerMoveRòR3R4tNPCIDRõRö(R    RñRòtnpcIDRW((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( RRšRštLostHPtLostHPExRÓtDef_PerPointValueRüRÐR tSetDeadRý(R˜R
RR    tlostHPtcurHPtupdHPR÷((sgD:\SG_ServerCode\ServerPython\ZoneServerGroup\map1_8G\MapServer\MapServerData\Script\Player\ChPlayer.pyt OnRoleLostHPs
  cCsdS(N((R˜R
R((sgD:\SG_ServerCode\ServerPython\ZoneServerGroup\map1_8G\MapServer\MapServerData\Script\Player\ChPlayer.pytOnSelectRealmDifficulty4scCstjƒj|ƒ}|j}|j}|tjkr:dS|tjkrX|jƒ}nt    j
ƒj ||ƒ}t ||j ƒ||ƒdS(N(RRšRštRecTypetRecIDRÓtDef_GameRecTypeListtDef_ViewGameRecSelfListRR¸R´RµtSyncGameRecInfot GetDataList(R˜R
RR    trecTypetrecIDt recTypeIDMgr((sgD:\SG_ServerCode\ServerPython\ZoneServerGroup\map1_8G\MapServer\MapServerData\Script\Player\ChPlayer.pyt OnViewGameRecAs        cCs\g}xü|D]ô}|sq n|s@|jƒ}|jƒ}ntjƒ}|jƒ|_|jƒ|_|jƒ|_    |j
ƒ|_ |j ƒ|_ |jƒ|_|jƒ|_|jƒ|_|jƒ|_|jƒ|_t|jƒ|_|j|ƒq Wtjƒ}|jƒ||_||_||_t|jƒ|_ t!j"||ƒdS(N(#t
GetRecTypetGetRecIDRðt tagSCGameRectGetTimetTimet    GetValue1tValue1t    GetValue2tValue2t    GetValue3tValue3t    GetValue4tValue4t    GetValue5tValue5t    GetValue6tValue6t    GetValue7tValue7t    GetValue8tValue8t GetUserDatatUserDataRt UserDataLenR»ttagSCGameRecInfoRòRÜRÝtRecListRVRõRö(R    t recDataListRâRãR¥RÀtrecRk((sgD:\SG_ServerCode\ServerPython\ZoneServerGroup\map1_8G\MapServer\MapServerData\Script\Player\ChPlayer.pyRàMs8    
            (àRRvRR RÙRRŽRRERþRxR RSRµR7RURÔRŒRCRÓRõRðR)R<R@RCR:R}RKRŠRIRLRARÌRGRR+RPRRR“R”RYRQRZR[RR¼ReR¾RˆR?R_RRaR‚R„R‹RƒRüR…RÝRWR‘R’R†RXRR¸RÏR‰RŸRÊRt    PyMongoDBRR|RzR‡R~RRRŒRRŽR5R€R¨RRÑRR«tdatetimeR9tmathtreRšRR
R R$RR R•RÃRÆRÙRÔRÚRÄRR–RëR>R4R:R=RHR[RdR\R(RsR‡R™R—R£R¢R'RºR¸RœRìRûRÌRR-RR;RARXR2ReRORyRuRR‡R“R•R”R˜R–R±RÃRRÔR^RäR6RìRðRöRúRRRR    RR R RRRRR7R=RºR}RR…RŽRàRxRkRmRlRyRuRƒR~RR€RŠR±R³R RÈR²RˆRRúR`RÕR\RRdR[R^R_RvR|R}RRR­R·R¸RªRºRÒRÚRÛRåRà(((sgD:\SG_ServerCode\ServerPython\ZoneServerGroup\map1_8G\MapServer\MapServerData\Script\Player\ChPlayer.pyt<module>s¸                                                                                                               &         ª    ;    2             1            
    &            4    A         ,        
        <            
         
    ?    >    
        Ž                 %    2 !    $    :    K    +    $ 6                        
              0         -        "        
                     "                                      
    !    )    "    #     +    ?                             A                    J    #    ‰    &                                            (    
    @    /    
    '        n