gwj
3 天以前 f87cc7fbd9af4a8cecc09fe3128ca1521bf363fd
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
m7©ic@sddlZddlZddlZddlZddlZddlZddlZddlZddlZddl    Z    ddl
Z
ddl Z ddl Z ddl Z ddlZddlZddlZd„Zd„Zd„Zd„Zd„Zd„Zd„Zd    „Zd
„Zd d „Zd „Zd d„Zd„Zd„Zd„Zd„Z d„Z!d„Z"d„Z#d„Z$d„Z%dd„Z'e(d„Z)d„Z*d„Z+d„Z,d„Z-d„Z.e(d„Z/d „Z0e(d!„Z1d"„Z2d#„Z3e(d$„Z4d%„Z5d&„Z6d'„Z7d(„Z8d)„Z9d d*„Z:d+„Z;d,„Z<d-„Z=d.„Z>d/„Z?d0„Z@d1„ZAd2„ZBd3„ZCd4„ZDd5„ZEd6„ZFd7„ZGd8d9„ZHd:„ZId;„ZJd<„ZKd=„ZLd>„ZMd?„ZNd@„ZOdA„ZPdB„ZQdC„ZRdD„ZSdE„ZTdF„ZUddG„ZVddH„ZWdI„ZXddJ„ZYddK„ZZdS(LiÿÿÿÿNcCs9|jtjƒr5tj|tjdƒt|ƒndS(Ni(tNomalDictGetPropertytChConfigtDef_PDict_HeroAwakeRebirthCntt PlayerControltNomalDictSetPropertytSync_PlayerHeroInfo(t    curPlayer((siD:\SG_ServerCode\ServerPython\ZoneServerGroup\map1_8G\MapServer\MapServerData\Script\Player\PlayerHero.pyt PlayerOnDay%s cCs6t|ƒt|ƒt|ƒt|ƒt|ƒdS(N(t Sync_HeroInfoRtSync_LineupRecommendInfotSync_HeroFatesInfot__CheckOSAHeroStar(R((siD:\SG_ServerCode\ServerPython\ZoneServerGroup\map1_8G\MapServer\MapServerData\Script\Player\PlayerHero.pyt OnPlayerLogin+s 
 
 
 
 
cCst|ƒt|ƒdS(N(tOnFirstLoginInitPlayertOnFirstLoginInitHero(R((siD:\SG_ServerCode\ServerPython\ZoneServerGroup\map1_8G\MapServer\MapServerData\Script\Player\PlayerHero.pytOnPlayerFirstLogin3s
 
c     Csx|jƒjtjƒ}|jƒsO|jƒjtjƒ}|jƒsOdSntjddiƒ}|sndStj    d||j
ƒƒxé|j ƒD]Û\}}tj ƒj |ƒ}|sÂq•n|jƒ}|d}|dks•||jƒkrüq•n|j|ƒ}    |    jƒsq•n|r3i|tj6ni}
tj|dd|d|
ƒ} | scq•n|    j| ƒq•WdS(Nt NewRoleInitis³õʼ»¯ÐÂÊÖ¶¨ÖÆ×°±¸: %siRt setAttrDict(tGetItemManagertGetPackt IPY_GameWorldtrptEquiptGetCountt rptIdentifyt IpyGameDataPYtGetFuncEvalCfgt    GameWorldtDebugLogt GetPlayerIDtitemst GetGameDatatGetItemByTypeIDt GetEquipPlacetGetAttIsEmptyt ShareDefinetDef_CItemKey_AppointIDt ItemControlertGetOutPutItemObjt
AssignItem( Rt    equipPackt identifyPacktdefaultEquipInfotequipIDt    appointIDtitemDatat
equipPlacetequipPlaceIndext    destEquipRtcurItem((siD:\SG_ServerCode\ServerPython\ZoneServerGroup\map1_8G\MapServer\MapServerData\Script\Player\PlayerHero.pyR 8s4   
 c        Csø|jƒjtjƒ}tjd|jƒ|jƒƒ|jƒsHdStj    ddiƒ}|sgdStjd||jƒƒd}d}xd|j
ƒD]V\}}t |||ƒ}i|gtj 6}t j||dttjgd|ƒqšWdS(NsOnFirstLoginInitHero: %sRis³õʼ»¯ÐÂÊÖÎ佫: %siiR(RRR#trptHeroRRRRRRRtComLineupValuetDef_IudetHeroLineupR%tGivePlayerItemtFalse(    RtcurPacktdefaultHeroInfotpresetIDt    shapeTypetheroIDtposNumt lineupValueR((siD:\SG_ServerCode\ServerPython\ZoneServerGroup\map1_8G\MapServer\MapServerData\Script\Player\PlayerHero.pyRWs  )cCsÇ|jtjdƒ|jtjƒr;|jtjdƒn|jtjƒrc|jtjdƒn|jtjƒr‹|jtjdƒn|jtjƒr³|jtjdƒn|jtjƒrÛ|jtjdƒn|j    tj
ƒr|j tj
ƒn|j    tj ƒr%|j tj ƒn|j    tj ƒrJ|j tj ƒn|j    tjƒro|j tjƒn|j    tjƒr”|j tjƒn|j    tjƒr¹|j tjƒnt|ƒdS(Nii(t SetUserAttrR#tDef_IudetHeroLVt GetUserAttrtDef_IudetHeroStartDef_IudetHeroBreakLVtDef_IudetHeroAwakeLVtDef_IudetHeroSkintDef_IudetHeroSkinAttrtGetUserAttrCounttDef_IudetHeroTalentIDt ClearUserAttrtDef_IudetHeroTalentIDLVtDef_IudetHeroTalentWashLocktDef_IudetHeroTalentWashIDtDef_IudetHeroTalentIDAwakeRandR4tInitHeroTalent(t
singleItem((siD:\SG_ServerCode\ServerPython\ZoneServerGroup\map1_8G\MapServer\MapServerData\Script\Player\PlayerHero.pyt InitHeroItemks2
cCs¦|jƒ}tjd|ƒ}|s(dS|jƒ}tjd|ƒ}|sPdSd}|jƒ}|r}tj|dƒ}ni}g}tjƒ}    x^t|    j    ƒƒD]J}
|    j
|
ƒ} | j ƒ} | j ƒ} |j | | gƒ| || <q¨W|jtjƒ|jtjƒx‰t|ƒD]{}tj|ƒ}|sDq#n|j|dƒ|g}||krx|j|ƒn|jtj|ƒ|jtjdƒq#WdS(s+³õʼ»¯²ÛλÌ츳£¬²»Í¬²ÛλÌ츳ID²»ÄÜÒ»Ñù
    tHeroNt HeroQualityii(t GetItemTypeIDRtGetIpyGameDatat
GetQualitytGetInitTalentWeightRtGetResultByWeightListtIPY_DatatrangetGetHeroTalentCounttGetHeroTalentByIndext GetTalentIDt GetInitWeighttappendRHR#RGRItgettremovet AddUserAttr(RNR;t heroIpyDatatqualitytqualityIpyDatat initTalentCnttinitTalentWeightt talentIDDictttalentWeightListt
ipyDataMgrtindext talentIpyDatattalentIDt
initWeightt_t randTalentIDt randWeightID((siD:\SG_ServerCode\ServerPython\ZoneServerGroup\map1_8G\MapServer\MapServerData\Script\Player\PlayerHero.pyRM‰sB       cCs›|jƒ}tjd|ƒ}|s(dSt||ƒs—t||dƒtjd||jƒƒt||gƒt    j
|ƒj |ƒt j |ƒndS(NRPisÊ״줻îÎ佫: heroID=%s(RRRRStGetHeroActivitetSetHeroActiviteRRRRt PlayerOnlinetGetOnlinePlayertOnHeroItemUpatetOpenServerActivitytUpdOSA_HeroTrainBillboard(RtheroItemR;Ra((siD:\SG_ServerCode\ServerPython\ZoneServerGroup\map1_8G\MapServer\MapServerData\Script\Player\PlayerHero.pytOnGiveHeroItemµs cCs|jtj|ƒd}|S(Ni
(RRtDef_PDict_HeroBook(RR;tactState((siD:\SG_ServerCode\ServerPython\ZoneServerGroup\map1_8G\MapServer\MapServerData\Script\Player\PlayerHero.pyRpÆsicCs˜|jtj|ƒ}|d}|r9|r0dSd}nd}tj|dd|ƒ}tj|tj||ƒtjd|||f|jƒƒdS(Ni
iis0ÉèÖÃÎ佫¼¤»î״̬:%s,bookState=%s,updBookState=%s(    RRRyRtSetValueRRRR(RR;tisActt    bookStateRzt updBookState((siD:\SG_ServerCode\ServerPython\ZoneServerGroup\map1_8G\MapServer\MapServerData\Script\Player\PlayerHero.pyRqÌs
    #cCs$|jtj|ƒd}|dkS(Ni
i(RRRy(RR;t    initState((siD:\SG_ServerCode\ServerPython\ZoneServerGroup\map1_8G\MapServer\MapServerData\Script\Player\PlayerHero.pytGetHeroBookInitStateÛscCsš|jtj|ƒ}|d}|r/d}n|r;dnd}tj|dd|ƒ}tj|tj||ƒtjd|||f|jƒƒdS(Ni
iiis4ÉèÖÃÎ佫ͼ¼ø¼¤»î״̬:%s,bookState=%s,updBookState=%s(    RRRyRR{RRRR(RR;R|R}RzR~((siD:\SG_ServerCode\ServerPython\ZoneServerGroup\map1_8G\MapServer\MapServerData\Script\Player\PlayerHero.pytSetHeroBookInitStateßs
    #cCs|jtj|ƒdS(Ni
(RRtDef_PDict_HeroSkinInfo(RtskinID((siD:\SG_ServerCode\ServerPython\ZoneServerGroup\map1_8G\MapServer\MapServerData\Script\Player\PlayerHero.pytGetHeroSkinStateíscCsK|jtj|ƒ}|ddtd|ƒ}tj|tj||ƒS(Ni
i(RRR‚tminRR(RRƒtstatetinfo((siD:\SG_ServerCode\ServerPython\ZoneServerGroup\map1_8G\MapServer\MapServerData\Script\Player\PlayerHero.pytSetHeroSkinStateðscCs|jtj|ƒdS(Ni
(RRR‚(RRƒ((siD:\SG_ServerCode\ServerPython\ZoneServerGroup\map1_8G\MapServer\MapServerData\Script\Player\PlayerHero.pytGetHeroSkinStarôscCsB|jtj|ƒ}|d|d}tj|tj||ƒS(Ni
(RRR‚RR(RRƒtstarR‡((siD:\SG_ServerCode\ServerPython\ZoneServerGroup\map1_8G\MapServer\MapServerData\Script\Player\PlayerHero.pytSetHeroSkinStar÷scCs}|jƒjtjƒ}|dks6||jƒkr:dS|j|ƒ}| s\|jƒr`dS|jƒtj    krydS|S(Ni(
RRR#R2RR!R"tGetTypeRtDef_ItemType_Hero(Rt    itemIndexR7Rw((siD:\SG_ServerCode\ServerPython\ZoneServerGroup\map1_8G\MapServer\MapServerData\Script\Player\PlayerHero.pyt GetHeroItemüscCs_|jtjƒ}|sgSg}x6t|ƒD](}|jtj|ƒ}|j|ƒq/W|S(N(RFR#tDef_IudetHeroEffPresetIDRXtGetUserAttrByIndexR](Rwt    dataCountteffPresetIDListtlpIndexR9((siD:\SG_ServerCode\ServerPython\ZoneServerGroup\map1_8G\MapServer\MapServerData\Script\Player\PlayerHero.pytGetHeroEffPresetIDListscCsZtjƒj|ƒ}|jƒ}|j}t||ƒ}|sCdS|jƒ}tjd|ƒ}|skdS|j    ƒ}    |j
t j ƒ}
|j
t j ƒ} tjd||| |    |
f|ƒtjd|    | ƒ} | sÝdS| d} tjd|    | ƒstjd|    | f|ƒdS| jƒ}|s0dS|\}}| sJ| rNdS|jƒjtjƒ}tj|||ƒ\}}|s¢tjd||fƒdStj||||tdƒ| }tjd|||f|ƒ|jt j |ƒtj|ƒj|ƒtj|tjdƒt j!|tj"ƒt#j$|t j%dƒt&j'|ƒdS(    NRPsDÇëÇóÎ佫Éý¼¶: itemIndex=%s,heroID=%s,heroLV=%s,quality=%s,breakLV=%st HeroQualityLVis*²»´æÔÚ¸ÃÎ佫µÈ¼¶: quality=%s,nextHeroLV=%ss7²ÄÁϲ»×㣬Î佫ÎÞ·¨Éý¼¶! costItemID=%s, costItemCount=%stHeroLVUPs-Î佫Éý¼¶: itemIndex=%s,heroID=%s,updHeroLV=%s((RtGetPlayerManagertGetPlayerByIndexRt    ItemIndexRRRRRSRTR@R#RBR?Rt GetUPCostItemRRRtrptItemt
ItemCommontGetItem_FromPack_ByIDt
ReduceItemtTrueR>RrRsRttPlayerActivitytAddDailyTaskValueRtDailyTask_HeroLVUPt
PlayerTaskt AddTaskValuetTaskType_HeroLVUPt PlayerSuccesstDoAddSuccessProgresstSuccType_OSAHeroLVUPRuRv(Rit
clientDatattickRtplayerIDRŽRwR;RaRbtbreakLVtheroLVtqualityLVIpyDatat
nextHeroLVt costItemInfot
costItemIDt costItemCounttitemPackt    hasEnought itemIndexListt    updHeroLV((siD:\SG_ServerCode\ServerPython\ZoneServerGroup\map1_8G\MapServer\MapServerData\Script\Player\PlayerHero.pyt
OnHeroLVUPsV           
   cCsd|jƒ}tjd|ƒ}|s(dS|jƒ}tjdi|d6tƒ}|sZdSt|ƒS(NRPiR–tQuality(RRRRSRTtGetIpyGameDataByConditionR tlen(RwR;RaRbt lvIpyDataList((siD:\SG_ServerCode\ServerPython\ZoneServerGroup\map1_8G\MapServer\MapServerData\Script\Player\PlayerHero.pyt GetHeroLVMaxIs  c CsÊtjƒj|ƒ}|jƒ}|j}|j}t||ƒ}t||ƒ}| sk| sk||krodS|jƒ}    |jƒ}
tjd||    ||
f|ƒ|    |
krÇtjd|ƒdS|j    ƒrñtjd||    f|ƒdS|j
t j ƒ} | r'tj d||    f|ƒdS|j
t jƒ} | r]tj d||    f|ƒdS|jt jƒ} | rtjd| |ƒdS|jt jƒ}|jt jƒ}|dksÃ|rátjd||f|ƒdStjd    |    ƒ}|sýdS|jƒ}|jt jƒ}|jt jƒ}t|    |ƒ}tjd
|    ||||f|ƒ||krƒtjd ||ƒdS|jt jƒ}|d}||}tjd ||    ||||f|ƒtj|||jƒtd ƒt|||ƒtj|ƒj|ƒtjd|ƒ}|r¹tj ddƒ}g}|j!ƒ}xD|D]<\}}t"dt#||dƒƒ}|j$||gƒqWWt%j&||ddtigƒnt'j(|ƒdS(NsAÇëÇóÎ佫ÉýÐÇ: itemIndex=%s,heroID=%s,useItemIndex=%s,useHeroID=%ssÎ佫²ÄÁϷDZ¾Ì壬ÎÞ·¨ÉýÐÇ!s1²ÄÁÏ¿¨Ëø¶¨ÖУ¬ÎÞ·¨ÉýÐÇ! useItemIndex=%s,heroID=%ss4Î佫ϴÁ¶½á¹ûδ´¦Àí£¬ÎÞ·¨ÉýÐÇ! itemIndex=%s,heroID=%ss8Î佫¾õÐѽâËøÌ츳δѡÔñ£¬ÎÞ·¨ÉýÐÇ! itemIndex=%s,heroID=%ss.²ÄÁÏ¿¨¾õÐѵȼ¶²»Îª0ÔÝʱÎÞ·¨ÉýÐÇ£¡useAwakeLV=%sis:²ÄÁÏ¿¨ÒÑÉý¼¶»òÍ»ÆÆÔÝʱÎÞ·¨ÉýÐÇ£¡useHeroLV=%s,useBreakLV=%sRPs2heroID=%s,star=%s,quality=%s,awakeLV=%s,starMax=%ss¸ÃÎ佫ÒÑÂúÐÇ£¡starMax=%ssIÎ佫ÉýÐÇ: itemIndex=%s,heroID=%s,star=%s,useStar=%s,addStar=%s,updStar=%st
HeroStarUPRQt HeroRebirthigY@teventtHeroStarUPReturn()RR˜R™RRšt UseItemIndexRRRRt GetIsLockedRFR#RKtErrLogRLR@RCR?RBRRSRTRAtGetHeroStarMaxRtDelItemRR6t DoHeroUpdStarRrRsRtt
GetFuncCfgtGetDismissReturnItemstmaxtintR]R%tGivePlayerItemOrMailRuRv(RiRªR«RR¬RŽt useItemIndexRwtuseItemR;t    useHeroIDt    washIDCntt awakeRandCntt
useAwakeLVt    useHeroLVt
useBreakLVRaRbRŠtawakeLVtstarMaxtuseStartaddStartupdStarRctratiotreturnItemListtdismissReturnItemstitemIDt    itemCountt    returnCnt((siD:\SG_ServerCode\ServerPython\ZoneServerGroup\map1_8G\MapServer\MapServerData\Script\Player\PlayerHero.pyt OnHeroStarUP]s‚                  # 
 
     " c Csçtjd|ƒ}|sdS|jƒ}tjd|ƒ}|sDdS|jƒ}d}|rq|jtjƒ}n|dkr|Sd}tjd|ƒ}|rÙx7|D],}    |    jƒ|krÂPn||    j    ƒ7}q¦Wn||}
|
S(NRPiRQiŸ†t    HeroAwake(
RRSRTtGetInitStarUpperR@R#RCtGetIpyGameDataListNotLogt
GetAwakeLVtGetAddStarUpper( R;RwRaRbRct InitStarUpperRÕt addStarUppertheroAwakeIpyDataListtipyDataRÖ((siD:\SG_ServerCode\ServerPython\ZoneServerGroup\map1_8G\MapServer\MapServerData\Script\Player\PlayerHero.pyRÅ¥s,    
c    Csô|jƒ}t|ƒ}||krD|}tjd||fƒn|jtjƒ}||}|jƒ}|jtj|ƒ|dkrÝt    ||ƒt
j |t j |ƒtj|t j|ƒtj|tj|ƒn|rð|jƒndS(Ns3²»³¬¹ý°æ±¾×î´óÎ佫ÐǼ¶: heroID=%s,versionStarMax=%si(RRRÅRRR@R#RAtGetItemR>t__DoHeroStarTalentUpR¡R¢RtDailyTask_HeroStarUPR¤R¥tTaskType_HeroStarUPR§R¨tSuccType_OSAHeroStarUPt    Sync_Item(    RRwRÙtisSyncR;tversionStarMaxtcurStarRØtitem((siD:\SG_ServerCode\ServerPython\ZoneServerGroup\map1_8G\MapServer\MapServerData\Script\Player\PlayerHero.pyRÇÄs"   
    c CsK|jƒ}tjddƒ}tjddƒ}|}tjd|ƒ}|r§|jtjƒ}xD|| ddd…D](}|jƒ}    |    rx|    rx|    }PqxqxWn|jtj    ƒ}
|jtj
ƒ} gg} } g}g}t }x™t t |
| ƒƒD]‚}|jtj    |ƒ}|jtj
|ƒ}| j|ƒ| j|ƒ||kr|j|ƒ||kr‚|j|ƒq‚qqWt| ƒ|krÑ| dg|t| ƒ7} | dg|t| ƒ7} ntjd|ƒtjd| | |fƒtjd    ||fƒd| kr’i}g}tjƒ}xpt |jƒƒD]\}|j|ƒ}|jƒ}|| kr}qJn|jƒ}|j||gƒ|||<qJWtjd
|ƒxÔt |ƒD]Ã}d| krÞPntj|ƒ}|sùqÈn|j|dƒ|g}||kr-|j|ƒn| jdƒ}|| |<d| |<|j|ƒ|j|ƒtjd |ƒ|d8}t}qÈWn|dkrµxt |ƒD]}|s»Pn|rÐtj|ƒn tj|ƒ}|| krñq«n| j|ƒ}| |}||krG|d7}|| |<tjd |||fƒn||kr¨||kro|j|ƒn||kr‹|j|ƒntjd |||fƒnt}q«Wn|s¿dStjd| | fƒ|jtj    ƒ|jtj
ƒxNt | ƒD]@\}}|sPn|j!tj    |ƒ|j!tj
| |ƒqWdS(NtHeroStarTalentiiRáiÿÿÿÿis"Ö´ÐÐÎ佫ÐǼ¶Ì츳µÈ¼¶ÌáÉý: addLV=%ss2µ±Ç°ÐǼ¶Ì츳: idList=%s,lvList=%s,maxUnlockSlot=%ss,δÂú¼¶ÐǼ¶Ì츳ID: %s,unfullLVIDListUnlock=%ss³£¹æ¿Õ²ÛλÔö¼ÓÌ츳Êý£º%ssÐÂÔöÐǼ¶Ì츳ID: %ss#Éý¼¶ÐǼ¶Ì츳ID: %s,idLV=%s,index=%ss<    ÒƳýÂú¼¶ID: %s,unfullLVIDList=%s,unfullLVIDListUnlock=%ss!¸üÐÂÐǼ¶Ì츳: idList=%s,lvList=%s("RRRRÈRãR@R#RCtGetUnlockTalentSlotRFRGRIR6RXR…R‘R]R»RRRWRYRZR[t GetWashWeightRVR^R_RiR trandomtchoiceRHt    enumerateR`( RNtaddLVR;tcommTalentSlott talentMaxLVt maxUnlockSlottawakeIpyDataListRÕRétunlockTalentSlottidCounttlvCounttidListtlvListtunfullLVIDListtunfullLVIDListUnlockthaveUpRiRkttalentLVt idWeightDictRgRhRjtweightRmRnRot    zeroIndextrandIDt    randIndextidLV((siD:\SG_ServerCode\ServerPython\ZoneServerGroup\map1_8G\MapServer\MapServerData\Script\Player\PlayerHero.pyRëÝs¼                 
 
 
  $ 
 
 
    cCsšd}|jƒjtjƒ}xut|jƒƒD]a}|j|ƒ}| s1|jƒr_q1n||jƒkrwq1nt    |j
tj ƒ|ƒ}q1W|S(Ni( RRR#R2RXRR!R"RRRÊR@RA(RR;RÖR7RiRw((siD:\SG_ServerCode\ServerPython\ZoneServerGroup\map1_8G\MapServer\MapServerData\Script\Player\PlayerHero.pyt GetHeroIDStarOscCs}d}|jƒjtjƒ}xXt|jƒƒD]D}|j|ƒ}| s1|jƒr_q1n||jtj    ƒ7}q1W|S(Ni(
RRR#R2RXRR!R"R@RA(Rt    totalStarR7RiRw((siD:\SG_ServerCode\ServerPython\ZoneServerGroup\map1_8G\MapServer\MapServerData\Script\Player\PlayerHero.pytGetHeroStarTotal\scCsotj|tjgƒ}t|ƒ}||}|dkr>dStjd||fƒtj|tj|ƒdS(Nis5ÉÏÏßÐÞÕýÇìµäÎ佫ÉýÐdzɾͽø¶È! addStar=%s,starTotal=%s(R§t GetSuccValueR#RîRRtLogR¨(Rt osaHeroStart    starTotalRØ((siD:\SG_ServerCode\ServerPython\ZoneServerGroup\map1_8G\MapServer\MapServerData\Script\Player\PlayerHero.pyR gs 
 cCs'tjƒj|ƒ}|jƒ}|j}t||ƒ}|sCdS|jƒ}tjd|ƒ}|skdS|j    ƒ}    |j
t j ƒ}
|j
t j ƒ} tjd|||    |
| f|ƒtjd|    | ƒ} | sÝdS| jƒ} |
| krtjd|
| f|ƒdS| d}tjd|    |ƒsPtjd|    | f|ƒdS| jƒ}|sfdS|jƒjtjƒ}tj||ƒ\}}|r½tjd|    | |f|ƒdStj|||dƒtjd    |||f|ƒt|||ƒtj|ƒj|ƒtj|ƒdS(
NRPsDÇëÇóÎä½«Í»ÆÆ: itemIndex=%s,heroID=%s,quality=%s,heroLV=%s,breakLV=%stHeroQualityBreaks&Î佫µÈ¼¶²»×㣬ÎÞ·¨Í»ÆÆ: heroLV=%s < %sis%Í»ÆÆµÈ¼¶ÒÑÂú¼¶: quality=%s,breakLV=%ss=²ÄÁϲ»×㣬Î佫ÎÞ·¨Í»ÆÆ! quality=%s,breakLV=%s,lackItemDict=%st    HeroBreaks/Îä½«Í»ÆÆ: itemIndex=%s,heroID=%s,nextBreakLV=%s(RR˜R™RRšRRRRRSRTR@R#R?RBRt GetUPLVNeedtGetUPCostItemListRRRRœRtGetCostItemIndexListt DelCostItemtSetHeroBreakLVRrRsRtRuRv(RiRªR«RR¬RŽRwR;RaRbR®R­RétUPLVNeedt nextBreakLVt costItemListR´t lackItemDictt delInfoDict((siD:\SG_ServerCode\ServerPython\ZoneServerGroup\map1_8G\MapServer\MapServerData\Script\Player\PlayerHero.pyt OnHeroBreakysP             
  cCs6|jƒ}|jtj|ƒ|r2|jƒndS(N(RêR>R#RBRï(RRwR­RðRó((siD:\SG_ServerCode\ServerPython\ZoneServerGroup\map1_8G\MapServer\MapServerData\Script\Player\PlayerHero.pyR¥s
  c    Csltjƒj|ƒ}|jƒ}|j}t||ƒ}|sCdS|jƒ}tjd|ƒ}|skdS|j    ƒ}    |j
t j ƒ}
|j
t j ƒ} tjd|||    | |
f|ƒtjddƒ} tjddƒ} |
| ksú|
| krtjd|
| | f|ƒdStjd|    | ƒ}|s:dS| d}tjd|    |ƒswtjd|    | f|ƒdS|jƒ}|sdS|\}}| s§| r«dS|jƒjtjƒ}tj|||ƒ\}}|sÿtjd    ||fƒdStj||||td
ƒtjd |||f|ƒt||ƒtj|ƒj|ƒtj|ƒdS( NRPsDÇëÇóÎ佫¾õÐÑ: itemIndex=%s,heroID=%s,quality=%s,awakeLV=%s,starLV=%sRôiis$µ±Ç°ÐǼ¶²»¿É¾õÐÑ: starLV=%s < %s, %stHeroQualityAwakes%¾õÐѵȼ¶ÒÑÂú¼¶: quality=%s,awakeLV=%ss7²ÄÁϲ»×㣬Î佫ÎÞ·¨¾õÐÑ! costItemID=%s, costItemCount=%sRás/Î佫¾õÐÑ: itemIndex=%s,heroID=%s,nextAwakeLV=%s(RR˜R™RRšRRRRRSRTR@R#RARCRRÈR›RRRRœRRžRŸR tSetHeroAwakeLVRrRsRtRuRv(RiRªR«RR¬RŽRwR;RaRbtstarLVRÕtawakeLimitStarRûRét nextAwakeLVR±R²R³R´RµR¶((siD:\SG_ServerCode\ServerPython\ZoneServerGroup\map1_8G\MapServer\MapServerData\Script\Player\PlayerHero.pyt OnHeroAwake¹sX           
    cCs@|jƒ}|jtj|ƒt|ƒ|r<|jƒndS(N(RêR>R#RCtunlockTalentSlotByAwakeRï(RwRÕRðRó((siD:\SG_ServerCode\ServerPython\ZoneServerGroup\map1_8G\MapServer\MapServerData\Script\Player\PlayerHero.pyR#ès  
 cCsl|jƒ}|jtjƒ}tjd|ƒ}|s:dSd}x;|| ddd…D]"}|jƒ}|rX|}PqXqXW|sˆdS|jtjƒ}||krªdStj    ddƒ}||krÌdS|jtj
ƒ}    |    rèdSg}
x6t |ƒD](} |j tj| ƒ} |
j | ƒqûWtjd|||
fƒi} g}tjƒ}xpt |jƒƒD]\} |j| ƒ}|jƒ} | |
krŸqln|jƒ}|j || gƒ|| | <qlWtj    ddƒ}x‡t |ƒD]y}tj|ƒ}|s qën| j|dƒ|g}||kr@|j|ƒn|jtj
|ƒtjd|ƒqëWdS(    NRáiiÿÿÿÿRôis5¾õÐѽâËøÌ츳²Û: awakeLV=%s,maxUnlockSlot=%s,idList=%sis!Ëæ»ú¾õÐÑÌ츳ѡÏî: randTalentID=%s(RRR@R#RCRRãRõRFRGRÈRLRXR‘R]RRRWRYRZR[tGetAweakWeightRVR^R_R`(RNR;RÕRþRýRéRÿRRûRÑRRiRkRRgRhRjR    t randTalentCntRmRnRo((siD:\SG_ServerCode\ServerPython\ZoneServerGroup\map1_8G\MapServer\MapServerData\Script\Player\PlayerHero.pyR(ñsb         cCs;tjƒj|ƒ}|j}|j}t|||ƒdS(N(RR˜R™Ršt SelectIndextdoSelectAwakeTalent(RiRªR«RRŽt selectIndex((siD:\SG_ServerCode\ServerPython\ZoneServerGroup\map1_8G\MapServer\MapServerData\Script\Player\PlayerHero.pytOnHeroAwakeSelectTalent6s
        cCsê|jƒ}t||ƒ}|s%dS|jƒ}|jtjƒ}| sV||krwtjd|||f|ƒdS|jtj|ƒ}|s–dS|j    ƒ}    |    jtj
ƒ}
|    jtj ƒ} gg} } xat t |
| ƒƒD]J}|    jtj
|ƒ}|    jtj |ƒ}| j|ƒ| j|ƒqéW|| krgtjd|||| f|ƒdStjddƒ}tjddƒ}t| ƒ}
tjd||| | fƒ|
|kr| dg||
7} | dg||
7} d}tjdƒntjd    |ƒ}|sdS|jƒ}tjd
|ƒ}|sDdS|jƒ}tjd |ƒ}|sldSd}||7}x4|D],}|
|jƒkrŸPn||jƒ7}qƒW|jtjƒ}tjd |
||fƒ||}tdt |d|ƒƒ}| j|ƒ| j|ƒ|    jtjƒtjd ||| | fƒ|    jtj
ƒ|    jtj ƒxDt| ƒD]6\}}|    jtj
|ƒ|    jtj | |ƒqyWt|    ƒ|rÐ|j ƒnt!j"|ƒj#|ƒdS(NsB²»´æÔڸþõÐÑÌì¸³Ëæ»úÑ¡Ïî! heroID=%s,selectIndex=%s,awakeRandCnt=%ssDÑ¡ÔñÌ츳ID²»ÄÜÖØ¸´! heroID=%s,selectIndex=%s,selectTalentID=%s in %sRôiis9Ñ¡ÔñÌ츳: heroID=%s,selectTalentID=%s,idList=%s,lvList=%sis'³£¹æ²Ûλδȫ²¿½âËø£¬¾õÐѲÛλĬÈÏ1¼¶Ì츳RPRQRás;³£¹æ²ÛλÒÑÈ«²¿½âËø, idCount=%s,preSlotStarMax=%s,curStar=%ss7selectTalentID=%s,selectTalentLV=%s,idList=%s,lvList=%s($RRRRRFR#RLRRR‘RêRGRIRXR…R]RÄRRÈR»RSRTRâRãRõRåR@RARÊRHRùR`R(RïRrRsRt(RRŽR-RðR¬RwR;RÑtselectTalentIDRNRRRRRiRkRRûRütselectTalentLVRaRbRcRæRètpreSlotStarMaxRéRòt overflowStar((siD:\SG_ServerCode\ServerPython\ZoneServerGroup\map1_8G\MapServer\MapServerData\Script\Player\PlayerHero.pyR,=sŠ              
 
 
 cCsžtjƒj|ƒ}|j}|j}|j}t||ƒ}|sIdS|dkrht|||ƒn2|dkr‡|jt    j
ƒnt ||||ƒdS(Nii( RR˜R™RštLockTalentIndexstOPTypeRtHeroTalentWashReplaceRHR#RKtHeroTalentWash(RiRªR«RRŽtlockTalentIndexstopTypeRw((siD:\SG_ServerCode\ServerPython\ZoneServerGroup\map1_8G\MapServer\MapServerData\Script\Player\PlayerHero.pyt
OnHeroWashšs              cCsæ|jƒ}tjd|||fƒ|jtjƒ}|rStjd|ƒdStjddƒ}tj    ddƒ}|sdS|j
ƒ}|jtj ƒ}    xH|ddd…D]3}
|
|    kr³|j |
ƒtjd|
ƒq³q³Wt |ƒ} t |ƒ| kr|| n|d} tjd|| |fƒ|jƒjtjƒ} tj|| | ƒ\}}|sŠtjd    || fƒdStj|| || td
ƒg}xRt|    ƒD]D}||krð|jtj |ƒ}|j|ƒq¹|jd ƒq¹Wtjd |ƒi}g}tjƒ}xpt|jƒƒD]\}|j|ƒ}|jƒ}||krpq=n|jƒ}|j||gƒ|||<q=Wxt|ƒD]q\}}|rÂqªntj|ƒ}|sÝqªn|j |d ƒ|g}||kr|j |ƒn|||<qªWtjd |ƒ|j!tjƒx!|D]}|j"tj|ƒqGW|j!tj#ƒx!|D]}|j"tj#|ƒq{W|j$ƒtjd||||fƒt%j&|tj'| ƒt%j(|ƒdS(Ns4Î佫ϴÁ¶: itemIndex=%s,heroID=%s,lockTalentIndexs=%ss*Î佫ϴÁ¶½á¹ûδ´¦Àí£¬ÎÞ·¨Ï´Á¶! washIDCnt=%stHeroWashiiiÿÿÿÿs"È¥³ý²»´æÔÚµÄËø¶¨Ë÷Òý: lockIndex=%ss6washItemID=%s,washCostItemCount=%s,lockTalentIndexs=%ss>Ï´Á¶²ÄÁϲ»×㣬Î佫ÎÞ·¨Ï´Á¶! washItemID=%s,washCostItemCount=%sR6is
Ï´Á¶Ç°: %ss
Ï´Á¶ºó: %ssFÎ佫ϴÁ¶½á¹û! itemIndex=%s,heroID=%s,washIDList=%s,lockTalentIndexs=%s()RRRRRFR#RKRÄRRÈRRêRGR_R»RRRRœRRžRŸR RXR‘R]RWRYRZR[RöRùRVR^RHR`RJRïRut AddOSAValuetDef_BT_OSA_HeroTrainRv(RRŽRwR7R;RÐt
washItemIDtlockCostItemListRNRt    lockIndextlockCnttwashCostItemCountR´RµtwashItemIndexListt
washIDListRiRkRRgRhRjR    RnRo((siD:\SG_ServerCode\ServerPython\ZoneServerGroup\map1_8G\MapServer\MapServerData\Script\Player\PlayerHero.pyR6­s„     &        
     c    Csû|jƒ}|jƒ}|jtjƒ}|sKtjd||fƒdSg}|jtjƒxIt    |ƒD];}|j
tj|ƒ}|j |ƒ|j tj|ƒqnW|jtjƒ|j ƒtjd|||fƒtj|ƒj|ƒdS(Ns.Î佫ûÓÐÏ´Á¶²»ÐèÒªÌæ»»! itemIndex=%s,heroID=%ss2Î佫ϴÁ¶Ìæ»»! itemIndex=%s,heroID=%s,washIDList=%s(RRRêRFR#RKRRÄRHRGRXR‘R]R`RïRRrRsRt(    RRŽRwR;RNRRCRiRk((siD:\SG_ServerCode\ServerPython\ZoneServerGroup\map1_8G\MapServer\MapServerData\Script\Player\PlayerHero.pyR5ÿs"   
c Cs tjƒj|ƒ}|j}|j}|j}|j}tjd|ƒ}|sUdS|j    ƒ}    ||    kr‹tj
d|||    fƒdS|    j |ƒ}
|dkr¹t |||ƒnc|dkrÛt |||
tƒnA|dkrút|||ƒn"|dkrt |||
tƒndS(NRPs+²»´æÔÚ¸ÃÆ¤·ô! heroID=%s,skinID=%s not in %siiii(RR˜R™tHeroIDtSkinIDR4RšRRSt GetSkinIDListRRitActiveHeroSkintDoHeroWearSkinR6tDoHeroSkinStarUPR ( RiRªR«RR;RƒR8RŽRat
skinIDListt    skinIndex((siD:\SG_ServerCode\ServerPython\ZoneServerGroup\map1_8G\MapServer\MapServerData\Script\Player\PlayerHero.pyt OnHeroSkinOP"s,                      c
CsIt||ƒ}|sdS|jƒ}tjd|ƒ}|sAdS|jƒ}|dkr½|t|ƒkr†tjd||fƒdS||}t||ƒs½tjd||fƒdSntjd|||fƒ|j    ƒ}    |sÿ|    j
t j |ƒn<|    j
t j |ƒ|    j
t j |ƒtj|ƒj|ƒ|jƒtS(NRPis*¸ÃÎ佫²»´æÔÚ¸ÃÆ¤·ô! heroID=%s,skinIndex=%ss(¸ÃÎ佫Ƥ·ôδ½âËø! heroID=%s,skinIndex=%ss2Çл»Î佫Ƥ·ô! heroID=%s,skinIndex=%s,isSkinAttr=%s(RRRRRSRFR»RRR„RêR>R#RDRERrRsRtRïR (
RRŽRKt
isSkinAttrRwR;RaRJRƒRó((siD:\SG_ServerCode\ServerPython\ZoneServerGroup\map1_8G\MapServer\MapServerData\Script\Player\PlayerHero.pyRH<s2   
 
cCsftjd|ƒ}|sdS|jƒ}| sAt|ƒ|krEdS||}t||||ƒdS(NRP(RRSRFR»t__onHeroSkinActive(RR;RKtisActiveRaRJRƒ((siD:\SG_ServerCode\ServerPython\ZoneServerGroup\map1_8G\MapServer\MapServerData\Script\Player\PlayerHero.pyt GMSetHeroSkin[s 
c
Cstjd|ƒ}|sdSt||ƒrFtjd||fƒdS|jƒ}d}tj|||ƒ\}}}|||}    |    dkr±tjd||||    fƒdStj|||||dƒtjd||f|j    ƒƒt
|||dƒdS(Nt HeroSkinAttrs)¸ÃÎ佫Ƥ·ôÒѾ­¼¤»îÁË: heroID=%s,skinID=%siisG¼¤»îÎ佫ʱװÎïÆ·²»×ã! heroID=%s,needItemID=%s,needItemCnt=%s,lackCnt=%stHeroSkins!¼¤»îÎ佫Ƥ·ô: heroID=%s,skinID=%s( RRSR„RRt GetNeedItemIDRtGetPackItemBindStateIndexInfotDelCostItemByBindRRN(
RR;Rƒt skinIpyDatat
needItemIDt needItemCnttcostItemIndexListtbindCntt    unBindCnttlackCnt((siD:\SG_ServerCode\ServerPython\ZoneServerGroup\map1_8G\MapServer\MapServerData\Script\Player\PlayerHero.pyRGfs"   cCs.t|||ƒt||gƒt|ƒdS(N(RˆRtRefreshLordAttr(RR;RƒRO((siD:\SG_ServerCode\ServerPython\ZoneServerGroup\map1_8G\MapServer\MapServerData\Script\Player\PlayerHero.pyRNys
cCs‘|jƒ}t||ƒs9tjd||f|ƒdStjd|ƒ}|sUdS|jƒ}t||ƒ}||kr tjd||||f|ƒdS|jƒ}d}| sÀ| rÄdSt    j
|||ƒ\}    }
} ||
| } | dkr tjd||||| fƒdSt    j ||    |
| |dƒ|d} tjd||| f|ƒt ||| ƒt ||gƒt|ƒdS(    Ns%¸ÃÎ佫ʱװδ¼¤»î! heroID=%s,skinID=%sRQs6Î佫ʱװÐǼ¶ÒÑÂú! heroID=%s,skinID=%s,curStar=%s >= %siisQÎ佫ʱװÉýÐÇÎïÆ·²»×ã! heroID=%s,skinID=%s,needItemID=%s,needItemCnt=%s,lackCnt=%sRPs-Î佫ʱװÉýÐÇ! heroID=%s,skinID=%s,nextStar=%s(RR„RRRRSt
GetStarMaxR‰RSRRTRUR‹RR](RR;RƒR¬RVRÖRòRWRXRYRZR[R\tnextStar((siD:\SG_ServerCode\ServerPython\ZoneServerGroup\map1_8G\MapServer\MapServerData\Script\Player\PlayerHero.pyRIs8       
 
cCsVtjƒj|ƒ}|j}|j}|dkr6n|dkrEn t||ƒdS(Nii(RR˜R™RDtBookTypet__doHeroBookAct(RiRªR«RR;tbookType((siD:\SG_ServerCode\ServerPython\ZoneServerGroup\map1_8G\MapServer\MapServerData\Script\Player\PlayerHero.pyt OnHeroBookUP¨s           cCsd}tjƒ}xft|jƒƒD]R}|j|ƒ}|jƒ}|jƒsXq%nt||ƒsmq%n|d7}q%W|S(Nii(RRWRXt GetHeroCounttGetHeroByIndext    GetHeroIDtGetPlayerCanUseR€(RtbookCntRhRiRéR;((siD:\SG_ServerCode\ServerPython\ZoneServerGroup\map1_8G\MapServer\MapServerData\Script\Player\PlayerHero.pytGetHeroBookActCntµs   c
    Cso|jƒ}t||ƒr3tjd||ƒdStjd||ƒtjd|ƒ}|scdS|jƒ}tjd|ƒ}|s‹dSt||ƒdkr¸tjd||ƒdSt||dƒ|j    ƒ}|r&t
|ƒdkr&|\}}|r&|r&t j |||dd    t ƒq&nt||gƒt|ƒ}    tj|tjƒtj|tj|    ƒdS(
Ns¸ÃÎ佫ͼ¼øÒѼ¤»î! heroID=%ssÎ佫ͼ¼ø¼¤»î! heroID=%sRPRQis%Î佫δ»ñµÃ¹ý£¬²»¿É¼¤»îͼ¼ø! heroID=%sit HeroBookActt notifyAward(RR€RRRRSRTRpRtGetBookActAwardMoneyR»Rt    GiveMoneyR RRiR¤t UpdTaskValueRtTaskType_HeroBookR§tUptateSuccessProgressR#tSuccType_OSAHeroBook(
RR;R¬RaRbRctawardMoneyInfot    moneyTypet
moneyValueRh((siD:\SG_ServerCode\ServerPython\ZoneServerGroup\map1_8G\MapServer\MapServerData\Script\Player\PlayerHero.pyRaÃs4     " cCs]tjƒj|ƒ}|j}|j}t||ƒ}|s@dS|j|rRdndƒdS(Nii(RR˜R™RštIsLockRt SetIsLocked(RiRªR«RRŽtisLockRw((siD:\SG_ServerCode\ServerPython\ZoneServerGroup\map1_8G\MapServer\MapServerData\Script\Player\PlayerHero.pyt
OnHeroLockës        cCs.tjƒj|ƒ}|j}|j}|jp3|}|j}t||ƒ}|sXdS|jt    j
ƒ}    |jt    j ƒ}
|jt    j ƒ} |    dkr½|
r½| r½tj d|ƒdS|r| r|jtjƒ} tjddƒ} | r| | krtj d| | fƒdSn|jƒ}tjd|ƒ}|sEdS|jƒ}d}d}d}tjddƒ}|r±| r±tjd|| ƒ}|r¨|jƒnd}n|ráttdttjdd    ƒƒƒƒ}n|rttdttjd
dƒƒƒƒ}n|||}tj d ||||    |
| |||||||f ƒ|r}|r}tj|||ƒ r}dStjdd ƒ}i}|r±t||    ||ƒn|rÍt||
||ƒn|rét || ||ƒn|r|rtj!|||dƒ rdS|j"ƒ}|r:|j#t    j
dƒn|rV|j#t    j dƒn|rr|j#t    j dƒn|j$ƒ|rÏg|j%ƒD]\}}||g^q}t&j'||d dt(igƒn|r| r|jtjƒ} tj)|tj| dƒt*|ƒnt+j,|ƒj-|ƒdS(Nis8¸ÃÎ佫δ½øÐйýµÈ¼¶Í»ÆÆ¾õÐÑÅàÑø£¬²»ÐèÒªÖØÉú! itemIndex=%sR¿is5½ñÈÕ¾õÐѹýµÄÎ佫֨Éú´ÎÊýÒÑ´ïÉÏÏÞ! rebirthCnt=%s >= %sRPiR"it HeroRebirth2s•Î佫֨Éú: itemIndex=%s,heroID=%s,quality=%s,heroLV=%s,breakLV=%s,awakeLV=%s,costMoneyTotal=%s(lv:%s+b:%s+a:%s),lvReset=%s,breakReset=%s,awakeReset=%siRÀ(.RR˜R™RštLVResett
BreakResett
AwakeResetRR@R#R?RBRCRRRRRRÈRRRSRTtGetIpyGameDataNotLogtGetRebirthCostMoneyRËRÊtevaltGetFuncCompileCfgRt    HaveMoneyt__calcHeroLVReturnitemt__calcHeroBreakReturnitemt__calcHeroAwakeReturnitemtPayMoneyRêR>RïRR%RÌR6RRRrRsRt(RiRªR«RRŽtlvResett
breakResett
awakeResetRwR®R­RÕt
rebirthCntt rebirthCntMaxR;RaRbt lvCostMoneytbreakCostMoneytawakeCostMoneyRstqualityAwakeIpyDatatcostMoneyTotalRÚtreturnItemDictRótktvRÛ((siD:\SG_ServerCode\ServerPython\ZoneServerGroup\map1_8G\MapServer\MapServerData\Script\Player\PlayerHero.pyt OnHeroRebirthÿsˆ                **    /"% 
+"  c
CsÚi}x­td|ƒD]œ}tjd||ƒ}|s=qn|jƒ}|sUqn|\}}    tdt|    |dƒƒ}    |j|dƒ|    ||<|j|dƒ|    ||<qWtjd|||||fƒdS(NiR–gY@is3    µÈ¼¶·µ»¹: quality=%s,heroLV=%s,ratio=%s,%s,×Ü%s(    RXRRSR›RÊRËR^RR(
RbR®RRÚt
returnDicttretLVR¯R±R²R³((siD:\SG_ServerCode\ServerPython\ZoneServerGroup\map1_8G\MapServer\MapServerData\Script\Player\PlayerHero.pyR‚Ss   c
Csåi}x¸td|ƒD]§}tjd||ƒ}|s=qn|jƒ}|sUqnxe|D]]\}}    tdt|    |dƒƒ}    |j|dƒ|    ||<|j|dƒ|    ||<q\WqWtjd|||||fƒdS(NiRigY@s4    Í»ÆÆ·µ»¹: quality=%s,breakLV=%s,ratio=%s,%s,×Ü%s(    RXRRSRRÊRËR^RR(
RbR­RRÚR”t
retBreakLVtqualityBreakIpyDataRR²R³((siD:\SG_ServerCode\ServerPython\ZoneServerGroup\map1_8G\MapServer\MapServerData\Script\Player\PlayerHero.pyRƒds " c
CsÚi}x­td|ƒD]œ}tjd||ƒ}|s=qn|jƒ}|sUqn|\}}    tdt|    |dƒƒ}    |j|dƒ|    ||<|j|dƒ|    ||<qWtjd|||||fƒdS(NiR"igY@s4    ¾õÐÑ·µ»¹: quality=%s,awakeLV=%s,ratio=%s,%s,×Ü%s(    RXRRSR›RÊRËR^RR(
RbRÕRRÚR”t
retAwakeLVRŽR±R²R³((siD:\SG_ServerCode\ServerPython\ZoneServerGroup\map1_8G\MapServer\MapServerData\Script\Player\PlayerHero.pyR„us   c Cs®tjƒj|ƒ}|j}tjd|ƒtjddƒ}g}i}|jƒjt    j
ƒ}x¯|D]§}    |    dksl|    |j ƒkr–qln|j |    ƒ}
|
sl|
j ƒr¾qln|
jt    jƒ} | rótjd|    | fƒqln|
jƒrtjd|    ƒqln|
jt    jƒ} | rygt| ƒD]} |
jt    j| ƒ^q;}tjd|    |fƒqln|
jƒ}t|
ƒ}|r·tjd|    ||fƒqlntjd    |ƒ}|sÕqln|jƒ}|
jt    jƒ}|
jt    jƒ}|
jt    jƒ}tjd
|ƒ}|s5qlntjd |    |||||fƒ|jƒ}xS|D]K\}}td t|d ||d ƒƒ}|j|dƒ|||<qkWtjd|||||fƒt ||||ƒt!||||ƒ|j"|    |
gƒqlW|s!dSx3|D]+\}    }
t#j$||
|
j ƒt%dƒq(W|rªg|j&ƒD]\}}||g^qj}t'j(||ddt%igƒndS(NsÎ佫Dzɢ: itemIndexList=%sR¿iis7¾õÐѹýµÄÎ佫ÐèÏÈÖØÉúºó²Å¿ÉDzɢ! itemIndex=%s,awakeLV=%ss Ëø¶¨µÄÎ佫ÎÞ·¨Ç²É¢! itemIndex=%ss5ÉÏÕóÖеÄÎ佫ÎÞ·¨Ç²É¢! itemIndex=%s,lineupValueList=%ss?ÉúЧÖеĿ¨ÅÆÎÞ·¨Ç²É¢! itemIndex=%s,heroID=%s,effPresetIDList=%sRPRQsHDzɢ: itemIndex=%s,heroID=%s,quality=%s,heroLV=%s,breakLV=%s,heroStar=%sigY@s5    ÐǼ¶·µ»¹: quality=%s,heroStar=%s,ratio=%s,%s,×Ü%st HeroDismissRÀ()RR˜R™t ItemIndexListRRRÈRRR#R2RR!R"R@RCRÃRFR4RXR‘RRR•RSRTR?RBRARÉRÊRËR^R‚RƒR]RRÆR6RR%RÌ(RiRªR«RR¶RÚtdismissItemListRR7RŽRwRÕt lineupCountR”tlineupValueListR;R“RaRbR®R­theroStarRcRÜRÝRÞt
starRetCntR‘R’RÛ((siD:\SG_ServerCode\ServerPython\ZoneServerGroup\map1_8G\MapServer\MapServerData\Script\Player\PlayerHero.pyt OnHeroDismissŽsr      .   # % #+"c Cswtjƒj|ƒ}|j}d}|j}i}x*|D]"}|j}    |j}
|    ||
<q:Wt||||ƒdS(Ni(RR˜R™tPresetIDt HeroPosListtPosNumRštDoSaveHeroPreset( RiRªR«RR9R:t heroPosListtitemIndexPosDicttposInfoR<RŽ((siD:\SG_ServerCode\ServerPython\ZoneServerGroup\map1_8G\MapServer\MapServerData\Script\Player\PlayerHero.pytOnHeroPresetSaveÝs                 icCs tj||tjƒs-tjd|ƒdSi}g}xC|jƒD]5\}}||krdqFn|j|ƒ|||<qFWtjd||f|jƒƒ|j    ƒj
tj ƒ}d}    i}
xût |j ƒƒD]ç} |j| ƒ} | sÖ| jƒrqÖn| jtjƒ} | s"qÖn| jƒ}xŒt | ƒddd…D]q}|jtj|ƒ}t|ƒd|krqHn|jtj|ƒ|    d7}    |    tjkr¯Pn| |
| <qHWqÖWg}i}xü|jƒD]î\}}|dksÚ||j ƒkr
qÚn|j|ƒ} | sÚ| jƒr2qÚn| jƒ}||krgtjd||fƒqÚn|j|ƒ| jƒ}t|||ƒ}|jtj|ƒ||
kr¾| |
|<n|||<qÚWx|
jƒD]}|jƒqÙWtj|ƒj|||ƒdS(Ns!¸ÃÎ佫ÕóÈÝÔ¤Éè²»¿ÉÓÃ! presetID=%ss!±£´æÎ佫ԤÉèÕóÈÝ: presetID=%s, %siiÿÿÿÿis,ͬ¸öÎ佫ֻÄÜÉÏÕóÒ»¸ö! itemIndex=%s,itemID=%s(t PlayerPresettGetFuncPresetIDStateR#tFuncPreset_HeroRRRR]RRRR2RXRR!R"RFR4RêR‘tGetLineupValuet DelUserAttrt LineupObjMaxRRR3R`tvaluesRïRrRstUpdHeroItemPreset(RR9R¦R:t heroPosDictt    indexListRŽR<R7tdelCountt syncItemDictRiRwRœRóR”R=t
heroIDListt heroItemDictRÝtsyncItem((siD:\SG_ServerCode\ServerPython\ZoneServerGroup\map1_8G\MapServer\MapServerData\Script\Player\PlayerHero.pyR¤ìsl     
      cCs|d|d|S(Ni'id((tlineupIDR:R<((siD:\SG_ServerCode\ServerPython\ZoneServerGroup\map1_8G\MapServer\MapServerData\Script\Player\PlayerHero.pyR3.scCs/|d}|dd}|d}|||fS(Ni'id((R=R¸R:R<((siD:\SG_ServerCode\ServerPython\ZoneServerGroup\map1_8G\MapServer\MapServerData\Script\Player\PlayerHero.pyR¬/s
 
c Cs²tj|ƒ}|jtj|ƒ}|td|ƒ@rStjd||fƒdStjd|ƒ}|sodS|j    ƒ}|t
|ƒkr‘dS||}tjd|ƒ}|s·dS|j ƒ}tjd|ƒ}    |    sßdS|    j ƒ}
|
st
|
ƒdkrdS|
\} } t ||ƒs8tjd|ƒdS|td|ƒO}tj|tj||ƒtjd||||fƒtj|| | ddtƒt||gƒdS(    Nis+ÕóÈÝÍÆ¼ö½±ÀøÒÑÁìÈ¡! recommendID=%s,index=%stLineupRecommendRPRQs)Î佫δ»ñµÃ¹ý£¬²»¿É¼¤»îÕóÈÝÍÆ¼ö! heroID=%ss=ÕóÈÝÍÆ¼öÁì½±! recommendID=%s,index=%s,heroID=%s,awardState=%sRk(RtToIntDefRRtDef_PDict_HeroRecommendtpowRRRSt GetHeroIDListR»RTtGetRecommendAwardMoneyRpRRRmR R    ( Rt recommendIDRit
awardStateRéRµR;RaRbRcRrRsRt((siD:\SG_ServerCode\ServerPython\ZoneServerGroup\map1_8G\MapServer\MapServerData\Script\Player\PlayerHero.pytGetLineupRecommendAward;s@ 
   cCs|jtj|ƒ}|dS(Ni
(RRtDef_PDict_HeroFatesInfo(RtfatesIDR‡((siD:\SG_ServerCode\ServerPython\ZoneServerGroup\map1_8G\MapServer\MapServerData\Script\Player\PlayerHero.pytGetHeroFatesState^scCsQ|jtj|ƒ}|ddt|dƒ}tj|tj||ƒ}|S(Ni
i    (RRRÂR…RR(RRÃR†R‡((siD:\SG_ServerCode\ServerPython\ZoneServerGroup\map1_8G\MapServer\MapServerData\Script\Player\PlayerHero.pytSetHeroFatesStateascCs|jtj|ƒ}|dS(Ni
(RRRÂ(RRÃR‡((siD:\SG_ServerCode\ServerPython\ZoneServerGroup\map1_8G\MapServer\MapServerData\Script\Player\PlayerHero.pytGetHeroFatesLVgscCsH|jtj|ƒ}|d|d}tj|tj||ƒ}|S(Ni
(RRRÂRR(RRÃtlvR‡((siD:\SG_ServerCode\ServerPython\ZoneServerGroup\map1_8G\MapServer\MapServerData\Script\Player\PlayerHero.pytSetHeroFatesLVjscCs`tjƒj|ƒ}|j}|j}|j}|dkrOt|||ƒn t||ƒdS(Ni(RR˜R™tFatesIDR4Ršt__onHeroFatesLVUPt__onHeroFatesActivite(RiRªR«RRÃR8R¶((siD:\SG_ServerCode\ServerPython\ZoneServerGroup\map1_8G\MapServer\MapServerData\Script\Player\PlayerHero.pyt OnHeroFateszs              cCsðt||ƒr$tjd|ƒdStjd|ƒ}|s@dS|jƒ}x;|D]3}t||ƒsStjd|||fƒdSqSWtjd||fƒt||dƒ|jƒ}t    j
||ddt igƒt ||gƒdS(NsËÞÔµ×éºÏÒѾ­¼¤»îÁË! fatesID=%st    HeroFatess@ÓÐÎ佫δ»ñµÃ¹ý£¬²»¿É¼¤»îËÞÔµ! fatesID=%s,heroID=%s,heroIDList=%ss"¼¤»îËÞÔµ! fatesID=%s,heroIDList=%siRÀ( RÄRRRRSR½RpRÅtGetAwardItemListR%RÌR6R
(RRÃRéRµR;titemList((siD:\SG_ServerCode\ServerPython\ZoneServerGroup\map1_8G\MapServer\MapServerData\Script\Player\PlayerHero.pyRˆs"   cCsât||ƒs$tjd|ƒdStjd|ƒ}|s@dS|jƒ}|jƒ}t||ƒd}tjd|||||fƒtjd||ƒ}|sªdS|jƒ}|j    ƒ}    |j
ƒ}
g} i} t j |ƒ} |j ƒjtjƒ}xât|jƒƒD]Î}|j|ƒ}| s|jƒrBqn|jƒ}||kr…t| |
|||ƒr…| j|ƒq…n||kr—qn|| kr°d| |<n|jtjƒ}|| |krØqn|| |<qWt| jƒƒ}||kr"tjd||| fƒdStjd||| fƒt| ƒ|    krotjd    t| ƒ|    fƒdStjd
|    ƒx1| |     D]%}tj|||jƒtd ƒq‹Wt |||ƒt!||gƒt"|ƒdS( NsËÞÔµ×éºÏδ¼¤»î! fatesID=%sRÍisQËÞÔµÉý¼¶: fatesID=%s,fatesQuality=%s,fatesNextLV=%s,heroIDList=%s,useIndexList=%stHeroFatesQualityLVis9    µ±Ç°×ÜÐǼ¶²»×ã: nowStarTotal=%s < %s, heroStarDict=%ss@    µ±Ç°×ÜÐǼ¶: nowStarTotal=%s,needStarTotal=%s,heroStarDict=%ss    ¿ÉÓòÄÁÏ¿¨²»×ã: %s < %ss    ËÞÔµÉý¼¶! needHeroCnt=%st HeroFatesLVUP(#RÄRRRRStGetFatesQualityR½RÆtGetNeedStarTotaltGetNeedHeroCnttGetNeedQualityRrRsRRR#R2RXRR!R"RRt__checkHeroFatesLVUPItemR]R@RAtsumR¯R»RRÆR6RÈR
R](RRÃt useIndexListRét fatesQualityRµt fatesNextLVR¯t needStarTotalt needHeroCntt needQualityRt heroStarDicttolPlayerR7RiRwR;RŠt nowStarTotal((siD:\SG_ServerCode\ServerPython\ZoneServerGroup\map1_8G\MapServer\MapServerData\Script\Player\PlayerHero.pyRÊšsf            #
c
Cs¡tjd|ƒ}|sdS|jƒ}||krUtjd||||fƒdS|jtjƒ}|jtjƒ}|jtj    ƒ}    |jtj
ƒ}
|dks»|s»|    s»|
rßtjd||||    |
fƒdS|j ƒrtjd|ƒdS|j tj ƒ} | ragt| ƒD]} |jtj | ƒ^q%} tjd|| fƒdS|jƒ}t|ƒ}|rtjd|||fƒdStS(NRPsK    ÓëËÞÔµËùÐèÆ·Öʲ»Í¬µÄ¿¨ÎÞ·¨Ê¹ÓÃ: itemIndex=%s,heroID=%s,quality=%s != %sis\    Éý¼¶Í»ÆÆÉýÐǾõÐѹýµÄÎ佫ÎÞ·¨Ê¹ÓÃ! itemIndex=%s,heroLV=%s,breakLV=%s,starLV=%s,awakeLV=%ss$    Ëø¶¨µÄÎ佫ÎÞ·¨Ê¹ÓÃ! itemIndex=%ss9    ÉÏÕóÖеÄÎ佫ÎÞ·¨Ê¹ÓÃ! itemIndex=%s,lineupValueList=%ssC    ÉúЧÖеĿ¨ÅÆÎÞ·¨Ê¹ÓÃ! itemIndex=%s,heroID=%s,effPresetIDList=%s(RRSRTRRR@R#R?RBRARCRÃRFR4RXR‘RRR•R (RßRÝRŽRwR;RaRbR®R­R$RÕRœR”RR“((siD:\SG_ServerCode\ServerPython\ZoneServerGroup\map1_8G\MapServer\MapServerData\Script\Player\PlayerHero.pyRÖ×s8    .  cCs!t|ƒtj|ƒjƒdS(N(tCalcHeroAddAttrRrRstRefreshRoleAttr(R((siD:\SG_ServerCode\ServerPython\ZoneServerGroup\map1_8G\MapServer\MapServerData\Script\Player\PlayerHero.pyR]ýs
cCsvi}i}|jƒ}tjƒ}xt|jƒƒD]í}|j|ƒ}|jƒ}t||ƒsmq7nt||ƒ}|j    ƒ}    |j
ƒ}
|j ƒ} xtt t |    ƒt |
ƒƒƒD]^} |    | } t | ƒ| krî| | nd}|
| ||}|j| dƒ||| <qÂWq7Wtjd||ƒtj|ƒjtj|ƒxçt|jƒƒD]Ó}|j|ƒ}|jƒ}t||ƒs¡qknt||ƒ}|dkrÂqkn|jƒ}    |jƒ}xatt t |    ƒt |ƒƒƒD]>} |    | } || }||}|j| dƒ||| <qüWqkWtjd||ƒtj|ƒjtj|ƒdS(Nis ʱװÊôÐÔ: %ss ËÞÔµÊôÐÔ: %s(tGetIDRRWRXtGetHeroSkinAttrCounttGetHeroSkinAttrByIndext    GetSkinIDR„R‰tGetRoleAttrIDListtGetRoleAttrValueListtGetRoleAttrPerStarAddListR…R»R^RRRrRst SetCalcAttrRtDef_CalcAttr_HeroSkintGetHeroFatesCounttGetHeroFatesByIndext
GetFatesIDRÄRÆt GetAttrIDListtGetLVAttrValueListtDef_CalcAttr_HeroFates(Rt skinAttrDictt fatesAttrDictR¬RhRiRéRƒtskinStart
attrIDListt attrValueListtperStarAddListtitattrIDtattrValuePerStart    attrValueRÃtfatesLVtlvAttrValueListtattrValuePerLV((siD:\SG_ServerCode\ServerPython\ZoneServerGroup\map1_8G\MapServer\MapServerData\Script\Player\PlayerHero.pyRásL      (
""    (
 
 
"cCsé|dkr|}ncg}tjƒ}xNt|jƒƒD]:}|j|ƒ}|jƒsaq:n|j|jƒƒq:W|s‚dSg}x|D]}tj    d|ƒ}|s³qn|dkrÜ|j
t j |ƒ rÜqn|j ƒ}    tjƒ}
||
_|j
t j |ƒd|
_g|
_x[|    dD]O} tjƒ} | | _t|| ƒ| _t|| ƒ| _|
jj| ƒq.Wt|
jƒ|
_|j|
ƒqW|s®dStjƒ} || _t| jƒ| _tj|| ƒdS(NRPi
i( tNoneRRWRXRdReRgR]RfRSRRRyRFtChPyNetSendPackt    tagSCHeroRDt BookInitStatetSkinListt tagSCHeroSkinRER„tStateR‰tStarR»tSkinCntt tagSCHeroInfot HeroInfoListtHeroCntt NetPackCommont SendFakePack(RRµtsyncHeroIDListRhRiRét syncInfoListR;RaRJtheroRƒtskint
clientPack((siD:\SG_ServerCode\ServerPython\ZoneServerGroup\map1_8G\MapServer\MapServerData\Script\Player\PlayerHero.pyR5sL        #                    c CsRtj|ƒ}|r!|g}n |jƒ}g}x×|D]Ï}|j|ƒ}|s[q:nd„|jjƒDƒ}g}xOtddtjƒD]7}||kr»|j    ||dƒq‘|j    dƒq‘Wt
j ƒ}    ||    _ ||    _ t|    j ƒ|    _|j    |    ƒq:W|sdSt
jƒ}
||
_t|
jƒ|
_tj||
ƒdS(NcSsi|]\}}||“qS(((t.0R‘R’((siD:\SG_ServerCode\ServerPython\ZoneServerGroup\map1_8G\MapServer\MapServerData\Script\Player\PlayerHero.pys
<dictcomp>ps    ii(RrRstGetHeroPresetIDListt GetHeroPresetR¶RRXR#R®R]RttagSCHeroPresetR¡tHeroItemIndexListR»R
ttagSCHeroPresetInfot
PresetListt    PresetCntR R ( Rt heroPresetIDRßt
syncIDListt
presetListt
heroPresettposNumItemIndexDicttheroItemIndexListR<tpresetR((siD:\SG_ServerCode\ServerPython\ZoneServerGroup\map1_8G\MapServer\MapServerData\Script\Player\PlayerHero.pytSync_HeroPresetcs6                  cCs5tjƒ}|jtjƒ|_tj||ƒdS(N(RttagSCPlayerHeroInfoRRRtAwakeRebirthCntR R (RR((siD:\SG_ServerCode\ServerPython\ZoneServerGroup\map1_8G\MapServer\MapServerData\Script\Player\PlayerHero.pyR‡s c
Csýg}tjƒ}x£t|jƒƒD]}|j|ƒ}|jƒ}|jtj|ƒ}|dkr}||kr‰q%q‰n |s‰q%nt
j ƒ}||_ ||_ |j|ƒq%W|sÂdSt
jƒ}    ||    _t|    jƒ|    _tj||    ƒdS(N(RRWRXtGetLineupRecommendCounttGetLineupRecommendByIndextGetRecommendIDRRR»RÿRttagSCLineupRecommendt RecommendIDt
AwardStateR]ttagSCLineupRecommendInfot RecommendListR»tCountR R (
RRt recommendListRhRiRéR¿RÀt    recommendR((siD:\SG_ServerCode\ServerPython\ZoneServerGroup\map1_8G\MapServer\MapServerData\Script\Player\PlayerHero.pyR    Žs,                      c
Csg}tjƒ}x®t|jƒƒD]š}|j|ƒ}|jƒ}t||ƒ}|dkrv||kr‚q%q‚n |s‚q%ntj    ƒ}||_
||_ t ||ƒ|_ |j|ƒq%W|sÍdStjƒ}    ||    _t|    jƒ|    _tj||    ƒdS(N(RRWRXRìRíRîRÄRÿRttagSCHeroFatesRÉRRÆtFatesLVR]ttagSCHeroFatesInfot    FatesListR»R,R R (
RRt    fatesListRhRiRéRÃR†tfatesR((siD:\SG_ServerCode\ServerPython\ZoneServerGroup\map1_8G\MapServer\MapServerData\Script\Player\PlayerHero.pyR
©s.                      ([RR#RRR%R§RRuR¡R RRrR©R¤RRR÷RR RR RRORMRxRpRqR€RR„RˆR‰R‹RR•R¸R½RàRÿRÅR RÇRëRRR R!RR'R#R(R.R,R9R6R5RLRHRPRGRNRIRcRiRaRxR“R‚RƒR„R R¨R¤R3R¬RÁRÄRÅRÆRÈRÌRËRÊRÖR]RáRR!RR    R
(((siD:\SG_ServerCode\ServerPython\ZoneServerGroup\map1_8G\MapServer\MapServerData\Script\Player\PlayerHero.pyt<module>s°                                             ,                                           0        H      r                  ,     /         E     ]        R    #                     )             (        T                O     B             #                             =    &        2 . $