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
f9²ic@s”ddlZddlZddlZddlZddlZddlZddlZddlZddlZddl    Z    ddl
Z
ddl Z ddl Z ddl Z ddlZddlZddlZddlZd„Zd„Zd„Zd„Zd„Zd„Zd„Zd    „Zd
„Zd d „Zd „Zd d„Zd„Zd„Zd„Z d„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„Z0d „Z1e)d!„Z2d"„Z3d#„Z4e)d$„Z5d%„Z6d&„Z7d'„Z8d(„Z9d)„Z:d d*„Z;d+„Z<d,„Z=d-„Z>d.„Z?d/„Z@d0„ZAd1„ZBd2„ZCd3„ZDd4„ZEd5„ZFd6„ZGd7„ZHd8„ZId9d:„ZJd;„ZKd<„ZLd=„ZMd>„ZNd?„ZOd@„ZPdA„ZQdB„ZRdC„ZSdD„ZTdE„ZUdF„ZVdG„ZWddH„ZXddI„ZYdJ„ZZddK„Z[ddL„Z\dS(Miÿÿÿÿ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.pytOnPlayerFirstLogin4s
 
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 9s4   
 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.pyRXs  )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 InitHeroItemls2
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 GetHeroLVMaxJs  c" Cs0tjƒ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|ƒ}|rtj ddƒ}g}|j!ƒ}xD|D]<\}}t"dt#||dƒƒ}|j$||gƒqWWi}t%|||ƒx<|j&ƒD].\} }| \}}!|j$|||!gƒqºWtjd|ƒt'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@sÍÌÊɶîÍâ×Ü·µ»¹: %steventtHeroStarUPReturn(+RR˜R™RRšt UseItemIndexRRRRt GetIsLockedRFR#RKtErrLogRLR@RCR?RBRRSRTRAtGetHeroStarMaxRtDelItemRR6t DoHeroUpdStarRrRsRtt
GetFuncCfgtGetDismissReturnItemstmaxtintR]t__calcHeroQualityReturnItemExRR%tGivePlayerItemOrMailRuRv("RiRªR«RR¬RŽt useItemIndexRwtuseItemR;t    useHeroIDt    washIDCntt awakeRandCntt
useAwakeLVt    useHeroLVt
useBreakLVRaRbRŠtawakeLVtstarMaxtuseStartaddStartupdStarRctratiotreturnItemListtdismissReturnItemstitemIDt    itemCountt    returnCnttreturnItemExDicttkeytisBind((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 GetHeroIDStarVscCs}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.pytGetHeroStarTotalcscCsotj|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 ns 
 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 OnHeroBreak€sP             
  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ÖRRRíRRRÿRÒRRiRkR RgRhRjR 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.pytOnHeroAwakeSelectTalent=s
        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ŽR1RôR¬RwR;RÒtselectTalentIDRNRRRRRiRkR RÿRtselectTalentLVRaRbRcRêRìtpreSlotStarMaxRíRöt overflowStar((siD:\SG_ServerCode\ServerPython\ZoneServerGroup\map1_8G\MapServer\MapServerData\Script\Player\PlayerHero.pyR0DsŠ              
 
 
 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=%sR:is
Ï´Á¶Ç°: %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ŽRwR;R;RÑt
washItemIDtlockCostItemListRNRt    lockIndextlockCnttwashCostItemCountR´RµtwashItemIndexListt
washIDListRiRkR RgRhRjR RnRo((siD:\SG_ServerCode\ServerPython\ZoneServerGroup\map1_8G\MapServer\MapServerData\Script\Player\PlayerHero.pyR:´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;RNRRGRiRk((siD:\SG_ServerCode\ServerPython\ZoneServerGroup\map1_8G\MapServer\MapServerData\Script\Player\PlayerHero.pyR9s"   
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™tHeroIDtSkinIDR8RšRRSt GetSkinIDListRRitActiveHeroSkintDoHeroWearSkinR6tDoHeroSkinStarUPR ( RiRªR«RR;RƒR<RŽ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RRRRSRJR»RRR„RîR>R#RDRERrRsRtRóR (
RRŽROt
isSkinAttrRwR;RaRNRƒR÷((siD:\SG_ServerCode\ServerPython\ZoneServerGroup\map1_8G\MapServer\MapServerData\Script\Player\PlayerHero.pyRLCs2   
 
cCsftjd|ƒ}|sdS|jƒ}| sAt|ƒ|krEdS||}t||||ƒdS(NRP(RRSRJR»t__onHeroSkinActive(RR;ROtisActiveRaRNRƒ((siD:\SG_ServerCode\ServerPython\ZoneServerGroup\map1_8G\MapServer\MapServerData\Script\Player\PlayerHero.pyt GMSetHeroSkinbs 
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tGetPackItemBindStateIndexInfotDelCostItemByBindRRR(
RR;Rƒt skinIpyDatat
needItemIDt needItemCnttcostItemIndexListtbindCntt    unBindCnttlackCnt((siD:\SG_ServerCode\ServerPython\ZoneServerGroup\map1_8G\MapServer\MapServerData\Script\Player\PlayerHero.pyRKms"   cCs.t|||ƒt||gƒt|ƒdS(N(RˆRtRefreshLordAttr(RR;RƒRS((siD:\SG_ServerCode\ServerPython\ZoneServerGroup\map1_8G\MapServer\MapServerData\Script\Player\PlayerHero.pyRR€s
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=%sRUs6Î佫ʱװÐǼ¶ÒÑÂú! 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‰RWRRXRYR‹RRa(RR;RƒR¬RZR×RöR[R\R]R^R_R`tnextStar((siD:\SG_ServerCode\ServerPython\ZoneServerGroup\map1_8G\MapServer\MapServerData\Script\Player\PlayerHero.pyRM†s8       
 
cCsVtjƒj|ƒ}|j}|j}|dkr6n|dkrEn t||ƒdS(Nii(RR˜R™RHtBookTypet__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 RRmR¤t UpdTaskValueRtTaskType_HeroBookR§tUptateSuccessProgressR#tSuccType_OSAHeroBook(
RR;R¬RaRbRctawardMoneyInfot    moneyTypet
moneyValueRl((siD:\SG_ServerCode\ServerPython\ZoneServerGroup\map1_8G\MapServer\MapServerData\Script\Player\PlayerHero.pyReÊ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 lvCostMoneytbreakCostMoneytawakeCostMoneyRwtqualityAwakeIpyDatatcostMoneyTotalRÛtreturnItemDictR÷tktvRÜ((siD:\SG_ServerCode\ServerPython\ZoneServerGroup\map1_8G\MapServer\MapServerData\Script\Player\PlayerHero.pyt OnHeroRebirthsˆ                **    /"% 
+"  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†Zs   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
retBreakLVtqualityBreakIpyDataR"R²R³((siD:\SG_ServerCode\ServerPython\ZoneServerGroup\map1_8G\MapServer\MapServerData\Script\Player\PlayerHero.pyR‡ks " 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ˆ|s   c! Cstjƒj|ƒ}|j}tjd|ƒtjddƒ}g}i}i}|jƒjt    j
ƒ}    x¿|D]·}
|
dksr|
|    j ƒkrœqrn|    j |
ƒ} | sr| j ƒrÄqrn| jt    jƒ} | rùtjd|
| fƒqrn| jƒrtjd|
ƒqrn| jt    jƒ} | rgt| ƒD]}| jt    j|ƒ^qA}tjd|
|fƒqrn| jƒ}t| ƒ}|r½tjd|
||fƒqrntjd    |ƒ}|sÛqrn|jƒ}| jt    jƒ}| jt    jƒ}| jt    jƒ}tjd
|ƒ}|s;qrntjd |
|||||fƒ|jƒ}xS|D]K\}}td t|d ||d ƒƒ}|j|dƒ|||<qqWtjd|||||fƒt ||||ƒt!||||ƒt"|||ƒ|j#|
| gƒqrW|s7dSx3|D]+\}
} t$j%|| | j ƒt&dƒq>W|rg|j'ƒD]\}}||g^q€}x<|j'ƒD].\}}|\}} |j#||| gƒq«Wtjd|ƒ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 HeroDismisssDzɢ×Ü·µ»¹: %sRÀ(*RR˜R™t ItemIndexListRRRÈRRR#R2RR!R"R@RCRÃRFR4RXR‘RRR•RSRTR?RBRARÉRÊRËR^R†R‡RÌR]RRÆR6RR%RÍ(!RiRªR«RR¶RÛtdismissItemListR”RáR7RŽRwRÖt lineupCountR”tlineupValueListR;R“RaRbR®R­theroStarRcRÝRÞRßt
starRetCntR•R–RÜRâRã((siD:\SG_ServerCode\ServerPython\ZoneServerGroup\map1_8G\MapServer\MapServerData\Script\Player\PlayerHero.pyt OnHeroDismiss•s~      .   # % #+ "c
CsË|jƒ}|rÇtjdtjƒ}tj|tjƒd}xg|D]_\}}|s]Pn||f}tdt    t
||dƒƒƒ}    |j |dƒ|    ||<qGWt j d|||fƒndS(NtsrcSigniigY@s    ºìÑÕ·µ»¹: retPer=%s,%s,×Ü%s(tGetBeautyReturnItemsR%tGetIsBindValueRtItemSrcSign_BeautyEfft PlayerBeautytGetBeautyEffInfotEffType_HeroItemExPerRÊRËtroundR^RR(
RRcRátbeautyReturnItemsRãtretPerRÞRßRâtretCnt((siD:\SG_ServerCode\ServerPython\ZoneServerGroup\map1_8G\MapServer\MapServerData\Script\Player\PlayerHero.pyRÌÛs  #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.pyR3OscCs/|d}|dd}|d}|||fS(Ni'id((R=RÇR:R<((siD:\SG_ServerCode\ServerPython\ZoneServerGroup\map1_8G\MapServer\MapServerData\Script\Player\PlayerHero.pyR»Ps
 
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=%sRo(RtToIntDefRRtDef_PDict_HeroRecommendtpowRRRSt GetHeroIDListR»RTtGetRecommendAwardMoneyRpRRRqR R    ( Rt recommendIDRit
awardStateRíRÄR;RaRbRcRvRwRx((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.pytGetHeroFatesStatescCsQ|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.pytSetHeroFatesState‚scCs|jtj|ƒ}|dS(Ni
(RRRÑ(RRÒR‡((siD:\SG_ServerCode\ServerPython\ZoneServerGroup\map1_8G\MapServer\MapServerData\Script\Player\PlayerHero.pytGetHeroFatesLVˆscCsH|jtj|ƒ}|d|d}tj|tj||ƒ}|S(Ni
(RRRÑRR(RRÒtlvR‡((siD:\SG_ServerCode\ServerPython\ZoneServerGroup\map1_8G\MapServer\MapServerData\Script\Player\PlayerHero.pytSetHeroFatesLV‹scCs`tjƒj|ƒ}|j}|j}|j}|dkrOt|||ƒn t||ƒdS(Ni(RR˜R™tFatesIDR8Ržt__onHeroFatesLVUPt__onHeroFatesActivite(RiRªR«RRÒR<R¶((siD:\SG_ServerCode\ServerPython\ZoneServerGroup\map1_8G\MapServer\MapServerData\Script\Player\PlayerHero.pyt OnHeroFates›s              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
Ra(RRÒt useIndexListRít fatesQualityRÄt fatesNextLVR¯t needStarTotalt needHeroCntt needQualityR"t 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.pyRas
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( tNoneRRWRXRhRiRkR]RjRSRRRyRJtChPyNetSendPackt    tagSCHeroRHt BookInitStatetSkinListt tagSCHeroSkinRIR„tStateR‰tStarR»tSkinCntt tagSCHeroInfot HeroInfoListtHeroCntt NetPackCommont SendFakePack(RRÄtsyncHeroIDListRhRiRít syncInfoListR;RaRNtheroRƒtskint
clientPack((siD:\SG_ServerCode\ServerPython\ZoneServerGroup\map1_8G\MapServer\MapServerData\Script\Player\PlayerHero.pyRVsL        #                    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>‘s    ii(RrRstGetHeroPresetIDListt GetHeroPresetRÅRRXR#R½R]RttagSCHeroPresetR°tHeroItemIndexListR»RttagSCHeroPresetInfot
PresetListt    PresetCntRR( Rt heroPresetIDRît
syncIDListt
presetListt
heroPresettposNumItemIndexDicttheroItemIndexListR<tpresetR ((siD:\SG_ServerCode\ServerPython\ZoneServerGroup\map1_8G\MapServer\MapServerData\Script\Player\PlayerHero.pytSync_HeroPreset„s6                  cCs5tjƒ}|jtjƒ|_tj||ƒdS(N(RttagSCPlayerHeroInfoRRRtAwakeRebirthCntRR(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ÊRRttagSCLineupRecommendt RecommendIDt
AwardStateR]ttagSCLineupRecommendInfot RecommendListR»tCountRR(
RR*t 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ÓRRttagSCHeroFatesRØRRÕtFatesLVR]ttagSCHeroFatesInfot    FatesListR»R;RR(
RR*t    fatesListRhRiRíRÒR†tfatesR ((siD:\SG_ServerCode\ServerPython\ZoneServerGroup\map1_8G\MapServer\MapServerData\Script\Player\PlayerHero.pyR
Ês.                      (]RR#RRR%R§RRuR¡RRRrR¸R©R¤RRRûRR RR RRORMRxRpRqR€RR„RˆR‰R‹RR•R¸R½RäRRÅR RÇRïRRR R%RR+R'R,R2R0R=R:R9RPRLRTRKRRRMRgRmReR|R—R†R‡RˆR¤RÌR·R³R3R»RÐRÓRÔRÕR×RÛRÚRÙRåRaRðRR0RR    R
(((siD:\SG_ServerCode\ServerPython\ZoneServerGroup\map1_8G\MapServer\MapServerData\Script\Player\PlayerHero.pyt<module>s´                                              ,                                           0        N      r                  ,     /         E     ]        R    #                     )             (        T                F    #     B             #                             =    &        2 . $