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
Ð
Ž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 d „Zhd „Zid„Zjd„Zkeld d„Zmd„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†gd*„Z‡d+„Zˆd,„Z‰d-„ZŠd.„Z‹d/„ZŒeld0„Zd1„ZŽd2„Zd3„Zd4„Z‘d5„Z’d6„Z“d7„Z”d8„Z•d9„Z–d:„Z—d;„Z˜d<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ªdO„Z«dP„Z¬dQ„Z­dR„Z®deldS„Z°dT„Z±d eldU„Z²dV„Z³d eldW„Z´dX„ZµdY„Z¶dZ„Z·d[„Z¸d\„Z¹dd d]„Zºdd<eld d^„Z»d_„Z¼d`„Z½da„Z¾db„Z¿dc„ZÀdd„ZÁde„ZÂdf„ZÃdg„ZÄddh„ZÅdi„ZÆdj„ZÇdk„ZÈdl„ZÉdm„ZÊd<dn„ZËdo„ZÌdp„ZÍdq„ZÎdr„ZÏds„ZÐdt„ZÑdu„ZÒddv„ZÓdw„ZÔdx„ZÕdyZÖdzZ×d{„ZØd|„ZÙd d}„ZÚd~„ZÛd„ZÜd€„ZÝd„ZÞdS(‚iÿÿÿÿN(tRecvPackToMapDBcCsdS(N((ttick((sgD:\SG_ServerCode\ServerPython\ZoneServerGroup\map1_8G\MapServer\MapServerData\Script\Player\ChPlayer.pyt
InitPlayeruscCs6tj|ƒ|jƒdkr2|jtjƒndS(Ni(t PlayerOnlinet OnPlayerLogintGetTickTypeCounttSetTickTypeCounttChConfigtTYPE_Player_Tick_Count(t    curPlayerR((sgD:\SG_ServerCode\ServerPython\ZoneServerGroup\map1_8G\MapServer\MapServerData\Script\Player\ChPlayer.pytInitLoginPlayer~s cCstj||ƒrdSdS(N(tFBLogictPlayerLoginInFBCheck(R    R((sgD:\SG_ServerCode\ServerPython\ZoneServerGroup\map1_8G\MapServer\MapServerData\Script\Player\ChPlayer.pytOnAllServerInitOKŠscCsÊ|jtjdƒtjƒj|jƒƒt|ƒt|ƒ|j    ƒt
|ƒt j ƒrp|j tƒntj|ƒt||ƒt j ƒr¼|j tƒtj||jƒƒn|jƒdS(Ni(tSetDictRtDef_PlayerKey_LoadMapIsLogint CrossPlayertGetCrossPlayerMgrt RegistPlayert GetPlayerIDtSync_PyServerDataTimeToClienttSync_OpenServerDaytSync_ClientPlayerLogintSyncSettingDatat    GameWorldt IsCrossServertSetForbiddenSyncClientStatetTruetPlayerEventCountertUpdatePlayerLoginTimet__DoPlayerLoginServertFalset PlayerControlt SetCrossMapIDtGetMapIDtBalanceServer_PlayerLoginInitOK(R    R((sgD:\SG_ServerCode\ServerPython\ZoneServerGroup\map1_8G\MapServer\MapServerData\Script\Player\ChPlayer.pyt DoPlayerLogin°s
 
 
 
 
cCs,|jtjƒƒt|ƒtjƒrTt||ƒtj|ƒtj    |ƒdSt
j |ƒ}|t j dkrÝt
j|t jdƒt
j|t jdƒt
j|t jdƒt
j|ƒrÝt
j|dƒqÝnt|ƒtj|ƒt|ƒtj|ƒt||ƒt
j|ƒt
j|ƒtj|ƒtj    |ƒtj|ƒt|ƒt j|ƒt!j|ƒt"j#|ƒt$j%|ƒt&j'|ƒt(j)|ƒt*j+|ƒt,j|ƒt-j.|ƒt/j|ƒt
j0|ƒt
j1|ƒt2j|ƒt3j|ƒt4j|ƒt5j|ƒt6j7|ƒt8j9|ƒt:j|ƒt;j|ƒt<j|ƒt=j|ƒt>j|ƒt?j|ƒt@|ƒt"jA|ƒtB|ƒtCj|ƒtD|ƒtEj|ƒ|jFt jGƒ}|rtH|t jI|ƒn|jFt jJƒ}|r<tH|t jK|ƒn|jFt jLƒ}|rjtH|t jM|ƒn|jFt jNƒ}|r˜tH|t jO|ƒn|jFt jPƒ}|rÆtH|t jQ|ƒn|jFt jRƒ}|rôtH|t jS|ƒn|jTdƒ|jUdƒt
j|ƒtj|ƒdS(s2 Íæ¼ÒµÇ¼ÐèÒª´¦ÀíµÄÄÚÈÝ£¬±¾·þ¼°¿ç·þ·þÎñÆ÷·Ö¿ª
    Nièi(Vt 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 SuccOnLogint PlayerArenatNotifyPlayerAllCurrencytNotifyUseMoneyTotaltPlayerActTotalRechargetPlayerActBuyOnetPlayerActFamilyCTGAssisttPlayerActCollectWordstChItemtSync_ItemDayUseCnttFunctionNPCCommontShopItemOnLogintPlayerActBuyCountGiftt PlayerActTasktPlayerActLoginNewtPlayerActLianqitPlayerActManyDayRechargetPlayerActSingleRechargetSyncPackDownloadAwardtDoFuncOpenLogictSyncLittleHelpertPlayerFBtSync_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%nUtjƒ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|ƒ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 PlayerPresetRtPlayerActLunhuidiant__OnFixVersiontSyncOnlineStateToCrosst GetDictByKeyRt!Def_PlayerKey_MixServerFirstLogintstrtGetPlayerManagertGameServer_QueryPlayerResulttGetIDtlen(R    RtisMixServerFirstLogintmsg((sgD:\SG_ServerCode\ServerPython\ZoneServerGroup\map1_8G\MapServer\MapServerData\Script\Player\ChPlayer.pytDoPlayerRealLoginOK„sB            
 
 .cCsV|jƒ}d}|jtjƒ}|s…|jƒ}|jdƒd}tjd|jddƒƒ}tj    d||f|ƒn||kr©tj    d||ƒd    Stj
d
||f|ƒd }||krþt j ||ƒt j|tj|ƒnd}||kr<tjƒr<tj
d ƒtj|ƒq<nt j|tj|ƒd    S( sº ÐÞÕýÏßÉÏÍæ¼ÒÊý¾ÝÄÚÈÝ
    Ã¿´ÎÓÐÐèÒªÐÞÕýʱ£¬Ö»Òª¶¨ÒåÒ»¸öеÄϵͳÄÚÈݰ汾ºÅ  sysFixVersion , È»ºóÍæ¼Ò¸ù¾Ý×ÔÉí°æ±¾ºÅ½øÐÐÖð²½ÐÞÕý¼´¿É
    ÕâÑùÖ»Óõ½Ò»¸ökey¼´¿É£¬²»ÐèҪÿ´Î¶¼¶¨ÒåеÄkey
    i´¡Âxs is%s00s-tsĬÈÏÊý¾Ý°æ±¾Îª´´½ÇÈÕÆÚ: %s, %ss0Íæ¼Òµ±Ç°Êý¾Ý°æ±¾ºÅÒÑÊÇ×îа汾! playerVersion=%sNsDÍæ¼Òµ±Ç°Êý¾Ý°æ±¾ºÅ²»µÈÓÚϵͳ°æ±¾ºÅ£¬¿ªÊ¼ÐÞÕý! playerVersion=%s != %siÄì´xs¿ç·þ¹«»áÍæ¼ÒµÇ¼²¹¹ýÌì(RReRtDef_Player_Dict_FixVersiontGetCreateRoleTimetsplitRtToIntDeftreplacetDebugLogR|tChEquiptFixRoleEquipHPR R/tDBFamilyt IsFamilyCrossR€t__doPlayerOnDay(R    tplayerIDt sysFixVersiont playerVersiontcreateRoleTimetymdt
fixVersion((sgD:\SG_ServerCode\ServerPython\ZoneServerGroup\map1_8G\MapServer\MapServerData\Script\Player\ChPlayer.pyR•¼s.       cCsli}g}tjƒrbtjƒjƒ}|dkrb||d<||kr_|j|ƒq_qbn||fS(NitcrossFamilyServerID(RªR«t    DBDataMgrt GetFamilyMgrtGetCurCrossServerIDtappend(tdataExt serverIDListR³((sgD:\SG_ServerCode\ServerPython\ZoneServerGroup\map1_8G\MapServer\MapServerData\Script\Player\ChPlayer.pytGetSyncCrossServerIDAndFuncInfoæs  
 ic CsM|jƒ}tjƒ}|j|ƒ}|s1dStj|ƒ|tjkr]tj    |ƒnd}|tj
kr{d    }nt j ƒj ƒ}|jdƒ}|r¶|||kr¶dS|jd|ƒ|tjkrî|jƒdkrîdSntƒd}|sdS|jƒ}tj||ƒ}    i|    d6}
tjtj|
||ƒdS(
sˆÍæ¼Ò»ù´¡ÐÅÏ¢±ä¸üͬ²½¸üÐÂÆäËû¹¦ÄÜ£¬¿ÉÒÔÊÓΪͬ²½µ½ÒÔǰµÄGameServer
    ³ýÁËÏà¹Ø»ù´¡Öµ±ä»¯Í¬²½Í⣬ÉÏÏÂÏß״̬±ä¸üÒ²»á¸½´ø»ù´¡ÐÅÏ¢µÄͬ²½
    NiÐi<iètS2C_PlayerBaseInfoiitbaseInfoi`ê(RRRtFindCrossPlayerR€tRefreshFamilyMembertIPY_PlayerDefinetCDBPlayerRefresh_PlayerNameR<tUpdatePlayerBillboardNametCDBPlayerRefresh_FightPowerRt GetGameWorldtGetTickR—RtCDBPlayerRefresh_LVtGetLVRºtPlayerViewCachetGetPlayerBaseViewInfotCrossMsgtSendToCrossServert ShareDefineR»( R    t refreshTypeR­tcrossPlayerMgrt crossPlayertsyncCDRt lastSyncTickR¹R¼tdataMsg((sgD:\SG_ServerCode\ServerPython\ZoneServerGroup\map1_8G\MapServer\MapServerData\Script\Player\ChPlayer.pytOnPlayerBaseInfoChange÷s6          cCs't}|d}t||||ƒdS(NR¼(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Ó.s   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.pytSyncOnlinePlayerToCrossDs c
CsÀ|jƒ}tjƒ}|s.|j|ƒntƒ\}}|sGdS|ri||kr]dS|g}ntj||ƒ}i|d6|d6|d6}    |    j|ƒtj    t
j |    ||ƒdS(NRÕt
isLoginoutR¼( RRRRÙRºRÇRÈtupdateRÉRÊRËtS2C_OnlineState(
R    RÕRãRßR­RÍR¹R¸R¼RÑ((sgD:\SG_ServerCode\ServerPython\ZoneServerGroup\map1_8G\MapServer\MapServerData\Script\Player\ChPlayer.pyR–Ns      cCsŠ|d}|d}t||||ƒ}tjƒjƒ}d|kr†|d}||kr†|rstj|ƒqƒtj|ƒq†ndS(sbÊÕµ½ÓÎÏ··þÍæ¼ÒÔÚÏß״̬ͬ²½
    ¿ç·þÊÕµ½ÔÚÏß״̬ͬ²½Ê±¶¼ÊÓΪÔÚ¿ç·þÉÏÏߣ¬ÐèÒª´¦Àí¿ç·þÔÚÏß/ÉÏÏßµÄÂß¼­
    ²»È»ÔÚ¿ç·þά»¤ÓÎÏ··þ²»Î¬»¤µÄÇé¿öÏ£¬µÈ¿ç·þÖØ¿ªºó£¬ÓÎÏ··þÖØÐÂͬ²½ÔÚÏßÍæ¼Ò£¬´ËʱÈç¹û¿ç·þ²»´¦ÀíµÇ¼Âß¼­£¬»áÉÙͬ²½·â°ü
    È繫»á£¬¿ç·þά»¤Ö®ºóµÇ¼µÄÍæ¼Ò»áÈ¡²»µ½¹«»áÊý¾Ý£¬µÈ¿ç·þÖØ¿ªºó£¬ÐèÊÓΪµÇÂ¼ÖØÐÂͬ²½
    Óë¿ç·þÖØÁ¬Ò»ÑùµÄµÀÀí£¬¶¼ÊÇÖØÐÂͬ²½ËùÓÐÐÅÏ¢
    RÕR¼R³N(RÓRRÃt GetServerIDR€tOnCrossPlayerLoginRØ(RÑRÔR­RÕR¼RÎt curServerIDR³((sgD:\SG_ServerCode\ServerPython\ZoneServerGroup\map1_8G\MapServer\MapServerData\Script\Player\ChPlayer.pyRåjs
 
 
 
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ƒ}x0|D](\}}tj||jƒg|ƒqÂWtj|ƒtj|ƒtj|tjdƒdS(NsÍæ¼ÒÊǵÚÒ»´Î½øÈëÓÎÏ·iit MailLVAwardi(RœReRtDef_Player_Dict_FirstLoginRR|R+tWriteEvent_Entryt SetFightPointtGameObjtSetHPtGetMaxHPRÆRAR`R)t DR_FirstLogintGetAccIDtGetIPt IpyGameDataPYtGetFuncEvalCfgR t SendMailByKeyRRtOnPlayerFirstLoginRˆtInitGoldEnergyR/(R    R­tmailListt 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|ƒtj|dƒtjddƒ}tjddƒ}tjddƒ}tjdd    ƒ}    td
||    ƒ}
|\} } g} x¥|D]\}}}tjƒj|ƒ}|s¾qŽn|jd ƒ}|jƒ}|tjkrîqŽn|jdƒ}|s    qŽn||
kr*|||gg} qŽPqŽWi|d 6|d 6|
d6}|| }tj d|
|f|ƒt j d|g|d| d| d|ƒt!j"|dt#ƒdS(Ns'±¾´ÎºÏ·þÒѾ­µÇ¼¹ý. lastMixServerDay=%ss9Íæ¼ÒºÏ·þÊ׵Ǵ¦Àí! lastMixServerDay=%s,mixServerWorldLV=%sis    ÐºŲ»¸øºÏ·þ½±Àø!t    MixServert MixServerMailiiii–itMixServerWorldLVtLastMixServerDayt ItemWorldLVs3    ·¢ËͺϷþ²¹³¥Óʼþ: itemWorldLV=%s,addItemList=%st
MixServer1tgoldtsilvertdetailtisAll($RRÃtGetGameWorldDictByKeyRËtDef_Notify_WorldKey_IsMixServerRt$Def_Notify_WorldKey_LastMixServerDayReRtDef_PDict_MixLoginDayR§t(Def_Notify_WorldKey_LastMixServerWorldLVR|R R/RÆRR˜RCt ResetDaySignR?tDoResetCTGCountRûRüt
GetFuncCfgtmaxt GetGameDatatGetItemByTypeIDtGetEffectByIndext GetEffectIDtDef_Effect_ItemAddLVtGetEffectValueRýR<t"UpdatePlayerBillboardOnLeaveServerR(R    t isMixServerR­tlastMixServerDayt    playerDaytmixServerWorldLVRtworldLVMailItemListt mailMoneyListt worldLVDownt itemWorldLVR    R
tworldLVItemListtitemIDt    itemCounttisBindtitemDatatcurEfftcurEffIDtlvLimitt
detailDictt addItemList((sgD:\SG_ServerCode\ServerPython\ZoneServerGroup\map1_8G\MapServer\MapServerData\Script\Player\ChPlayer.pyt__DoMixServerFirstLoginÈsZ      
(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_PackDetels 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_ClientSkill@s 
      cCsnt|ƒ|jƒjƒ|jƒjƒ|jƒjƒ|jƒjƒ|jƒjƒ|jƒjƒdS(N(t__SyncClearBufft GetBuffStatet    Sync_BufftGetDeBuffStatetGetAurat
GetIncBufftGetProcessBuffStatetGetProcessDeBuffState(R    ((sgD:\SG_ServerCode\ServerPython\ZoneServerGroup\map1_8G\MapServer\MapServerData\Script\Player\ChPlayer.pyt__Sync_ClientBuffXs
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.pyRQbs 
    cCs|jtƒ|jtƒ|jtƒ|jtƒ|jtƒt||ƒtjƒj    ƒt
j kr‚t j |tj|ƒn|jƒ|jƒkr³tj||jƒƒn|jƒdkrØtj|dƒntj||ƒtjƒr|jtƒntj|ƒ}|jƒtjƒr9|jtƒn|j|ƒ|j|ƒ|j tj!|ƒtj"||ƒt#|ƒtt$_%dS(Ni(&t
SetCanMoveRt    SetInitOKt SetMapLoadOKt
SetVisiblet SetCanAttackt__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(qs4       
 
    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( RRgR"t ReadChConfigtGetEvalChConfigtitemst    BuffSkilltDelBuffBySkillIDR§R·RtClearBuffOnMapChangeList(R    RtcurMapIDt
fbBuffDictt
buffIDListtbuffIDt    mapIDList((sgD:\SG_ServerCode\ServerPython\ZoneServerGroup\map1_8G\MapServer\MapServerData\Script\Player\ChPlayer.pyRf«scCsdS(N((R    ((sgD:\SG_ServerCode\ServerPython\ZoneServerGroup\map1_8G\MapServer\MapServerData\Script\Player\ChPlayer.pyRzÁ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$RaRtSendToBServerServerInitOKR t__Func_LoadMapOKR tKickRitdisWaitForPlayerLoinErrort    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 ChangeMapInitùscCs¦tjƒj|ƒ}t||ƒtj||ƒt|ƒt||ƒ|jƒtj    ƒj
ƒt j kr~|j dƒn |j dƒ|jƒ|jtƒdS(Nii(RRšRŽR
RktPlayerChangeMapUpdateSkillCDR'R(tInitChangeMapPlayerSummonInfoRgRhRitfbtTeamtGameServer_TeamEnterFBt#BalanceServer_PlayerChangeMapInitOKRaR(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_PackCountRitrptEquipRRtrptItemt rptIdentifyRËtrptHerot
rptMGGuayut rptMGTuiyant rptTempSwapt rptTempItemt rptTreasuret
ItemCommontSyncPackBuyCntR=R7tCheckGiveBindMoneyTypeItem(R    ((sgD:\SG_ServerCode\ServerPython\ZoneServerGroup\map1_8G\MapServer\MapServerData\Script\Player\ChPlayer.pyR'Bs 
 cCstj}t||ƒS(N(RRmtCheckHasBuffBySkillID(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(( RRtGetSkillBySkillIDR|RRRkt GetBuffTypetGetBuffManagerByBuffTypetGetSkillTypeIDtFindBuffR(R    R­t    buffSkilltbuffTypet    buffTuplet    buffStatetbuffSkillTypeIDtcurBuff((sgD:\SG_ServerCode\ServerPython\ZoneServerGroup\map1_8G\MapServer\MapServerData\Script\Player\ChPlayer.pyR¬Šs 
 cCsÎtjƒj|ƒ}|jƒrÎ|jtjƒ}|jtjƒ}|rÊ|rÊtjd|j    ƒƒ|j
tjdƒ|j
tjdƒ|j t ƒt j|tjƒ|jƒtj||ƒndSt|ƒsÞdStjd|j    ƒƒ|jt ƒ|j|jƒ|jƒƒ|jƒ|jƒkrNt j||jƒƒn|jƒdkrst j|dƒn|jƒ|j t ƒtj|ƒdkr²|jtj ƒn|j!t ƒt"|ƒsÛ|j#t ƒn|j$t ƒt j%|t ƒt&j'||ƒtj(||ƒtj)ƒ}|jƒ}|jƒ}|j*tj+ƒrÃ|j*tj+ƒdkr|t j |ƒj,ƒn.t-j.||tj/ƒ\}}|j0||ƒt j1|tj+dƒntj|ƒdksí|j2ƒtj krB|jtj3ƒ}|rtj4ntj5}    tj6ƒr/tj5}    nt7||    |ƒn½|j8||ƒt krÿt-j.||tj/ƒ\}
} |
dkrÌ| dkrÌtjd||f|j    ƒƒt j |ƒ} | j,ƒqÿ|j0|
| ƒtjd|
| f|j    ƒƒn|j9ƒtj:krwt;j<tj)ƒj=ƒƒtj>krw|j?tj:ƒt@jA|tjB|ƒt@jA|tjC|ƒn|jDƒ} |jEƒ| krÀ|jF| ƒtG|ƒtjHd| ƒn|jIƒt S(Ns'Íæ¼Ò¸±±¾Öбä¸ü¹¦ÄÜÏß·ÐéÄâÇеØÍ¼³É¹¦!!!is µØÍ¼¶ÁÈ¡³É¹¦is:Íæ¼ÒµÇÂ¼ÖØÖÃλÖÃʧ°Ü, °ÑÍæ¼Ò´ò»ØÖØÉúµã posX = %s posY = %ss<Íæ¼ÒµÇÂ¼ÖØÖÃλÖÃʧ°Ü, ÉèÖø½½üµã nearPosX = %s nearPosY = %ss½øÈëµØÍ¼Ç¿ÖÆÇл»PKģʽ: %s(JRRšRŽt GetMapLoadOKR—RtDef_PlayerKey_ResetFBLinePosXtDef_PlayerKey_ResetFBLinePosYR|RRRdRR RqtDef_PlayerSight_Defaultt RefreshViewR t    DoEnterFBt__CheckForbidLoginRctInitPostGetPosXtGetPosYRnRœRoRpRõtGetHPtSetPlayerActionRitpaDieRbR®ReRatSetIsNeedProcesst PlayerGMOpert DoGMOperLogictDoEnterFBLogicRgRetDef_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    RL((sgD:\SG_ServerCode\ServerPython\ZoneServerGroup\map1_8G\MapServer\MapServerData\Script\Player\ChPlayer.pyRà6s
 
cCstS(N(R(R    ((sgD:\SG_ServerCode\ServerPython\ZoneServerGroup\map1_8G\MapServer\MapServerData\Script\Player\ChPlayer.pyt__CheckGMCanLoadMapOKCscCs:|jƒtdtjƒ@dkr&tS|jtjƒdS(Nii(t GetAccStatetpowRtDef_PysForbidByPyRR‘Rit    disGMKick(R    ((sgD:\SG_ServerCode\ServerPython\ZoneServerGroup\map1_8G\MapServer\MapServerData\Script\Player\ChPlayer.pyRÀ[s"c    Cs„tjƒj|ƒ}|j}|j}| sM| sMt|ƒt|ƒkrQdSd}x>t|ƒD]0\}}tjd|ƒs†dS|||7}qdW|j    ƒ}    ||    krËtj
d|    |fƒdS|j |    |ƒx{t|ƒD]m\}}||}
|j t j|ƒ} | |
} tj|t j|| ƒtj
d|| |
| fƒqéWt||ƒtj|ƒ} | jƒdS(Nit    RolePoints3Ê£ÓàµãÊý²»×ã! curFreePoint(%s) < needTotalPoint(%s)s7Íæ¼Ò¼Óµã: attrID=%s,curPoint=%s,addPoint=%s,updPoint=%s(RRšRŽtPointAttrIDListtPointValueListRt    enumerateRûtGetIpyGameDatat GetFreePointR§t SetFreePointReRtDef_PDict_AddPointValueR R/tNotifyPlayerBasePointtRefreshPlayerAttrState(RŒt
clientDataRR    tpointAttrIDListtpointValueListtneedTotalPointRátattrIDt curFreePointtaddPointtcurPointtupdPointRë((sgD:\SG_ServerCode\ServerPython\ZoneServerGroup\map1_8G\MapServer\MapServerData\Script\Player\ChPlayer.pyt
OnAddPointls2        &  
 
! 
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ŽRûtIPY_DataRÛtGetRolePointCounttGetRolePointByIndext    GetAttrIDRReRRûRR§RÆRRüR3R5RiR¡R©tGetItem_FromPack_ByIDtGetAttCheckItemCanUsetGetItemRemainingTimet
ReduceItemtItemDel_ResetAttrPoint(RŒRþRR    t
ipyDataMgrtcanResetIDListtcanResetRRtisFreetneedItemIDListtitemPacktdelIndext
expireTimeR&t    hasEnought itemIndexListt    itemIndextcurItemt isExpireItemt remainingTime((sgD:\SG_ServerCode\ServerPython\ZoneServerGroup\map1_8G\MapServer\MapServerData\Script\Player\ChPlayer.pytOnResetAttrPoint‘sR 4        %c    Cs×|sItjƒ}gt|jƒƒD]}|j|ƒjƒ^q%}ng}g}x>|D]6}|jtj|ƒ}|j    |ƒ|j    |ƒq\Wt
j ƒ}||_ ||_ t|ƒ|_tj||ƒdS(N(RûR    RÛR
R R ReRRûR·RéttagMCRolePointInfoRõRöRtPointAttrIDCountRîRï(    R    tsyncAttrIDListRRŒRÿRRRt    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__CheckPlayerCanMoveRgRÕtPosXtPosYtStopMovet    ChangePosRéttagMCMoveByTypeRëRœtIDR\R]tMoveTypeR t PyNotifyAllR(RŒRþRR    RL((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 SetTickByTypeR&RgRÕR'R(R)R*Rét    tagMCRushRëRœR,R\R]R R.R(RŒRþRR    RL((sgD:\SG_ServerCode\ServerPython\ZoneServerGroup\map1_8G\MapServer\MapServerData\Script\Player\ChPlayer.pyt OnPlayerRushs$& 
 
  c     Csªtjƒj|ƒ}tj|tjtjƒs4t    St
|ƒsDdS|j }|j }|j }|j}|j}||kr||krdStjƒj||ƒsÅ|j|jƒ|jƒƒdS||jdƒdkrâdS|jd|ƒ|jƒ}    |    tjtjgkrdStjƒ}
t|||
||||ƒsHdStj||||ƒdkr†|j|jƒ|jƒƒdStj||ƒ|j||ƒdS(Nt FightMoveTicki2i(RRšRŽtOperControlManagertIsObjCanDoActionRtDef_Obj_ActState_ServerActRitoalMoveRR&tStartXtStartYtDestXtDestYt    WorldTickRgRÕRÐRÂRÃR—RtGetPlayerVehicletpvNulltpvHorset CheckMovePostGetDistR tDelLimitSuperBuffR*( RŒRþRR    tsendPack_StartXtsendPack_StartYtsendPack_DestXtsendPack_DestYtsendPack_WorldTicktvehicleRä((sgD:\SG_ServerCode\ServerPython\ZoneServerGroup\map1_8G\MapServer\MapServerData\Script\Player\ChPlayer.pytPlayerFightMoveBsB                            cCso|jƒstS|jƒs tStj|ƒdkr9tStj|tjt    j
ƒsXtSt j |ƒsktSt S(Ni(RºRt
GetCanMoveRõRÄR7R8RR9RiR:R tPlayerCanStateTransferR(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(
RRgR tPlayerMoveCheckClientWorldTicktSync_ClientTickRCtChangePlayerActionRitpaNulltMove(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ÕtMoveFailRRDRtDef_PlayerMaxMoveDistR( R    tcheckObjRätstartXtstartYtdestXtdestYtsendPlayerMoveFailtobjPosXtobjPosYtmoveDist((sgD:\SG_ServerCode\ServerPython\ZoneServerGroup\map1_8G\MapServer\MapServerData\Script\Player\ChPlayer.pyRCÜ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ŽRitIPY_CCliectReborntGetTypeR§RRR R3tOnReqCrossServerRebornR tDoFBForbidRebornt
NotifyCodeRÔtPlayerReborn_InFB(RŒRR    RLRè((sgD:\SG_ServerCode\ServerPython\ZoneServerGroup\map1_8G\MapServer\MapServerData\Script\Player\ChPlayer.pytPlayerClickReborns      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.pyRi0s  cCsŒ|d}tjƒ}t|||ƒs,dS|jtjƒ}t|||ƒidd6|d6}|j|ƒtjt    j
||gƒdS(NRpitResultt ReviveTired( RRgRqReRtDef_PDict_IsAddReviveTiredt__DoPlayerRebornRätSendMsgToClientServerRËtCrossServerMsg_RebornRet(R    tmsgDatat serverGroupIDRRètgameMaptisAddReviveTiredtmsgInfo((sgD:\SG_ServerCode\ServerPython\ZoneServerGroup\map1_8G\MapServer\MapServerData\Script\Player\ChPlayer.pyRs@s
  cCsX|d}|dkrdS|d}|d}t||tƒ|rTt||ƒndS(NRviRpRw(t __RebornCostRt__AddReviveTired(R    R|RtresultRèR((sgD:\SG_ServerCode\ServerPython\ZoneServerGroup\map1_8G\MapServer\MapServerData\Script\Player\ChPlayer.pyR{Rs
 
 
cCs`tjƒ}|jƒ|jƒ|_||_|jƒ|_|jƒ|_    t
j ||ƒdS(N( RZttagPlayerRebornRëRRotTypeRÂR'RÃR(RîRï(R    Rèt
rebornInfo((sgD:\SG_ServerCode\ServerPython\ZoneServerGroup\map1_8G\MapServer\MapServerData\Script\Player\ChPlayer.pytSyncPlayerRebornbs 
    cCstjtƒ||ƒdS(N(RRŠt__Func_PlayerDisconnect(RŒR((sgD:\SG_ServerCode\ServerPython\ZoneServerGroup\map1_8G\MapServer\MapServerData\Script\Player\ChPlayer.pytPlayerDisconnectrscCswtjƒj|ƒ}yt||ƒWn*ddl}tjd|jƒƒnXtjt    |ƒƒ|j
|ƒdS(NiÿÿÿÿsÍæ¼ÒÏÂÏßÂß¼­´íÎó
%s( RRšRŽtDoPlayerDisconnectR“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 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(RR|RR 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ŽRitIPY_CSetShutCutDatat
GetSettingtEncodingToUnicodetErrLogRœRt
SetSetting(RŒRR    RLtsetting((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¬R8RR¥R®RéttagSCSettingDataR¦R§RtDataLenR·ttagSCSettingDataInfotSettingDataListtDataCntRîRï( R    R±R­R²R³R´RµtsettingDataListt syncKeyListR°R¯tsDataR`((sgD:\SG_ServerCode\ServerPython\ZoneServerGroup\map1_8G\MapServer\MapServerData\Script\Player\ChPlayer.pyRüs8                      cCsÿtjƒj|ƒ}|j}|tjkrKtjd||jƒƒdSx­tdtj    dƒD]•}t
|d|ƒs¡tjd||f|jƒƒqbnt |d|ƒ}t j |tj||f|ƒtjd|||f|jƒƒqbWdS(Ns!СÖúÊÖ²»Ö§³Ö¸ÃÉèÖñàºÅ! setNum=%sisValue%ss+СÖúÊÖ²»Ö§³Ö¸ÃÖµ±àºÅÉèÖÃ! setNum=%s,value%ss"СÖúÊÖÖµÉèÖÃ: setNum=%s,value%s=%s(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.pytOnSetLittleHelper)s      'cCsg}xÈttjdƒD]³}d}xŽtdtjdƒD]v}|jtj||fƒ}|skq=n|s‰tjƒ}||_    nt
|d|ƒr=t |d||ƒq=q=W|r|j |ƒqqW|sÛdStj ƒ}||_t|jƒ|_tj||ƒdS(NisValue%s(RÛRRÁR®RÂReRÅ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.pyRa8s*       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 OnSetGuideOKZs         cCsutjƒ}g|_x7ttjƒD]&}|jj|jtj|ƒƒq%Wt    |jƒ|_
t j ||ƒdS(N( RéttagMCGuideStatet
GuideStateRÛRRÓR·ReRÔRRKRîRï(R    tguideStatePackRá((sgD:\SG_ServerCode\ServerPython\ZoneServerGroup\map1_8G\MapServer\MapServerData\Script\Player\ChPlayer.pyR6os     $cCs)tjƒ}||_tj||ƒdS(N(RéttagMCShowGuidetGuideIDRîRï(R    tguideIDt    showGuide((sgD:\SG_ServerCode\ServerPython\ZoneServerGroup\map1_8G\MapServer\MapServerData\Script\Player\ChPlayer.pyt    ShowGuideys     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ŽRitIPY_CSetHPRestoretGetValuetSetHPRestoreSettingRõRÄR tPlayerAutoRestoreHP(RŒRR    RLtcurValue((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ŽRitIPY_CSetMPRestoreRætSetMPRestoreSettingRõRÄR tPlayerAutoRestoreMP(RŒRR    RLRé((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( RitamPeacetamMaxRR§RÞRgtGetAttackModelsRñ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 RNRRM(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(RRšRŽR tDoPlayerResetWorldPos(RŒRR    ((sgD:\SG_ServerCode\ServerPython\ZoneServerGroup\map1_8G\MapServer\MapServerData\Script\Player\ChPlayer.pyRü'    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.pytPlayerChangeMapFailCallback2    s
 
cCsM|jtƒtjƒ}|jƒtj||ƒtjd|j    ƒƒdS(Ns µØÍ¼Çл»Ê§°Ü(
RdRRéttagMCChangeMapFailRëRîRïRR|Rœ(R    RL((sgD:\SG_ServerCode\ServerPython\ZoneServerGroup\map1_8G\MapServer\MapServerData\Script\Player\ChPlayer.pyR;    s   
cCs&tjƒj|ƒ}t||ƒdS(N(RRšRŽt __Func_ExitFB(RŒRR    ((sgD:\SG_ServerCode\ServerPython\ZoneServerGroup\map1_8G\MapServer\MapServerData\Script\Player\ChPlayer.pytExitFBV    s cCs‘tjƒjƒtjkr=|jƒtjddƒkr=dStjd|j    ƒ|j
ƒƒt j |ƒspdSt j ||ƒtj|ƒdS(NtMapLineisÍæ¼Ò = %s , Ö÷¶¯À뿪¸±±¾(RRgRhRiRjR"RûRüR|tGetNameRœ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ŽRitIPY_CChangeLinetGetLineR¢RœRR"RûRüRt__CheckCanChangLineR tPlayerChangeLine(    RŒRR    RLt 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 RkRRÑRitpaSitt DoPlayerStandtDef_PlayerChangLine_StatetIsPlayerInFightR@tDef_PlayerChangLine_VehicleR(R    Rt playerAction((sgD:\SG_ServerCode\ServerPython\ZoneServerGroup\map1_8G\MapServer\MapServerData\Script\Player\ChPlayer.pyR ª    s  cCs/tj|ƒdkr.|jƒtjkr.dS|tjtjgkrJdStj    ƒj
ƒ}|tj kr¼t j ddƒ}tjtj    ƒjƒƒ}||kr¬||S|jddƒS|jtjƒr+tj|tjƒd}|r+|jƒjƒ|jƒjƒkr(t j ddƒdSq+ndS(s ËÀÍö״̬²ÅÑé֤ʱ¼ä£¬±¾·þ¿ç·þͨÓÃ
            ¿ç·þ·þÎñÆ÷ËÀÍöµÄ¸´»îÒ²ÊÇÏÈ·¢µ½±¾·þ£¬Õý³£Çé¿öϱ¾·þÊÇ»î×ŵģ¬ÎÞ·¨ÑéÖ¤
            ËùÒÔ¿É·ñ¸´»îÓÉ¿ç·þ·þÎñÆ÷ËÀÍö״̬ϵÄÍæ¼ÒʵÀýÅжϣ¬¼òµ¥½²¾ÍÊÇÄĸö·þÎñÆ÷ËÀÍöµÄÄĸö·þÎñÆ÷ÅжÏ
            ËùÒԸú¯Êý¿ÉÒÔÖ±½ÓʹÓÃÍæ¼ÒËùÔڵĵØÍ¼ÅжÏ
    itDuplicatesRebornTimeitRebornArguments(RõRÄRÑRiRÆRRÒtrebornType_MainCityRRgRhRjRûRüRIRØR"tgetReRxRkt 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(ReRR1tintttimeRR§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ÑRiRÆR‡RtDef_RebornTypeListRtrebornType_HealthtrebornType_UseItemtGetLocalRebornRR¢R"R,R-R.ReR1R RkR|RRRR t OnCanFBRebornR(R    RèR~RnR­trebornCDtcurTimetdeadTime((sgD:\SG_ServerCode\ServerPython\ZoneServerGroup\map1_8G\MapServer\MapServerData\Script\Player\ChPlayer.pyRqú    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 R3RRR5RûRüt HaveMoneyExRËtTYPE_Price_Gold_Paper_MoneyRR¢tPayMoneytDef_Cost_ReviveR6R©tFindItemInPackByEffectExtDef_Effect_ReborntDelItemR( R    RètisDoCostRtR­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"R<tOnResetFBRebornPlacePosRkRlRmReRxR‚RûRRrt IsInPKStatetSetPKStateTickt IsInBossStatetSetBossStateTicktRefreshAllStateRõRöR÷tOnPlayerRebornOverRRgRÕRÂRÃtGetRebornMapIDR"RÌtPlayerResetWorldPost GetRebornMapXt GetRebornMapYRQRiRR(
R    RèRt mapBornPlacetisAddSuperBufftresetHpPercentt
isFBRebornt    validTimeRëR~((sgD:\SG_ServerCode\ServerPython\ZoneServerGroup\map1_8G\MapServer\MapServerData\Script\Player\ChPlayer.pyRyB
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( RkR$RR%R&R'R(RlRR§R R/Rx(R    RR+t buffSkillLV((sgD:\SG_ServerCode\ServerPython\ZoneServerGroup\map1_8G\MapServer\MapServerData\Script\Player\ChPlayer.pyR‚
scCsatjƒ}t|||ƒs"dStjƒsGt||tƒsGdSnt|||||ƒtS(s Íæ¼Ò¸´»î
    N(RRgRqRRRRy(R    RèRRYRZR~((sgD:\SG_ServerCode\ServerPython\ZoneServerGroup\map1_8G\MapServer\MapServerData\Script\Player\ChPlayer.pyRԏ
s  cCs<tjƒjƒ}|tjkr%dStj|||ƒdS(N(RRgRhRiRjR t DoFBOnReborn(R    RèRR)((sgD:\SG_ServerCode\ServerPython\ZoneServerGroup\map1_8G\MapServer\MapServerData\Script\Player\ChPlayer.pyRl¤
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ŽRitIPY_CEnterFbGameEventR"t    GetLineIDR t PlayerEnterFB(RŒRR    RLRtclientSendLineID((sgD:\SG_ServerCode\ServerPython\ZoneServerGroup\map1_8G\MapServer\MapServerData\Script\Player\ChPlayer.pyRaÕ
s    c
    Csntjƒj|ƒ}|j}|j}|j}|j}|j}|j}    t    ||||||||    ƒdS(N(
RRšRŽR…tMapIDtLineIDR'R(tExData1t__Func_WorldTransPort(
RŒR`RR    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-927DE1ACCC4F378ERlRm(ii(R"R0RtTYPE_Player_Tick_WorldTransportR2R3RRR§RtDef_PackType_TransportTypeR8R¢R#R tCheckPlayerTransporttCheckTagCountrytGetTransportPosRktDef_Transport_Type_MissiontTransportVipLvRestricttPayForTransportRtDef_PlayerKey_TransTypet
BeginTrans(
R    RkRRåRæRRlRmR­t transportType((sgD:\SG_ServerCode\ServerPython\ZoneServerGroup\map1_8G\MapServer\MapServerData\Script\Player\ChPlayer.pyRjõ
s>&          c    Cs&tj||||||||ƒtS(N(R RVR(R    RRåRæRlRŸtcanLockRm((sgD:\SG_ServerCode\ServerPython\ZoneServerGroup\map1_8G\MapServer\MapServerData\Script\Player\ChPlayer.pyRx6 s"cCsX|jƒ|krNtjƒj||ƒsNtj||tjƒ\}}qNn||fS(N(R"RRgRÕRÍRÎRRÏ(R    RyttransportMapIDt transportPosXt transportPosY((sgD:\SG_ServerCode\ServerPython\ZoneServerGroup\map1_8G\MapServer\MapServerData\Script\Player\ChPlayer.pyRsQ 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(RûRRR3R5RiR¡R©R tTransportPayMoneytTYPE_Price_Gold_PaperRR§RR(R    RyR&tuseCountRRtitemListt    costMoney((sgD:\SG_ServerCode\ServerPython\ZoneServerGroup\map1_8G\MapServer\MapServerData\Script\Player\ChPlayer.pyRvm scCsdS(Ni((R    Ry((sgD:\SG_ServerCode\ServerPython\ZoneServerGroup\map1_8G\MapServer\MapServerData\Script\Player\ChPlayer.pyRuƒ sc    CsŽtj|||ƒ}|gkr%tSxb|D]Z\}}|dkr,tj|||tji|d6ƒtj||dd||ƒq,q,WtS(Nit TransportType(    R R=RR?RtDef_Cost_TransportRtLogin_Interface_GoldRecR(R    RHtmoneyRyt    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(RRRR€RšRŽR‹t ExchangeTimeR#R-R¢tGetVIPLvtGetOfflineMinutesR tGetPlayerReExpRÆtevalR=R?RtDef_Cost_OffLineExptDef_Cost_Reason_SonKeytAddExpRtSetOfflineMinutestSyn_OfflineTimeQueryResult(RŒt curPackDataRtOfflineExpChangeDictR    tmulIndext exchangeTimetrecListtminVIPLvtVIPLvt
useMinutest haveMinutestrExptreLVtworldLvExpRatet    redeemExpt moneyInfoListRHRƒRët haveMoneyListRIt 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(ReRRfR R/RgRhRiRjRoRpRqRrt
ADCntOnDay(R    RvRwRz((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
||ƒnw|tj kr”t    j ||ƒnU|tj kr¶tj||ƒn3|tjkrØtj||ƒn|tjkr÷t||ƒnò|tjkrtj|ƒnÓ|tjkr5tj|ƒn´|tjkrZtj|||ƒn|tjkr|tj ||ƒnm|tj!kržt"j#||ƒnK|tj$kr½t%||ƒn,|tj&krßt'j(||ƒn
|tj)krt*j+|||ƒnå|tj,kr)t-j.|||ƒnÀ|tj/krNt0j1|||ƒn›|tj2krst3j4|||ƒnv|tj5kr˜t6j7|||ƒnQ|tj8kr½t9j:|||ƒn,|tj;krât<j=|||ƒn|tj>krt?j@|||ƒnâ|tjAkr,tBjC|||ƒn½|tjDkrQtEjF|||ƒn˜|tjGkrvtHjI|||ƒns|tjJkr›tKjL|||ƒnN|tjMkr½t-jN||ƒn,|tjOkrÙtP|ƒn|tjQkrûtRjS||ƒnî|tjTkrtUjV||ƒnÌ|tjWkr?t-jX||ƒnª|tjYkratZj[||ƒnˆ|tj\kr†t]j^|||ƒnc|tj_krºt`||tjatbjcddƒƒn/|tjdkrît`||tjetbjcddƒƒnû|tjfkr"t`||tjgtbjcddƒƒnÇ|tjhkrVt`||tjitbjcddƒƒn“|tjjkrÊtjkƒjltmjnƒd}tbjoddƒ}    ||    krét`||tjptbjcddƒdƒqén|tjqkrétr||ƒndS(    Ns5PlayerGetReward: rewardType=%s,dataEx=%s,dataExStr=%stGameNoticeRewarditShareGameRewardtGoodGameRewarditOpenServerDailyAwardi(sRRš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”tGetLunhuidianAwardtDef_RewardType_FirstChargeR@tGetPlayerFirstChargetDef_RewardType_TotalRechargeRQtOnGetTotalRechargeAwardtDef_RewardType_ManyDayRechargeR]tOnGetManyDayRechargeAwardtDef_RewardType_SingleRechargeR^tOnGetSingleRechargeAwardtDef_RewardType_ActLoginAwardNewR[tOnGetActLoginAwardtDef_RewardType_ActBuyCountGiftRYtOnGetBuyCountGiftAwardtDef_RewardType_ActTaskRZtOnGetActTaskAwardtDef_RewardType_BuyOneRRtGetBuyOneFreeAwardtDef_RewardType_FamilyCTGAssistRStGetFamilyCTGAssistAwardtDef_RewardType_FamilyGCZR‰tGetFamilyGCZAwardtDef_RewardType_TreasureCntAwardRGtGetTreasureCntAwardt!Def_RewardType_HistoryChargeAwardtOnGetHistoryRechargeAwardtDef_RewardType_CreateRoletOnGetCreateRoleAwardtDef_RewardType_CustomAwardRdtOnGetCustomAwardtDef_RewardType_RealmLVUpTaskR:tGetRealmLVUpTaskAwardtDef_RewardType_DailyPackBuyGifttGetDailyPackBuyGifttDef_RewardType_TaskR†t GetTaskAwardtDef_RewardType_ZhanlingR…tGetZhanlingRewardRhtOnGiveAwardByClientRfRûRüRjRiRlRkRnRmRpRÃR RËtDef_Notify_WorldKey_ServerDayRRoRrtOnGetRechargeDayAward(
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||ƒndS(    NtADAwards-½ñÈÕ¸Ã¹ã¸æ½±ÀøÒÑ´ïÉÏÏÞ! adID=%s,adCnt=%s > %sisNÁìÈ¡¹ã¸æ½±Àø! adID=%s,adCnt=%s,adAwardType=%s,adAwardValue=%s,awardItemList=%steventiii(RûRøt GetADCntMaxReRtDef_PDict_ADCntRR§R R/tGetADAwardItemListtGetADAwardTypetGetADAwardValueR‹R7tGivePlayerItemOrMailRR‡tGetTreeEnergyAwardRIt
AddFBADCntRGt
DoTreasuretCostType_ADFreeRtAddTravelEnergy(
R    tadIDtipyDatatadCntMaxtadCntt awardItemListt adAwardTypet adAwardValuetadMapIDt treasureType((sgD:\SG_ServerCode\ServerPython\ZoneServerGroup\map1_8G\MapServer\MapServerData\Script\Player\ChPlayer.pyR¹“ s8 
    "    cCs§g}tjƒ}xxt|jƒƒD]d}|j|ƒ}|jƒ}|jtj|ƒsbq%nt    j
|tj|dƒ|j |ƒq%W|r£t ||ƒndS(Ni( RûR    RÛtGetADAwardCounttGetADAwardByIndextGetADIDReRRúR 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ÿ(RûR    RÛR RRReRRúR®Rét tagSCADInfotADIDtADCntR·ttagSCADInfoListt
ADInfoListRRKRîRï(
R    RRRátadIDListt
adInfoListRRtadInfoR`((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(ReRtDef_PDict_CTGRealTotalRqRûRüRR-RR§RR©t GiveAwardItemR R/Rg(
R    Ròt    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( ReRtDef_PDict_CreateRoleAwardStateRR§R©RRûRüR R/Rc(R    ((sgD:\SG_ServerCode\ServerPython\ZoneServerGroup\map1_8G\MapServer\MapServerData\Script\Player\ChPlayer.pyRäô s 
cCs?tjƒ}|jƒ|jtjƒ|_tj||ƒdS(N(    RéttagMCCreateRoleAwardStateRëReRR#tGetStateRîRï(R    RL((sgD:\SG_ServerCode\ServerPython\ZoneServerGroup\map1_8G\MapServer\MapServerData\Script\Player\ChPlayer.pyRc s
 
cCsû|jƒ}tjddƒ}|jtjƒ}||krZtjd||f|ƒdStjddƒ}|svdSt    j
|tj|ƒtjd||f|ƒ|dkrÎt j d|j ƒ|ƒntj||ddtigƒt|ƒdS(    Nt
DownRewardis7ÒÑÁìÈ¡·Ö°ü½±Àø! curAwardNum(%s) == downloadAwardNum(%s)is4ÁìÈ¡·Ö°üÏÂÔØ½±Àø: curAwardNum=%s,downloadAwardNum=%stSubpackageDownloadRøt PackDownload(RRûRReRtDef_PDict_DownloadAwardStateRR§RüR R/R‚RýRœR7RþRR_(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( RûRRéttagMCPackDownloadRecordRëReRR)tRecordRîRï(R    R*RL((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(ReRR§R©RR R/Rg(R    RòtdictKeytawardCfgt    eventName((sgD:\SG_ServerCode\ServerPython\ZoneServerGroup\map1_8G\MapServer\MapServerData\Script\Player\ChPlayer.pyRï' scCs<tjƒ}|jƒ||_||_tj||ƒdS(N(RéttagMCPlayerRewardGetRecordRëR­tRewardGetRecordRîRï(R    RòtrewardGetRecordRL((sgD:\SG_ServerCode\ServerPython\ZoneServerGroup\map1_8G\MapServer\MapServerData\Script\Player\ChPlayer.pyRg7 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tDataRR€R#R÷R R/RtDef_PDict_AutoFightSetting(RŒRþRR    t settingDicttBasicSkillCounttAreaSkillCounttBuffSkillCounttBasicSkillListtKeyt
ValueIndextValuet AreaSkillListt BuffSkillList((sgD:\SG_ServerCode\ServerPython\ZoneServerGroup\map1_8G\MapServer\MapServerData\Script\Player\ChPlayer.pytOnSaveAutoFightSettingB 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(NR4R5iR6R‚R7s%s(RR€RÛReRR9R·RéttagMCAutoFightSettingRëR8RtSizeRîRï( R    R;R<R=R:R?R>R@RARBRCRL((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_QueryMapNPCInfoR0R2R§R3RgRht    NPCIDListRt BaseExceptionR¢t
isinstancetlistR™RgR"Ròt
GetNPCInfoRit 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ŽRJtCheckPlayerTickRRKR§RgRhRLRRMR¢RNROR™RgR"Ròt GetNPCCntInfotSyncNPCCntInfoRTtqueryType_NPCCntR( RŒRþRR    RWRXRYRZR…R[R^((sgD:\SG_ServerCode\ServerPython\ZoneServerGroup\map1_8G\MapServer\MapServerData\Script\Player\ChPlayer.pytOnQueryMapNPCCntInfoÒ s@                           cCs#tjƒj|ƒ}|jƒdS(N(RRšRŽRP(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|_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.pyR s"  
        cCstjƒ}|sdStjƒ}tjƒjtjƒ|_    tjƒjtj
ƒ|_ tjƒjtj ƒ|_ tjƒjtjƒ|_|j|_|j|_|j|_|j|_|j|_|j|_|j|_tjƒ|_t j!||ƒdS(N("RRgRéttagMCOpenServerDayR´tGetEventTrigMgrRæRËt Def_ServerDayRntDef_IsMixServert IsMixServertDef_MixServerDaytMixDaytDef_OpenServerWeekdayt OpenWeekdayRitNowYearRktNowMonthRmtNowDayRotNowHourRqt    NowMinuteRst    NowSecondRut NowMicSecondt GetWeekOfYeart
WeekOfYearRîRï(R    R}R`((sgD:\SG_ServerCode\ServerPython\ZoneServerGroup\map1_8G\MapServer\MapServerData\Script\Player\ChPlayer.pyR&s$         cCsätjƒj|ƒ}t|||ƒsà|jƒ|jƒ}}tjƒj||ƒtkrÍt    j
||dƒ}|jƒ|kr²|jƒ|kr²tj d||fƒdS|jƒ}|jƒ}n|j ||ƒndS(NisÍæ¼Ò×ø±ê¿¨ËÀ %s %s( RRšRŽtPYPlayerNormalMoveRÂRÃRgRÕRRÍtGetEmptyPlaceInAreaR¢RÐ(RŒR`RR    RåRæt    resultPos((sgD:\SG_ServerCode\ServerPython\ZoneServerGroup\map1_8G\MapServer\MapServerData\Script\Player\ChPlayer.pyt PYPlayerMoveLs$ 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)(+R&RtDirt
ClientPosXt
ClientPosYt    SeverPosXt    SeverPosYR?R-tGetClientMoveTickRR§RgRÕRRÂRÃRtMoveDistCalcTickt MoveDistSumtSetClientMoveTicktPyNotifyPlayerMoveRhRiRjR t DoFBCanMoveR@RARBR RORPRDRœR—tminRûRtGetSpeedRQRRR*(R    R`RtmoveDirt
clientPosXt
clientPosYtsendPack_SeverPosXtsendPack_SeverPosYRJtmoveTypet lastMoveTickRKtdisttcalcTicktdistSumtspeedt passCalcTicktneedTickt checkNeedTick((sgD:\SG_ServerCode\ServerPython\ZoneServerGroup\map1_8G\MapServer\MapServerData\Script\Player\ChPlayer.pyR‘dsr                               $  
$  
 
     # cCstjƒ}|jƒ|jƒ|_tj|_||_||_    ||_
||_ ||_ |j ƒ|_||_tj||tdƒdS(Ni(RéttagMCPYPlayerMoveRëRœR^Rit    gotPlayerR]R˜R™RšR›RœR¤tSpeedR-R R.R(R    R¥R¦R§RåRæRªRL((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ëR'R(tNPCIDRîRï(R    RåRætnpcIDRL((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 OnRoleLostHPøs
  cCsdS(N((RŒRþR((sgD:\SG_ServerCode\ServerPython\ZoneServerGroup\map1_8G\MapServer\MapServerData\Script\Player\ChPlayer.pytOnSelectRealmDifficulty scCs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 OnViewGameRecs        cCs;g}xÛ|D]Ó}|sq ntjƒ}|jƒ|_|jƒ|_|jƒ|_|jƒ|_    |j
ƒ|_ |j ƒ|_ |jƒ|_|jƒ|_|jƒ|_|jƒ|_t|jƒ|_|j|ƒq Wtjƒ}|jƒ||_||_||_t|jƒ|_tj ||ƒdS(N(!Rét tagSCGameRectGetTimetTimet    GetValue1tValue1t    GetValue2tValue2t    GetValue3tValue3t    GetValue4tValue4t    GetValue5tValue5t    GetValue6tValue6t    GetValue7tValue7t    GetValue8tValue8t GetUserDatatUserDataRt UserDataLenR·ttagSCGameRecInfoRëRÃRÄtRecListRKRîRï(R    RÉRÊt recDataListRšR´trecR`((sgD:\SG_ServerCode\ServerPython\ZoneServerGroup\map1_8G\MapServer\MapServerData\Script\Player\ChPlayer.pyRÇ&s2   
            (ßRrRiRR RÍRR‚RRERòRkR RUR©R7RWRÈRR7RËRîRéR)R<R@RCR:R€RKRRIRLRAR½RGRûR+tPassiveBuffEffMngRRRTRQR\RSR]R^R’RZRNR{R?Rbt
SkillShellR„RdR…R‡RŽR†RõRˆR[RYR”R‰RZR‚R´RÇRŒtGameServerRefreshR“R¿R‘t    PyMongoDBRRR}RŠRR“RRRR‘R5RƒRªRRÉRxR¨tdatetimeR.tmathtreRŽRR
R R$RR R•RºRÒR»RÓRâRR–RåR>R4R/R2R=RPRYRQR(RfRzRR‹R—R–R'R®R¬RRàRïRÀRR!RüR/R5RLR&RYRCRmRiRsR{R‡R‰RˆRŒRŠR¥R·RRÈRaRØR6RàRäRêRîRöRúRûRýRüRRRRRR R,R2R®RqRRyR‚RÔRlR`RbRaRnRjRxRsRvRuRR¦R¨RöR¹R§R‹RñRäRcRÆR_RïRgRDRGRHR_ReRfRRR”RžRŸR‘R¡R¹RÁRÂRÌRÇ(((sgD:\SG_ServerCode\ServerPython\ZoneServerGroup\map1_8G\MapServer\MapServerData\Script\Player\ChPlayer.pyt<module>s¶                                                                                                               &         ´    8    *     1            
    &            /    A         ,        
        :            
         
    ?    >    
        Ž                 %    2 !    $    :    K    +    $ 6                                          0         -        "        
                     "                                      
    !    )    "    #     +    ?                             A                    J    #    €    $                                            (    
    @    /    
    &        n