cehua_wcy
2018-08-17 3f0535d34816e4934f881aed4191b4afeebeaae7
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
Xðt[c@soddlZddlZddlZddlZddlZddlZddlZddlZddlZddl    Z    ddl
Z
ddl Z ddl Z ddl Z ddlZddlZddlZddlZddlZedƒ\ZZdZd„Zd„Zd„Zd„Zd„Zd    „Zd
„Zd „Zd „Zd „Z d„Z!gd„Z"dS(iÿÿÿÿNiicCsOt|ƒtjƒ}tjt|ƒd tjƒ}tj|tj    |ƒdS(Ni
(
tAddRecoverTimest    GameWorldtGetCurrentTimetChangeTimeStrToNumtstrtChConfigtTYPE_Time_Format_Dayt PlayerControltNomalDictSetPropertytDef_PDict_RecoverGainLastTime(t    curPlayertcurTimet
curTimeNum((s].\ServerPython\ZoneServerGroup\map1_8G\MapServer\MapServerData\Script\Player\PlayerRecover.pyt RecoverOnDay2s
 
 cCst|ƒdS(N(t__NotifyRecoverNum(R
((s].\ServerPython\ZoneServerGroup\map1_8G\MapServer\MapServerData\Script\Player\PlayerRecover.pytRecoverOnLogin=s
c+ Csˆ|jƒ}|dkrdSt|ƒ}td|dƒ}tjd|ƒg}tjƒ}tjƒ}x t|j    ƒƒD]ù}|j
|ƒ}|j ƒ}|t kr°q}nt j|tj|dƒ|jƒ}    tjd|    ƒ}
|
sôq}n|
jƒ} | rtj|| ƒ rq}n|
jƒdkrq|
jƒ} tj| ƒ} | sXq}n| jƒ}|spq}n|jtj| ƒ}| tjkr¢| r¢q}ntj|| ƒ\}}|\}}}}}|\}}}}}t|ƒdkr| rq}n| tjkrIt ||d| ƒ}|s4q}n||d|}n|||}|||}|}|} |||}!t j|tj!||ƒ| tj"krêtj#|tj$|dt%| gƒ}"t j|tj&||"ƒn|jtj'|dƒ}#t j|tj'|t(||#|dƒƒ|jtj)|dƒ}$t j|tj)|t(||$|dƒƒ|jtj*|dƒ}%t j|tj*|t(||%|dƒƒ|jtj+|dƒ}&t j|tj+|t(| |&|dƒƒ|jtj,|dƒ}'t j|tj,|t(|!|'|dƒƒtjd||||| |!fƒ|j-|ƒq}|
jƒdkr}|
jƒ}(t.j/||(ƒ\})}*|(t0j1krÎd}*|)rÎ|*})qÎn|)|*krç| rçq}n|*|)||*}|dkr q}n|jtj'|dƒ}#t j|tj'|t(||#|*dƒƒ|j-|ƒtjd||fƒq}q}Wt2|ƒdS(Niis"    Ôö¼Ó¿ÉÕһشÎÊý lostOnDayNum=%st
DailyQuestis`Ôö¼ÓÕһشÎÊýindex=%s,addCommonCnt=%s,addExtraCnt=%s,addBuyCnt=%s,addItemAddCnt=%s,addnoBuyCnt=%ss$Ôö¼ÓÕһشÎÊýindex=%s,addCommonCnt=%s(3tGetLVt__GetLastRecoverPastDaytmaxRtDebugLogRt IpyGameDataPYtIPY_DatatxrangetGetResourcesBackCounttGetResourcesBackByIndextGetIDtDef_TJGRecoverIDRRRtDef_PDict_HaveRecovert GetRelatedIDtGetIpyGameDataNotLogtGetUnLockFuncIDt GameFuncCommt GetFuncCanUsetGetRelatedTypetFBCommont GetFBIpyDatat GetDayTimestNomalDictGetPropertyt Def_Player_Dict_FBHistoryMaxLinetDef_UnRecoverNoPassMaptGetFBDetailCntInfot
PyGameDatatFBEnterTimeLimiitMapIDt__GetLimitFBCnttDef_PDict_RecoverGainDatatDef_FBMapID_MunekadoTrialtGetDictValueByBitt"Def_Player_Dict_PlayerFBStar_MapIdtFalsetDef_PDict_RecoverGainDataExtDef_PDict_RecoverFBCommonCnttmintDef_PDict_RecoverFBExtraCnttDef_PDict_RecoverFBBuyCnttDef_PDict_RecoverFBItemAddCnttDef_PDict_RecoverFBNoBuyCnttappendtPlayerActivitytGetDailyActionFinishCntt ShareDefinetDailyActionID_DiceR(+R
tplayerLVt lostOnDayNumtrecoverNumListR t
ipyDataMgrtit recoverDatatindext    relatedIDtdailyQuestDatat unLockFuncIDt    dataMapIDt    fbIpyDatatmaxTimesthistoryMaxLinet
remainInfot    limitInfot
rCommonCntt    rExtraCnttrBuyCntt rItemAddCnttnoBuyCnttrCommonCntlimittrExtraCntlimitt rBuyCntlimittrItemAddCntlimitt noBuyCntlimitt    fbOpenCntt addCommonCntt addExtraCntt    addBuyCntt addItemAddCntt addnoBuyCntt historyStart curCommonCntt curExtraCntt    curBuyCntt curItemAddCntt curnoBuyCnttdailyIDt curDayTimest dayTimesLimit((s].\ServerPython\ZoneServerGroup\map1_8G\MapServer\MapServerData\Script\Player\PlayerRecover.pyRCs´           %            
cCsY|jtjdƒ}|sdStjtjƒƒ}td||ƒ}|dd}|S(Niii(R&RR    RRtGetCurrentDataTimeStrR(R
trecoverGainLastTimeR tpassTicktpastDay((s].\ServerPython\ZoneServerGroup\map1_8G\MapServer\MapServerData\Script\Player\PlayerRecover.pyR±scCs‰|s
dStjƒ}d}xft|ƒD]X}|tjd|dƒ}d|j|jf}tj||ƒswq)n|d7}q)W|S(Nitdaysis%02d%02d(    RRtrangetdatetimet    timedeltatmonthtdayR#tGetFBHasOpenToday(R
RjRHR RXtdiffDaysttimeDatatdayStr((s].\ServerPython\ZoneServerGroup\map1_8G\MapServer\MapServerData\Script\Player\PlayerRecover.pyR,»s c 
Cs’tjƒj|ƒ}tjd|jƒƒ|j}|d krVtjd|ƒdS|jscdS|j}|j}i}i}g}    dddif\}
} } } xrt    |ƒD]d\}}|t
krÓd}n
||}t j d|ƒ}|sûq²nt ||||ƒ\}}|s"q²nx.|D]&\}}|j|dƒ|||<q)W|jƒr–|tkr–t|||ƒ}|r |    j|ƒq nvt||||ƒ\}}}}|
|7}
| |7} | |7} x4|jƒD]&\}}| j|dƒ|| |<qâW|||<q²W|s$dSi|tj6}x†|jƒD]x\}}tj|||ƒ}tjd|||fƒ|s†dSx0|D](\}}tj|||tj|ƒqWqAW|
dkrâtj|ƒj|
ƒn| dkr tj|tj| tjƒn| dkr5tj || t!t!dƒn| rýt"j#|tj$ƒ}t%| ƒ|kr¯g| jƒD]\}}||dg^qo}tj&d|j'ƒg|ƒqýxK| jƒD]:\}}t(j)|||dtj$tj*gt!d    t!ƒq¼Wnt
|krt+j,|ƒnt-j.||||
| | | ƒt/||ƒt0|ƒ|    rht1j2||    ƒntjd
||||
| | | fƒdS( Ns0==[PlayerRecover]== In->OnRecoverGain(), Name:%siis&OnRecoverGain() hasn't recover way(%s)t ResourcesBacks-    moneyType=%s,moneyCnt=%s,costMoneyList=%stRecovertt showSysInfos•==[PlayerRecover]== Out->OnRecoverGain() recoverWay=%s, costMoneyDict=%s, recoverCntDict=%s, totalExp=%s, totalMoney=%s, totalSP=%s, totalItemDict=%s(ii(3RtGetPlayerManagertGetPlayerByIndexRt GetPlayerNametTypetCntt    IndexListtRecoverCntListt    enumerateRRtGetIpyGameDatat__GetRecoverCosttgettGetCanBackTimest RecoverWay1t__DoLogicBackTimesR9t__GetRecoverGaintitemsRtDef_Cost_Reason_SonKeyRt HaveMoneyExtPayMoneytDef_Cost_RecoverGaintAddExpt    GiveMoneyt IPY_GameWorldtTYPE_Price_Silver_MoneytDef_GiveMoney_RecovertPlayerAddZhenQitTruet
ItemCommontGetItemPackSpacetrptItemtlent SendMailByKeyt GetPlayerIDt ItemControlertGivePlayerItemt rptAnyWheret    PlayerTJGtResetTJGDeadInfotDataRecordPacktDR_PlayerRecovert__SetRecoverNumRR#tSync_FBPlayerFBInfoData( RDt
clientDatattickR
t
recoverWaytrecoverIndexListtrecoverCntListt costMoneyDicttrecoverCntDictt    mapIDInfottotalExpttotalSPt
totalMoneyt totalItemDictRBt
recoverCnttipyDatat costMoneyListt    moneyTypetmoneyCntRHtexptsptmoneytitemDicttitemIDtitemCnttinfoDicttmTypetmCntt
emptySpacet prizeItemList((s].\ServerPython\ZoneServerGroup\map1_8G\MapServer\MapServerData\Script\Player\PlayerRecover.pyt OnRecoverGainÕsŠ                      
!
 
 
$   .5  
&cCs…|jƒ}tjd|ƒ}|s(dS|jƒdkr}|jƒ}|jtj|ƒ}tj|tj|||ƒndS|S(NRii(    RRRR"R&RtDef_Player_Dict_RecoverFbCntRR(R
RCR¯RERFRHt recoverFbCnt((s].\ServerPython\ZoneServerGroup\map1_8G\MapServer\MapServerData\Script\Player\PlayerRecover.pyR†/s  !c Cs:|jƒ}|tkrCt||ƒ\}}t|||ƒ}n|jtjƒ}|tkrß|jƒ}|j    ƒ}    |tkr¢t
||t dƒƒ}
n(t||ƒ||    t d||ƒ}
t j|
gg} nQ|jƒ} |tkrt
| |t dƒƒ}
n
|| }
tj|
gg} | |fS(Nii(RRt__GetCanRecoverCntR4R&RtDef_PDict_TJGDeadPayTimeR…tGetNormalCostJadetGetVipCostJadetinttfloatRR<tTYPE_Price_Gold_Paper_Moneyt GetCostCopperRR( R
R¥R¯R°RDt    commonCntt vipExtraCntt recoverSecondtnormalCostJadet vipCostJadet    costMoneyR±t
costCopper((s].\ServerPython\ZoneServerGroup\map1_8G\MapServer\MapServerData\Script\Player\PlayerRecover.pyR‚Bs$      (  
cCs“|jtj|dƒ}|jtj|dƒ}|jtj|dƒ}|jtj|dƒ}|jtj|dƒ}|||||fS(Ni(R&RR3R5R6R7R8(R
RDR_R`RaRbRc((s].\ServerPython\ZoneServerGroup\map1_8G\MapServer\MapServerData\Script\Player\PlayerRecover.pyRÂ\s cCsôxí|jƒD]ß\}}|jtj|dƒ}|jtj|dƒ}|jtj|dƒ}|jtj|dƒ}|jtj|dƒ}|||||g}    tj    |    ƒ}
d} xKt
|    ƒD]=\} } | | 7} t d| |ƒ|
| <|| krÍPqÍqÍW|
\}}}}}t j |tj||ƒt j |tj||ƒt j |tj||ƒt j |tj||ƒt j |tj||ƒt |||||ƒdkr |tkr t j |tj|dƒq q WdS(Nii(RˆR&RR3R5R6R7R8tcopytdeepcopyR€RRRRR(R
R©RDR¯R_R`RaRbRctcntListt
newCntListtsumCntRBtcntt newCommonCntt    newBuyCntt newItemAddCntt newExtraCntt newnoBuyCnt((s].\ServerPython\ZoneServerGroup\map1_8G\MapServer\MapServerData\Script\Player\PlayerRecover.pyR¡es.
 *!cCsb|jƒ}|jƒ}tj|ƒ}tj|tjƒ}|jtj|dƒ}|jtj    |dƒ}    d}
d} d} d} i}|t
krÐ|jtj ƒ}|jtj ƒ}|tj |}
n|tkrè|jƒn    |jƒ}|jddƒ}|r5|ttjd||f|ƒƒ} n|jddƒ}|rv|ttjd||f|ƒƒ} n|jddƒ}|r·|ttjd||f|ƒƒ} n|jd    gƒ}|rRx€|D]u}|jd
dƒ}|jd dƒ}|s qÖn|ttjd |||f|ƒƒ}|sAqÖn|||<qÖWn| | | |fS( NiR´RwsResourcesBackEXP%s_%sR¶sResourcesBackMoney%s_%sRµsResourcesBacksp%s_%stitemtItemIDt    ItemCountsResourcesBackitem%s_%s_%s(RRRtGetPlayerReExptGetLimitExpRateRtExpRateLimitType_RecoverR&R-R2RtDef_PDict_TJGDeadExptDef_PDict_TJGDeadExp1tDef_PerPointValueR…t GetJadeRewardtGetCopperRewardRƒtevaltFormulaControltGetCompileFormula(R
R¥R¯R°RDtreLVtreExptexpRatet    extraDatatdataExttjgExpR´RµR¶R·tExptExp1t    awardDictt
expFormulat moneyFormulat    spFormulat itemInfoListtitemInfoR¸titemcntFormulatitemcnt((s].\ServerPython\ZoneServerGroup\map1_8G\MapServer\MapServerData\Script\Player\PlayerRecover.pyR‡ŠsJ   $))) )c Csctjƒ}|jƒg|_tjƒ}xt|jƒƒD]û}|j|ƒ}|j    ƒ}|rw||krwq>nt
||ƒ\}}|j t j |dƒ}    | rÀ| rÀ|     rÀq>ntjƒ}
|
jƒ||
_||
_||
_|j t j|dƒ|
_|j t j|dƒ|
_|jj|
ƒq>Wt|jƒ|_tj||ƒdS(Ni(tChPyNetSendPackttagMCRecoverNumtCleartNumInfoRRRRRRRÂR&RRttagMCRecoverNumInfotIndext
RecoverCnttExtraCntR-t    ExtraDataR2t
ExtraData2R9R—tNumt NetPackCommont SendFakePack( R
R@tsendPackRARBRCRDRÊRËt haveRecovert numInfoPack((s].\ServerPython\ZoneServerGroup\map1_8G\MapServer\MapServerData\Script\Player\PlayerRecover.pyR¼s0 
       
            (#RRèRRRúRRR<RšRŸR”RR#R RR:R*RÑRmRlR…t RecoverWay2RR RRRR,R¿R†R‚RÂR¡R‡R(((s].\ServerPython\ZoneServerGroup\map1_8G\MapServer\MapServerData\Script\Player\PlayerRecover.pyt<module>s@                                n    
        Z                    %    2