hxp
2018-08-13 c6338504cf292767e279f225dc9203f3cdf87ea5
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
     c[c@s\ddlZddlZddlZddlZddlZddlZddlZddlZddlZddl    Z    ddl
Z
ddl Z ddl Z ddl Z ddlZddlZddlZedƒ\ZZZZedƒ\ZZZZZZdZdZdZdZdZ d    Z!d
Z"d „Z#d „Z$dd „Z%d„Z&d„Z'd„Z(d„Z)d„Z*d„Z+d„Z,d„Z-d„Z.d„Z/d„Z0d„Z1d„Z2d„Z3d„Z4d„Z5d„Z6dd „Z7d!„Z8d"„Z9d#„Z:d$„Z;d%„Z<d&„Z=e>dd'„Z@d(„ZAd)„ZBd*„ZCd+„ZDdS(,iÿÿÿÿNiitZMSL_FBNextRefreshStept ZMSL_FBNPCCnttZMSL_FBNPCNeedRefreshCnttZMSL_FBNPCRefreshCnttZMSL_FBStepStartTicktZMSL_FBStepStart ZMSL_CostTimecCsOtj|jƒƒ}|tjkrKtjd|ƒ|jtjdƒndS(Ns1ZMSLOnDay curPlayerMapID=%s,SetDict IsInFBOnDay 1i(    tFBCommontGetRecordMapIDtGetMapIDtChConfigtDef_FBMapID_MunekadoTrialt    GameWorldtDebugLogtSetDicttDef_PlayerKey_IsInFBOnDay(t    curPlayertcurPlayerMapID((sˆ.\ProjectSServer\ServerPython\ZoneServerGroup\map1_8G\MapServer\MapServerData\Script\GameWorldLogic\FBProcess\GameLogic_MunekadoTrial.pytOnFBPlayerOnDayMs
cCs"tjƒjƒ}tj||ƒS(N(R tGetMapR    RtGetFBLineRefreshNPC(tlineIDtmapID((sˆ.\ProjectSServer\ServerPython\ZoneServerGroup\map1_8G\MapServer\MapServerData\Script\GameWorldLogic\FBProcess\GameLogic_MunekadoTrial.pyt__GetZMSLnpcCfgWscCs=tjƒjƒ}|dkr-tjƒ}ntj||ƒS(Niÿÿÿÿ(R RR    RtGetFBPropertyMarktGetFBLineStepTime(RR((sˆ.\ProjectSServer\ServerPython\ZoneServerGroup\map1_8G\MapServer\MapServerData\Script\GameWorldLogic\FBProcess\GameLogic_MunekadoTrial.pytGetMTFBLineStepTime[s cCsdS(N((ttick((sˆ.\ProjectSServer\ServerPython\ZoneServerGroup\map1_8G\MapServer\MapServerData\Script\GameWorldLogic\FBProcess\GameLogic_MunekadoTrial.pytOnOpenFBescCsdS(N((R((sˆ.\ProjectSServer\ServerPython\ZoneServerGroup\map1_8G\MapServer\MapServerData\Script\GameWorldLogic\FBProcess\GameLogic_MunekadoTrial.pyt    OnCloseFBmscCsi|dkrtStj|tj|dt|gƒ}tjdƒ}||kretjd|ƒtStS(NiitMunekadoLockLimits&    ÉÏÒ»²ãÆÀ¼¶Î´´ïµ½%s£¬ÎÞ·¨ÌôÕ½±¾²ã£¡(    tTrueR tGetDictValueByBitR
t"Def_Player_Dict_PlayerFBStar_MapIdtFalset IpyGameDataPYt
GetFuncCfgR (RRRRt historyStartneedStar((sˆ.\ProjectSServer\ServerPython\ZoneServerGroup\map1_8G\MapServer\MapServerData\Script\GameWorldLogic\FBProcess\GameLogic_MunekadoTrial.pytOnEnterFBEventvs % cCs|S(N((RRtlineIdtipyEnterPosInfoR((sˆ.\ProjectSServer\ServerPython\ZoneServerGroup\map1_8G\MapServer\MapServerData\Script\GameWorldLogic\FBProcess\GameLogic_MunekadoTrial.pytOnGetFBEnterPos‰scCstjS(N(t IPY_GameWorldt    cmeAccept(taskR((sˆ.\ProjectSServer\ServerPython\ZoneServerGroup\map1_8G\MapServer\MapServerData\Script\GameWorldLogic\FBProcess\GameLogic_MunekadoTrial.pytOnChangeMapAsk’sc
Cstjƒjƒ}tj|ƒ}tjƒ}tjƒs°|jtj    ƒ}tj
|ƒ|j ƒt kr°tj t|ƒ|jtdƒ|jtdƒ|jtdƒq°ntjƒ}tjd||jƒƒtj|ƒsƒtj|ƒtjj|jƒdƒ|jtjdƒt}tj|ƒrRt }tjd|jƒƒntj!||ƒ}t"j#|||tj$|ƒnt%ƒ}|j ƒ}|tkr |t&d|tjƒj'ƒ}    |j(t)j*dt+|    dƒt ƒ|j(t)j,dt+|    dƒt ƒnS|t-kr`|t.d|tjƒj'ƒ}    |j(t)j/dt+|    dƒt ƒnt0|t |ƒt1||ƒdS(NisZMSL DoEnterFB lineID=%s£¡sZMSL ÖúÕ½½øÈ븱±¾£¡iè(2R t GetGameWorldR    RRt    GetGameFBtGetHadSetFBPropertyMarktNomalDictGetPropertyR
tDef_Player_Dict_ReqFBFuncLinetSetFBPropertyMarkt    GetFBStept FB_Step_Opent    SetFBSteptFB_Step_Preparet SetGameFBDictRRRRR tGetIDtGetHadDelTickettSetHadDelTickett
PyGameDatatg_fbPickUpItemDicttpopt GetPlayerIDRRR"tSetIsHelpFightRt GetFBJoinTypet EventReportt WriteEvent_FBt CME_Log_StartRtDef_PrepareTimet GetFBStepTickt Sync_TimeTickR+t tttAddUpTimetmaxt tttWaitStartt FB_Step_Fightt Def_FightTimet tttTowerTaket__UpdZMSLFBStartDoFBHelp(
RRRtgameFBRt isHelpFighttjoinTypetZMSLCfgtfbStept notify_tick((sˆ.\ProjectSServer\ServerPython\ZoneServerGroup\map1_8G\MapServer\MapServerData\Script\GameWorldLogic\FBProcess\GameLogic_MunekadoTrial.pyt    DoEnterFB›sF           ""% "% c Cshtjƒ}|jtƒ}|jtƒ}|dksB|dkrFdS|jtƒ}tjƒ}t|ƒ\}}|t    |ƒks—|t    |ƒkr¨tj
dƒt S||}||}    d}x|    D]}
||
d7}qÉW|j t |ƒ|j t|ƒtj||    ||ƒ|j t|dƒ|j t|ƒ|j t|jtjƒƒt|t ƒdS(NisÒÑÊÇ×îºóÒ»²¨, Í¨¹Øi(R R0tGetGameFBDictByKeyRRRRRRtlenR RR9RtNPCCustomRefresht SetNPCRefreshRRR
t Def_FB_GradeRO( RRQtnpcCnttneedRefreshCntt refreshStepRtrefreshNPCListt    rMarkListtrMarktrNPCListtrNPCInfo((sˆ.\ProjectSServer\ServerPython\ZoneServerGroup\map1_8G\MapServer\MapServerData\Script\GameWorldLogic\FBProcess\GameLogic_MunekadoTrial.pyt__RefreshZMSLNextNPCÈs0  $ 
 
  cCs[tjd|jƒƒtjƒjƒdkrWtjdƒtjƒ}|jdƒndS(NsZMSL DoExitFB...is¸±±¾ÖÐֻʣÏÂÒ»¸öÈË£¬¹Ø±Õ¸±±¾!(R R R@tGetMapCopyPlayerManagertGetPlayerCountR0tSetIsSafeClose(RRRQ((sˆ.\ProjectSServer\ServerPython\ZoneServerGroup\map1_8G\MapServer\MapServerData\Script\GameWorldLogic\FBProcess\GameLogic_MunekadoTrial.pytDoExitFBðs   cCstjd|jƒƒdS(NsZMSL DoPlayerLeaveFB...(R R R@(RR((sˆ.\ProjectSServer\ServerPython\ZoneServerGroup\map1_8G\MapServer\MapServerData\Script\GameWorldLogic\FBProcess\GameLogic_MunekadoTrial.pytDoPlayerLeaveFBýscCstS(N(R(((sˆ.\ProjectSServer\ServerPython\ZoneServerGroup\map1_8G\MapServer\MapServerData\Script\GameWorldLogic\FBProcess\GameLogic_MunekadoTrial.pytOnPlayerRebornscCsdS(Nt((RR(((sˆ.\ProjectSServer\ServerPython\ZoneServerGroup\map1_8G\MapServer\MapServerData\Script\GameWorldLogic\FBProcess\GameLogic_MunekadoTrial.pytGetPlayerResetWorldPosFBMsgscCs„tjƒjƒ}|tkr+t|ƒnU|tkrNt|ƒt|ƒn2|tkrgt    |ƒn|t
kr€t |ƒndS(N( R R0R5R8t__DoLogic_FB_PrepareRLt__ProcessOverFightROtFB_Step_PickItemt__DoLogic_FB_PickItemt FB_Step_Overt__ProcessCloseFB(RRU((sˆ.\ProjectSServer\ServerPython\ZoneServerGroup\map1_8G\MapServer\MapServerData\Script\GameWorldLogic\FBProcess\GameLogic_MunekadoTrial.pyt    OnProcesss   
     cCs»tƒ}|tjƒjƒ|tdkr1dSt|ƒtjƒ}xBt|jƒƒD].}|j    |ƒ}|s{qZnt
||ƒqZWt j t |ƒt jtj|tdƒdS(Niè(RR R0RGRFReRftrangeRgtGetPlayerByIndexRPRR7RLtSync_Player_TimeTickR+RNRM(RtfbCfgt playerManagertiR((sˆ.\ProjectSServer\ServerPython\ZoneServerGroup\map1_8G\MapServer\MapServerData\Script\GameWorldLogic\FBProcess\GameLogic_MunekadoTrial.pyRn+s    $
 cCsUtƒt}tjƒjƒ}td|d||ƒdkrDdStt|ƒdS(Niiè(RRMR R/t GetOpenFBTickRJt __DoZMSLOverR"(Rt    FightTimetopenTick((sˆ.\ProjectSServer\ServerPython\ZoneServerGroup\map1_8G\MapServer\MapServerData\Script\GameWorldLogic\FBProcess\GameLogic_MunekadoTrial.pyRo@s  ! cCs?|tjƒjƒtƒtdkr+dStjt|ƒdS(Niè(R R0RGRtDef_PickItemTimeRR7Rr(R((sˆ.\ProjectSServer\ServerPython\ZoneServerGroup\map1_8G\MapServer\MapServerData\Script\GameWorldLogic\FBProcess\GameLogic_MunekadoTrial.pyRqMs'cCs\tjƒ}||jƒtƒtdkr1dStjƒtj|ƒtj    t
|ƒdS(Niè( R R0RGRt Def_ExitTimeRtDoLogic_FBKickAllPlayertGameWorldProcesstCloseFBR7t FB_Step_Close(RRQ((sˆ.\ProjectSServer\ServerPython\ZoneServerGroup\map1_8G\MapServer\MapServerData\Script\GameWorldLogic\FBProcess\GameLogic_MunekadoTrial.pyRsWs !
 cCspg}tjƒ}xWt|jƒƒD]C}|j|ƒ}|sFq%ntj|ƒr[q%n|j|ƒq%W|S(N(R RftxrangeRgRvRtGetIsHelpFighttappend(tdropPlayerListRytindexR((sˆ.\ProjectSServer\ServerPython\ZoneServerGroup\map1_8G\MapServer\MapServerData\Script\GameWorldLogic\FBProcess\GameLogic_MunekadoTrial.pytGetCanDropPlayerListbs ic    Csi|tjƒjƒ}tjƒ}|jt|ƒtjd||fƒtjt|ƒt    ƒt
d}tj ƒj ƒ}tj |ƒ}tjƒ}tjƒjtjƒ}i|tj6|tj6t|ƒtj6|tj6}    tjƒ}
|
jƒ} xgt| ƒD]Y} |
j| ƒ} | s)qn| jtjd|tƒ|s^tj| |    ƒqn|d| j tj!|ƒkrŸt"j#| tj!||dƒnt$}tj%| tj&|t$|gƒ}||krýtj'| tj&||t$|gƒt}n| j(tj)ƒ}tj*| ƒ}|dkrvtj+| |ƒ}t,j-| d|dƒt.j/| ||tj0|dƒnt1j2| t3j4d| ||dgƒ|r¸tj5| |dƒn€|sÚtj6| |dƒt$}n| j7tj)dƒt1j2| t3j8dƒt9j:| tj;id|6ƒ\}}}||    tj<<|rQtj=| |ƒntj| |    ƒqWdS(Ns#__DoZMSLOver isPass=%s,killNPCID=%sièiiiszmsl_%s(>R R0RGR9RR RR7RrRR€RR    RRRXR
R\t
Over_gradetOver_dataMapIDtintt Over_isPasst Over_costTimeRfRgR…RvRHR+t tttLeaveMapRtNotify_FB_OverR2t Def_Player_Dict_FBHistoryMaxLinet PlayerControltNomalDictSetPropertyR"R R!tSetDictValueByBitt GetDictByKeyRR†RBt
EventShelltEventRespons_FBEventRCRDt CME_Log_Endt PlayerSuccesstDoAddSuccessProgresst ShareDefinetSuccType_MunekadoTrialtAddFBHelpPointtAddEnterFBCountRtSuccType_MunekadoTrialExt    NPCCommontGiveKillNPCDropPrizeR t Over_itemInfotSync_FBPlayerFBInfoData(tisPassRt    killNPCIDtcostTimeRQt    leaveTimeRRtstartoverDictRyt playerCountR‰RtneedSyncFBDataR%t isInFBOnDayRRRSt jsonItemListttotalExpt
totalMoney((sˆ.\ProjectSServer\ServerPython\ZoneServerGroup\map1_8G\MapServer\MapServerData\Script\GameWorldLogic\FBProcess\GameLogic_MunekadoTrial.pyR|ns` 
 4   !! "     "&    ( cCs&tjƒ}|jƒtkr"tStS(N(R R0R5RLR"R(tattackertdefenderRQ((sˆ.\ProjectSServer\ServerPython\ZoneServerGroup\map1_8G\MapServer\MapServerData\Script\GameWorldLogic\FBProcess\GameLogic_MunekadoTrial.pytCheckCanAttackTagObjInFBÌs cCs»|jƒtƒkrdStjƒ}|jtƒ}|jtƒ}|d7}|d8}|jt|ƒ|jt|ƒtjd|jƒ||fƒ|dkr·tjd|ƒndS(Nis:DoFBRebornNPC, npcID=%s,ZMSL_FBNPCCnt=%s,needRefreshCnt=%sis±¾²¨¹ÖÎïË¢ÐÂÍê±Ï£¡npcCnt=%s(    tGetNPCIDt__GetAllNPCIDListR R0RXRRR9R (tcurNPCRRQR]R^((sˆ.\ProjectSServer\ServerPython\ZoneServerGroup\map1_8G\MapServer\MapServerData\Script\GameWorldLogic\FBProcess\GameLogic_MunekadoTrial.pyt DoFBRebornNPCÖs 
 
  cCs[tjƒ}t|ƒd}g}x2|D]*}x!|D]\}}|j|ƒq6Wq)W|S(Ni(RRRR‡(RR`t    npcIDListtrListtnpcidtnpccnt((sˆ.\ProjectSServer\ServerPython\ZoneServerGroup\map1_8G\MapServer\MapServerData\Script\GameWorldLogic\FBProcess\GameLogic_MunekadoTrial.pyRµçs  cCsç|jƒtƒkrdStjƒ}|jtƒ}|jtƒ}|d8}|jt|ƒtjd|jƒ||fƒ|dkrÐ|dkrÐtjdƒt    |ƒ}|rÐt
t ||jƒƒqÐnt j |tdƒdS(Nis@DoFB_Player_KillNPC, npcID=%s,ZMSL_FBNPCCnt=%s,needRefreshCnt=%sis±¾²¨ËùÓйÖÎïÒѱ»»÷ɱ£¡(R´RµR R0RXRRR9R ReR|RRtNotifyCopyMapPlayerFBHelpRP(RR¶RRQR]R^t isAllKilled((sˆ.\ProjectSServer\ServerPython\ZoneServerGroup\map1_8G\MapServer\MapServerData\Script\GameWorldLogic\FBProcess\GameLogic_MunekadoTrial.pytDoFB_Player_KillNPCös  
      cCsª|jƒ}|tjkr$|jƒ}tj|ƒ}tj|ƒ}|tjkr|rqtj|j    |ƒq!t
}xwtj|D]h}|d|dkr…|j dƒ|j dƒkr…|j ddƒ|j ddƒ|d<t }Pq…q…W|s!tj|j    |ƒq!q$|gtj|<nt jƒjƒdk}    |    r¦t jƒjƒtkr¦tjt|ƒtƒtd}
t jƒjƒ} tj| ƒ} t jƒ} | jtjƒ} | jtƒ}t jƒ}xÎt|j ƒƒD]·}|j!|ƒ}|s    qèn|j"t#j$d|
t ƒtjj |j%ƒgƒ}i| tj&6| tj'6dtj(6|tj)6|tj*6}t j+d||j%ƒƒtj,||ƒqèWndS(NtItemIDtIsBindtCountiièisPickItemOver: %s(-tGetTypeR
tDef_ItemType_MoneyR:t
ItemCommontCheckItemIsEquipt GetJsonItemR=R>R‡R"tgetRR tGetMapItemManagertGetMapItemCountR0R5RpRR7RrRR€RR    RRXR\RRfR…RgRvRHR+RR@R‹RŒRŽRR£R R‘(RtcurItemRt mapItemTypetplayerIDtisEquiptjsonItemtisIntitemInfotisItemAllPickUpR¨RRQR©R§RyR‰tplayerR®Rª((sˆ.\ProjectSServer\ServerPython\ZoneServerGroup\map1_8G\MapServer\MapServerData\Script\GameWorldLogic\FBProcess\GameLogic_MunekadoTrial.pyt OnPickUpItemsL  2&  !cCstS(N(R(t    atkPlayert    defPlayer((sˆ.\ProjectSServer\ServerPython\ZoneServerGroup\map1_8G\MapServer\MapServerData\Script\GameWorldLogic\FBProcess\GameLogic_MunekadoTrial.pytDoFBAttackHasPunishAscCs]tjƒ}|jtjƒ}|dkr.|S|jtƒ}|sG|Sttj||dƒƒ}t    j
ƒ}t j dƒj |gƒ}|jtƒ}    |    t|ƒkr½tjdƒdS|jtƒ}
||    d} |
ræ|
nd} d} xK| D]C}| dkrPn| |7} || kr;td| dƒ} qùPqùWtd| |ƒ}|| krj| rj|S|jtj| ƒtjd||| |fƒ|rÜt||ƒ| dkrY|jtjd|dtƒqYn}tjƒ}xnt|jƒƒD]Z}|j|ƒ}|sqûnt||ƒ| dkrû|jtjd|dtƒqûqûW| S(    Nig@@tMunekadoTrialStarTimes-    MunekadoTrialStarTime ÅäÖôíÎó Ó벨Êý²»µÈiis=__UpdFBStar useSecond=%s,curStar=%s,updStar=%s, diffSecond=%siè(R R0RXR
R\RRtmathtceilRRR#tGetFuncEvalCfgRÇRRYR RRJR9RPRHR+t tttFlagTakeRRfR…RgRv(RtisEnterRRQtcurStart stepStartTickt    useSecondRt starTimeListtwheelNumtstepStart starTimeInfotupdStart totalStarTimetstarTimet
diffSecondRyR‰((sˆ.\ProjectSServer\ServerPython\ZoneServerGroup\map1_8G\MapServer\MapServerData\Script\GameWorldLogic\FBProcess\GameLogic_MunekadoTrial.pyROEsX      
       #   $c Cs¸tjƒ}|jtjƒ}|jtƒ}|jtƒ}|jtƒ}td||ƒ}||g}t    j
ƒ}    i|t    j 6|t    j 6|t    j 6|    t    j6}
t    j||
ƒdS(Ni(R R0RXR
R\RRRRJRRt    Help_stept
Help_gradet Help_npcTotalt Help_lineIDt Notify_FBHelp( RRRQR©Rát needKillCntt remainNPCCntt
KillNPCCnttdataRt
fbHelpDict((sˆ.\ProjectSServer\ServerPython\ZoneServerGroup\map1_8G\MapServer\MapServerData\Script\GameWorldLogic\FBProcess\GameLogic_MunekadoTrial.pyRP‚s   .cCsdS(N((Rt
actionTypet
actionInfoR((sˆ.\ProjectSServer\ServerPython\ZoneServerGroup\map1_8G\MapServer\MapServerData\Script\GameWorldLogic\FBProcess\GameLogic_MunekadoTrial.pyt
DoFBAction˜scCsEtjƒ}tjtj|ƒ}|d \}}|j||ƒdS(Ni(RRtGetFBLineEnterPosInfoR
R tResetPos(Rt rebornPlaceRRR)tposXtposY((sˆ.\ProjectSServer\ServerPython\ZoneServerGroup\map1_8G\MapServer\MapServerData\Script\GameWorldLogic\FBProcess\GameLogic_MunekadoTrial.pytOnResetFBRebornPlacePos s
 c Cstjƒj|ƒ}|j}tjd|ƒ}|s:dS|jƒ}|jƒ}|jƒ}|j    ƒ}    |j
ƒ}
|j ƒ} | sž| sž|
sž| r¢dSt j |tjtƒs¾dSi| |
6} |jƒjtjƒ} t j| | ƒ\}}|r%tjd||
| |f|ƒdSt j|| |ƒtj||||    tjgdtjtigƒtjd||
| |f|ƒdS(Nt TrialExchangesN¶Ò»»ÏûºÄÎïÆ·²»×㣡exchangeID=%s,costItemID=%s,costItemCount=%s,lackItemDict=%steventsI×ÚÃŶһ»³É¹¦£¡exchangeID=%s,costItemID=%s,costItemCount=%s,delInfoDict=%s(R tGetPlayerManagerRvtIDR#tGetIpyGameDataR@tGetExchangeItemIDtGetExchangeItemCounttGetExchangeItemIsBindt GetCostItemIDtGetCostItemCountRÄtCheckPackHasSpaceR+trptItemRtGetItemManagertGetPacktGetCostItemIndexListR t DelCostItemt ItemControlertGivePlayerItemR
tItemGive_TrialExchangeR"(t playerIndext
clientDataRRt
exchangeIDtipyDataRÌtexchangeItemIDtexchangeItemCounttexchangeItemIsBindt
costItemIDt costItemCountt costItemDicttitemPackt lackItemDictt delInfoDict((sˆ.\ProjectSServer\ServerPython\ZoneServerGroup\map1_8G\MapServer\MapServerData\Script\GameWorldLogic\FBProcess\GameLogic_MunekadoTrial.pyt OnTrialExange®s8                   (ERR+R‚R RœRZR R
RšR#R“RÄRCR=R—R¡RØRuRFRMRR€R6R8RLRpRrR„RRRRRRRRRRRRR'R*R.RWReRiRjRkRmRtRnRoRqRsRŠR|R³R·RµR¾RÓRÖR"tNoneRORPRôRúR(((sˆ.\ProjectSServer\ServerPython\ZoneServerGroup\map1_8G\MapServer\MapServerData\Script\GameWorldLogic\FBProcess\GameLogic_MunekadoTrial.pyt<module>sr                      
    
                                    -    (         
                         
          ^    
                3    =