hxp
8 天以前 2769930d36081c0a8e7fd84dac68301972ae84fe
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
98
99
100
101
102
103
104
105
106
107
108
109
110
111
112
113
114
115
116
117
118
119
120
121
122
123
124
125
126
127
128
129
130
131
132
133
134
135
136
137
138
139
140
141
142
143
144
145
146
147
148
149
150
151
152
153
154
155
156
157
158
159
160
161
162
163
164
165
166
167
168
169
170
171
172
173
174
175
176
177
178
179
180
181
182
183
184
185
186
187
188
189
190
191
192
193
194
195
196
197
198
199
200
201
202
203
204
205
206
207
208
209
210
211
212
213
214
215
216
217
218
219
220
221
222
223
224
225
226
227
228
229
230
231
232
233
234
235
236
237
238
239
240
241
242
243
244
245
246
247
248
249
250
251
252
253
254
255
256
257
258
259
260
261
262
263
264
265
266
267
268
269
270
271
272
273
274
275
276
277
278
279
280
281
282
283
284
285
286
287
288
289
290
291
292
293
294
295
296
297
298
299
300
301
302
303
304
305
306
307
308
309
310
311
312
313
314
315
316
317
÷…ic@skddlZddlZddlZddlZddlZddlZddlZddlZddlZddl    Z    ddl
Z
ddl Z ddl Z ddl Z ddlZddlZddlZddlZddlZddlZddlZddlZddlZddlZdZeddkƒ\ZZZZide j6de j6de j 6Z!d„Z"d    „Z#d
„Z$d „Z%d „Z&d „Z'd„Z(d„Z)d„Z*d„Z+d„Z,d„Z-d„Z.d„Z/d„Z0d„Z1d„Z2dd„Z3d„Z4d„Z5e6ddd„Z8d„Z9d „Z:ddd!„Z;d"„Z<d#„Z=d$„Z>ddd%„Z?d&„Z@dd'„ZAe jeBd(„ZCeBd)d*„ZDd+„ZEdeBd,„ZFdeBdd-„ZGdeBd.„ZHdd/„ZId0„ZJd1„ZKddd2„ZLd3„ZMd4„ZNd5„ZOd6„ZPd7„ZQd8„ZReBd9„ZSd:„ZTd;„ZUd<„ZVd=„ZWddd>„ZXd?„ZYddd@„ZZdA„Z[dddB„Z\dC„Z]dddD„Z^dE„Z_dddF„Z`e6dG„ZadH„ZbdI„ZcdJ„ZddK„ZedL„ZfdddM„ZgdN„ZhdddO„ZiddP„ZjdQ„ZkdddR„ZldS„ZmdT„ZndU„ZodV„ZpdddW„ZqdX„ZrdddY„ZsdZ„Ztd[„Zuddd\„Zvd]„Zwddd^„Zxd_„Zyddd`„Zzda„Z{ddb„Z|dc„Z}dd„Z~de„Zdf„Z€dg„Zdh„Z‚di„Zƒdj„Z„dS(liÿÿÿÿNi!iit    MemberMaxtEliteMaxtDeputyLeaderMaxcCs
|jƒS(N(t    GetExtra1(tfamily((skD:\SG_ServerCode\ServerPython\ZoneServerGroup\map1_8G\MapServer\MapServerData\Script\Player\PlayerFamily.pyt GetRenameTime>scCs |j|ƒS(N(t    SetExtra1(Rt
renameTime((skD:\SG_ServerCode\ServerPython\ZoneServerGroup\map1_8G\MapServer\MapServerData\Script\Player\PlayerFamily.pyt SetRenameTime?scCs:tjƒrntjƒ s(tjƒr,dStjƒdS(N(t    GameWorldt IsCrossServert IsMainServertDBFamilyt IsFamilyCrosstPlayerFamilyEmblemtCheckExpireEmblem(((skD:\SG_ServerCode\ServerPython\ZoneServerGroup\map1_8G\MapServer\MapServerData\Script\Player\PlayerFamily.pytOnMinuteAs  
cCstjƒrtƒndS(N(R    R
t__doFamilyOnHour(((skD:\SG_ServerCode\ServerPython\ZoneServerGroup\map1_8G\MapServer\MapServerData\Script\Player\PlayerFamily.pytFamilyCrossCenterOnHourJs 
cCs5tjƒ stjƒr*tjdƒdStƒdS(Ns-·ÇÓÎÏ··þ»ò±¾·þÒÑ¿ç·þ»¥Í¨Á˲»´¦Àí FamilyOnHour(R    R R R tDebugLogR(((skD:\SG_ServerCode\ServerPython\ZoneServerGroup\map1_8G\MapServer\MapServerData\Script\Player\PlayerFamily.pyt FamilyOnHourOs
 cCsotjƒ}x\|jƒD]N}|j|ƒ}x6td|jƒƒD]}|j|ƒ}t|ƒqDWqWdS(Ni(t    DBDataMgrt GetFamilyMgrtGetZoneIDListThisServertGetZoneFamilyMgrtrangetGetCounttGetAtt__AutoChangeLeader(t familyManagertzoneIDtzoneMgrtiR((skD:\SG_ServerCode\ServerPython\ZoneServerGroup\map1_8G\MapServer\MapServerData\Script\Player\PlayerFamily.pyRVs cCstjƒrtƒndS(N(R    R
t__doFamilyOnDay(((skD:\SG_ServerCode\ServerPython\ZoneServerGroup\map1_8G\MapServer\MapServerData\Script\Player\PlayerFamily.pytFamilyCrossCenterOnDay`s 
cCs?tjƒ stjƒr*tjdƒdStƒtjƒdS(Ns,·ÇÓÎÏ··þ»ò±¾·þÒÑ¿ç·þ»¥Í¨Á˲»´¦Àí FamilyOnDay(R    R R R RR!tCheckCrossFamilyTransData(((skD:\SG_ServerCode\ServerPython\ZoneServerGroup\map1_8G\MapServer\MapServerData\Script\Player\PlayerFamily.pyt FamilyOnDayes  
cCsÛtjƒ}xÈ|jƒD]º}|j|ƒ}x¢td|jƒƒD]‹}|j|ƒ}|jƒ}tj    |ƒt
j    |ƒxCt |jƒƒD]/}|j|ƒ}|j dƒ|j dƒq’Wt|ƒqDWqWdS(Ni(RRRRRRRtGetIDtPlayerFamilyZhenbaogetOnDaytPlayerFamilyTaofatxranget SetContribDaytSetDonateCntDaytBroadcast_FamilyInfo(RRRR RtfamilyIDtindextmember((skD:\SG_ServerCode\ServerPython\ZoneServerGroup\map1_8G\MapServer\MapServerData\Script\Player\PlayerFamily.pyR!ps     cCs4tjƒs&tjd|jƒƒdSt|ƒdS(Ns"¹«»á»¹ÊôÓÚ±¾·þ£¬²»´¦Àí³ÉÔ±¿ç·þ¹ýÌì(R R R    Rt GetPlayerIDt__doPlayerOnDay(t    curPlayer((skD:\SG_ServerCode\ServerPython\ZoneServerGroup\map1_8G\MapServer\MapServerData\Script\Player\PlayerFamily.pytPlayerCrossCenterOnDay„s
 
cCs4tjƒr&tjd|jƒƒdSt|ƒdS(Ns"¹«»áÒѾ­¿ç·þÁË£¬²»´¦Àí³ÉÔ±±¾·þ¹ýÌì(R R R    RR0R1(R2((skD:\SG_ServerCode\ServerPython\ZoneServerGroup\map1_8G\MapServer\MapServerData\Script\Player\PlayerFamily.pyt PlayerOnDayŒs
 
cCs(tj|ƒtj|ƒt|ƒdS(N(R&R4R(tDo_MapServer_PlayerOnDay(R2((skD:\SG_ServerCode\ServerPython\ZoneServerGroup\map1_8G\MapServer\MapServerData\Script\Player\PlayerFamily.pyR1”s  
cCsYt|ƒtjƒr0tjd|jƒƒdStjƒj|jƒƒ}t    |ƒdS(Ns@¹«»áÒÑ¿ç·þ²»´¦Àí£¬ÓÉËùÊô¿ç·þ·þÎñÆ÷´¦Àí³ÉÔ±µÇ¼Âß¼­ OnPlayerLogin(
tDo_MapServer_PlayerLoginR R R    RR0t CrossPlayertGetCrossPlayerMgrtFindCrossPlayertOnCrossPlayerLogin(R2ttickt crossPlayer((skD:\SG_ServerCode\ServerPython\ZoneServerGroup\map1_8G\MapServer\MapServerData\Script\Player\PlayerFamily.pyt OnPlayerLoginšs
 
cCst|ƒt|tƒdS(N(tPlayerLoginRefreshFamilytSync_RequestAddFamilyInfotFalse(R<((skD:\SG_ServerCode\ServerPython\ZoneServerGroup\map1_8G\MapServer\MapServerData\Script\Player\PlayerFamily.pyR:£s
 cCsOtjƒr&tjd|jƒƒdStjƒj|jƒƒ}t|ƒdS(NsA¹«»áÒÑ¿ç·þ²»´¦Àí£¬ÓÉËùÊô¿ç·þ·þÎñÆ÷´¦Àí³ÉÔ±ÀëÏßÂß¼­ OnPlayerLogout(    R R R    RR0R7R8R9tOnCrossPlayerLogout(R2R<((skD:\SG_ServerCode\ServerPython\ZoneServerGroup\map1_8G\MapServer\MapServerData\Script\Player\PlayerFamily.pytOnPlayerLogoutªs  
cCs|jƒ}|jƒ}|s"dStjƒ}|j|ƒ}|sGdS|j|ƒ}|s`dS|jttjƒƒƒt    |d|gƒdS(NtchangeMemIDList(
R0t GetFamilyIDRRt
FindFamilyt
FindMembert
SetOffTimetintttimeR,(R<tplayerIDR-t    familyMgrRt    curMember((skD:\SG_ServerCode\ServerPython\ZoneServerGroup\map1_8G\MapServer\MapServerData\Script\Player\PlayerFamily.pyRA²s   cCsb|jƒ}i|d6|d6}tjƒrQtjtj||jƒg|ƒn t||ƒdS(NtdoTypetdoData(R0R    R
tCrossMsgtSendToClientServert ShareDefinetC2S_FamilyMapPlayertGetMainServerID(R<RMRNRJtdataMsg((skD:\SG_ServerCode\ServerPython\ZoneServerGroup\map1_8G\MapServer\MapServerData\Script\Player\PlayerFamily.pytSendToFamilyMapPlayerÅs   % ic CsD|jƒ}d}d}d}d \}}|r±tjƒ}    |    j|ƒ}
|
r¨|
jƒ}|
jƒ}|
jƒ}|
jƒ}|
j|ƒ} | r®| j    ƒ}q®q±d}n|j
|ƒt j |||||ƒi|d6} |r| j i|d6|d6|d6|d6|d6ƒn|r0d    | d
<nt|d | ƒd S(s> Ï൱ÓÚGameServerµ÷ÓàcurPlayer.MapServer_FamilyRefresh()
    ittFamilyIDtFmLVtFamilyLVt
FamilyNametEmblemIDt
EmblemWordit isVoluntarilyt FamilyRefreshN(is(R0RRREtGetLVtGetNamet GetEmblemIDt GetEmblemWordRFtGetFmLVt SetFamilyIDtPlayerViewCachetUpdPlayerViewFamilyInfotupdateRU( R<R-R]RJRXRYRZR[R\RKt    curFamilyR/RN((skD:\SG_ServerCode\ServerPython\ZoneServerGroup\map1_8G\MapServer\MapServerData\Script\Player\PlayerFamily.pytMapServer_FamilyRefreshÎs4             3 cCs|jƒ}tjƒ}|j|ƒ}tjd||fƒ|j|ƒt||ƒ|}|shdS|j|ƒ}|sdS|j    |ƒ}|sšdS|j
dƒ|j |ƒt |ƒt |d|gd|gƒt|tƒrtj|t|ƒƒndS(Ns7PlayerLoginRefreshFamily playerID=%s,refreshFamilyID=%siRCt excludeIDList(R0RRtGetPlayerFamilyIDR    RRdRiRERFRGtRefreshMemberByIDtSync_FamilyInfoR,tGetFamilyMemberHasPowtFamilyPowerID_CallR7t SendFakePacktGetPack_FamilyReqJoinInfo(R<RJRKtrefreshFamilyIDR-RRL((skD:\SG_ServerCode\ServerPython\ZoneServerGroup\map1_8G\MapServer\MapServerData\Script\Player\PlayerFamily.pyR>ðs,      
cCstjƒrntjƒ s(tjƒr,dS|jƒ}|sBdStjƒ}|j|ƒ}|sgdS|j    ƒ}|j
|ƒ}|sŒdS|j |ƒdS(N( R    R
R R R RDRRRER0RFRl(R<R-RKRRJR/((skD:\SG_ServerCode\ServerPython\ZoneServerGroup\map1_8G\MapServer\MapServerData\Script\Player\PlayerFamily.pytRefreshFamilyMembers"     gà?c Csº|jƒ}tjƒjƒ}|dkr>tj|dƒdS|dkr_tjd|ƒdS|dksƒ|tjƒj    ƒkr»t
|||d|ƒ}    |r·t ||||    ƒndSt j ƒj|ƒ}
|
sä|
jƒ røtj|dƒdS|rN|j|ƒ} | r;|| |dkr;tj|dƒdS|j||ƒni|d    6} |rt|jƒ| d
<n|r‡|| d<n|ršd | d <ntjtj| |g|ƒdS( NiþÿÿÿtFamilyInTransDatais¹«»á¹¦ÄÜÒì³£! crossServerID=%st    reqDataExt ServerNoOpenièt RequestLatertfuncNametpackBuffit
needResult(R0RRtGetCurCrossServerIDt PlayerControlt
NotifyCodeR    tErrLogt GetGameWorldt GetServerIDtCallPyPackFunct__doFamilyPyPackRettCrossMgrtGetSSServerMgrt GetSSServert IsServerOpent GetDictByKeytSetDictt    GetBufferROtSendToCrossServerRQtS2C_FamilyPyPack( R2t
clientDataR;RxRztreqCDRuRJt crossServerIDtisOKtssServertreqTickRT((skD:\SG_ServerCode\ServerPython\ZoneServerGroup\map1_8G\MapServer\MapServerData\Script\Player\PlayerFamily.pytFamilyPyPackForwarding's@   $   cCs®|d}|jdƒ}|jdƒ}d}|rPtj|ƒ}|sPdSnt|||||ƒ}d|krª|jdƒ||d<tjtj    ||g|ƒndS(NRxRyRuRzR(
tgettNonet NetPackCommontReadRecPyPackDataRtpopRORPRQtC2S_FamilyPyPackRet(RTt fromServerIDRJRxRyRuRŒR((skD:\SG_ServerCode\ServerPython\ZoneServerGroup\map1_8G\MapServer\MapServerData\Script\Player\PlayerFamily.pyR‹Vs
 
cCs–tjƒj|ƒ}|sdS|d}|jdƒ}|j|dƒd}|rptj|ƒ}|spdSn|jdƒ}t||||ƒdS(NRxRyiR(    R    tGetPlayerManagertFindPlayerByIDR“RˆR”R•R–R‚(RTRJR2RxRyRŒR((skD:\SG_ServerCode\ServerPython\ZoneServerGroup\map1_8G\MapServer\MapServerData\Script\Player\PlayerFamily.pyR˜gs
c    Csˆtjƒj|ƒ}|s3tjd||ƒdSt|ƒ}|sZtjd|ƒdStjƒjƒ}||||||ƒ}|S(Ns ÕÒ²»µ½¸ÃCrossPlayer! playerID=%ss¹«»á·â°ü¹¦Äܺ¯ÊýÃû²»´æÔÚ! %s(R7R8R9R    R~t GetCallFuncRtGetTick(    RJRŒRxR™RuR<tcallFuncR;R((skD:\SG_ServerCode\ServerPython\ZoneServerGroup\map1_8G\MapServer\MapServerData\Script\Player\PlayerFamily.pyRys cCs4d|}t|ƒ}|s dS||||ƒdS(Ns%s_Ret(Rœ(R2RŒRxRRž((skD:\SG_ServerCode\ServerPython\ZoneServerGroup\map1_8G\MapServer\MapServerData\Script\Player\PlayerFamily.pyR‚‰s 
 cCs½d}d|kr‡|jdƒ}t|ƒdkr¹|\}}t|ƒ}t||ƒr„t||ƒ}t|ƒr|}qq„q¹n2tƒ}||kr¹t||ƒr¹||}n|S(Ns.i(R”tsplittlent
__import__thasattrtgetattrtcallabletglobals(RxRžtpartst
moduleNamet    func_nametmoduletfunctgDict((skD:\SG_ServerCode\ServerPython\ZoneServerGroup\map1_8G\MapServer\MapServerData\Script\Player\PlayerFamily.pyRœ“s         cCs´tjƒj|ƒ}|j}tjdtj|ƒƒt||ƒsKdStjddƒ}tjddƒ}|r—|r—t    j
|||ƒs—dSnt |||dt dƒdS(NsOnCreateFamily: %st CreateFamilyiit__OnCreateFamilyi( R    RštGetPlayerByIndextNameRt    CodeToGbktCheckInputFamilyNamet IpyGameDataPYt
GetFuncCfgR|t    HaveMoneyR’tTrue(R.RŒR;R2t    inputNamet    needMoneyt    moneyType((skD:\SG_ServerCode\ServerPython\ZoneServerGroup\map1_8G\MapServer\MapServerData\Script\Player\PlayerFamily.pytOnCreateFamily±s     c    Cs,|j}|j}|j}tjdtj|ƒƒ|}|jƒ}    |jƒ}
tj    ƒ} |
r£| j
|
ƒ} | r£| j |    ƒr t j |dƒdSq£nt|||ƒr¹dS|jƒ} | j|| ƒ} | dkr÷tjd|    ƒdS| jƒ}| j|ƒ}|r$|jƒnd}| jdƒtjƒ}| sV||krhtj|ƒ}ntjd||    || |fƒ| j|ƒ| j|ƒtjddƒ}tjddƒ}|rò|ròt j |dd    i||6ƒnt!| |    |t"j#ƒ|r|j$ƒnt%j&| ƒt'S(
Ns__OnCreateFamily: %stGeRen_chenxin_85890s ´´½¨¼Ò×åʧ°ÜiÿÿÿÿisC´´½¨¹«»á: familyID=%s,playerID=%s,emblemID=%s,serverID=%s,zoneID=%sR¬it costMoneyDict((R¯R[R\R    RR°R0RDRRRERFR7R}tCheckFamilyNameExistsR€t    AddFamilyR”R~R%tGetZoneFamilyMgrByFamilyIDt    GetZoneIDtSetLVRtGetDefaultFamilyEmblemIDListtrandomtchoicetLogt SetEmblemIDt SetEmblemWordR²R³tCostPlayerResourcestDoPlayerJionFamilytIPY_PlayerDefinet    fmlLeadertSortR&tOnZhenbaogeResetRµ(R<RŒR;R™RuR¶temblemIDt
emblemWordtfullFamilyNameRJtplayerFamilyIDRKRhtserverIDt newFamilyIDRRt emblemIDListR·R¸((skD:\SG_ServerCode\ServerPython\ZoneServerGroup\map1_8G\MapServer\MapServerData\Script\Player\PlayerFamily.pyR­ÄsP               
            cCs:tjƒj|ƒ}tj|ƒ}tjddƒ}||ksN|dkritjd||fƒdStjddƒ}t|ƒ|krÎtjd|t|ƒ|fƒtj    |d|d|gƒdSt
j |ƒrñtj    |d    ƒdSt|ƒdkst|ƒt kr6tj    |dt dt gƒdSt S(
s¼ì²éÍæ¼ÒÊäÈëµÄ¹«»áÃûÊÇ·ñºÏ·¨£¬½¨ÃË¡¢¸ÄÃûͨÓÃ
    ¡¾×¢¡¿¸Ãº¯Êý½öÔÚÓÎÏ··þÑéÖ¤Ãû×ÖµÄͨÓúϷ¨ÐÔ£¬È糤¶È¡¢Ãô¸Ð´ÊµÈ£¬¹«»áÃûÖØÃûÇëÔÚ¹«»áËùÔÚÊý¾Ý·þÑéÖ¤
    @return: None-²»ºÏ·¨£»·Ç¿Õ-ºÏ·¨µÄ¹«»áÈ«Ãû
    tFamilyNameFormatiisF¹«»áÈ«Ãû serverID=%s error! maxServerID=%s, check FamilyNameFormat.txtNis?¹«»áÈ«Ãû familyName=%s, len=%s > %s, check FamilyNameFormat.txtt NameLenLimitt NameSensitive(R    Rt GetCharTrimtGetPlayerServerIDR²R³R~R R|R}t    DirtyListtIsWordForbiddentDef_CreatFamily_MaxStrRµ(R2R¶t
familyNameRÑt maxServerIDtmaxLen((skD:\SG_ServerCode\ServerPython\ZoneServerGroup\map1_8G\MapServer\MapServerData\Script\Player\PlayerFamily.pyR±ýs$ $cCsntjƒ}|j|ƒ}|dkr8tjdƒtS|j|ƒ}|j|ƒrjtj    |dƒtSt
S(Nis ÑéÖ¤¹«»áÖØÃûʱ·ÖÇøÒì³£Ò²ÊÓÎªÖØÃût
NameExists( RRtGetZoneIDInThisServerR    R~RµRtFindFamilyByNameR7R}R@(R<RÜR™RKRR((skD:\SG_ServerCode\ServerPython\ZoneServerGroup\map1_8G\MapServer\MapServerData\Script\Player\PlayerFamily.pyR¼s   c
Cs~tjƒ}t|tƒr3|}|j|ƒ}n|}|sCdS|jƒ}|j|ƒ}|j|ƒ|j|ƒ|t    j
kr—|j |ƒn|r¼t |d|gd|gƒn|j |ƒ|rt||ƒt|ƒt|ƒtj|ƒn|t    j
kr7tj|d|jƒgd|gƒntjƒjƒ}    t|jƒ|tjtjtj|dg|    ƒdS(sN¼ÓÈë¼Ò×壬֧³ÖÀëÏßÍæ¼Ò¼ÓÈë
    @param crossPlayer: Èç¹ûÊÇÀëÏßÍæ¼ÒÔòΪNone
    NRCRjtXW_JZ_EnterFamilyi(RRt
isinstanceRHRER%t    AddMembertSetFmLVRlRÉRÊt SetLeaderIDR,tDelPlayerReqJoinFamilyIDAllRiRmR?R(tOnCrossPlayerEnterFamilyR7t FamilyNotifyt GetPlayerNameR    RRtAddFamilyActionNoteRQtDef_ActionType_FamilyEventt"Def_FamilyActionEvent_MemberChangetDef_FamilyMemberChange_Join(
RRJR<tjionFamilySetLvtbroadcastFamilyChangeRKR-RhR/R;((skD:\SG_ServerCode\ServerPython\ZoneServerGroup\map1_8G\MapServer\MapServerData\Script\Player\PlayerFamily.pyRÈ+s6      
 
(RVc Cs²|tjkr tjdƒtStjƒj||ƒ}|jƒ}|sNtS|j    |ƒ|j
|ƒxCt |dƒD]2\}    }
t |d|    ƒ} | rx| |
ƒqxqxWt S(sͳһÌí¼Ó¼Ò×åActionÊý¾Ý
    s¼Ç¼¼Ò×åÐÐΪÀàÐÍ:%s ´íÎóis
SetValue%s(RQtDef_ActionTypeListR    R~R@RtGetFamilyActionMgrtGetFamilyActiont    AddActiontSetNamet SetUserDatat    enumerateR£Rµ( tcurNameR-t
actionTypetactionDataListR;t isClearNonetuseDatat familyActiont
actionDatatnumtvaluetsetFunc((skD:\SG_ServerCode\ServerPython\ZoneServerGroup\map1_8G\MapServer\MapServerData\Script\Player\PlayerFamily.pyRëYs    cCsKtjddiƒ}t|ƒ|kr+tS|t|ƒ}|jƒ|kS(Nt FamilyPoweri(R²tGetFuncEvalCfgtstrR@Rc(R/tpowerIDt    powerDictt needMemberLV((skD:\SG_ServerCode\ServerPython\ZoneServerGroup\map1_8G\MapServer\MapServerData\Script\Player\PlayerFamily.pyRnos
cCs<|jƒ}|sdSt|||ƒ}tj||ƒdS(N(RDtGetPack_FamilyInfoR7Rp(R<t syncMemIDListt    isSyncMemR-t
clientPack((skD:\SG_ServerCode\ServerPython\ZoneServerGroup\map1_8G\MapServer\MapServerData\Script\Player\PlayerFamily.pyRmws  cCs)t|||ƒ}tj|||ƒdS(N(RR7tSendFakePackByFamily(R-RCR
RjR ((skD:\SG_ServerCode\ServerPython\ZoneServerGroup\map1_8G\MapServer\MapServerData\Script\Player\PlayerFamily.pyR,€sc
CsÃtjƒ}|j|ƒ}|s%dStjƒ}||_|jƒ|_|jƒ|_    |j
ƒ|_ |j ƒ|_ |jƒ|_|jƒ|_|jƒ|_|jƒ|_|jƒ|_|jƒ|_|jƒ|_t|jƒ|_|jƒ|_g|_ |ržxŒt!|j"ƒƒD]u}|j#|ƒ}|j$ƒ}|r[||kr[q"ntj%ƒ}    |j$ƒ|    _&|j'ƒ|    _(|j)ƒ|    _*t|    j*ƒ|    _+|jƒ|    _,|j-ƒ|    _.|j/ƒ|    _0|j1ƒ|    _2|j3ƒ|    _4|j5ƒ|    _6|jƒ|    _|jƒ|    _|j7ƒ|    _8|jƒ|    _|j9ƒ|    _:|j;ƒ|    _<|j=ƒ|    _>|j?ƒ|    _@|jAƒ|    _B|j jC|    ƒq"Wnt|j ƒ|_D|jEƒ|_F|S(N(GRRREtChPyNetSendPackttagMCRoleFamilyInfoRWR`RZR_RYtGetExpt FamilyLVExpt GetJoinReviewt
JoinReviewt GetJoinLVMint    JoinLVMinR€tServerIDRaR[RbR\t GetFightPowert
FightPowertGetFightPowerExt FightPowerExt GetBroadcastt    BroadcastR t BroadcastLent GetLeaderIDtLeaderIDt
MemberListR)RRR0ttagMCRoleFamilyMembertPlayerIDt GetJoinTimetJoinTimeRêR¯tNameLentLVtGetJobtJobt
GetRealmLVtRealmLVtGetFacetFacet
GetFacePictFacePict
GetTitleIDtTitleIDRcRXtGetContribTotalt ContribTotalt GetContribDayt
ContribDaytGetDonateCntTotaltDonateCntTotaltGetDonateCntDayt DonateCntDayt
GetOffTimetOffTimetappendt MemberCountRtExtra1(
R-RCR
RKRhR R.R/tmemIDtmemInfo((skD:\SG_ServerCode\ServerPython\ZoneServerGroup\map1_8G\MapServer\MapServerData\Script\Player\PlayerFamily.pyRˆsd            cCs=tjƒ}||_||_||_t|jƒ|_|S(N(R ttagSCFamilyMemDeltTypeR!R¯R R$(t delPlayerIDt
playerNametdelTypeR ((skD:\SG_ServerCode\ServerPython\ZoneServerGroup\map1_8G\MapServer\MapServerData\Script\Player\PlayerFamily.pytGetPack_FamilyDelÂs              cCsdS(N((R.RŒR;((skD:\SG_ServerCode\ServerPython\ZoneServerGroup\map1_8G\MapServer\MapServerData\Script\Player\PlayerFamily.pytOnRequestJoinFamilyByPlayerÒs cCsWtjƒj|ƒ}|j}|dkr=t|ƒr=dSnt|||dtƒdS(Nit__OnRequesJoinFamily(R    RšR®R@t CheckInJoinCDR’Rµ(R.RŒR;R2t requestType((skD:\SG_ServerCode\ServerPython\ZoneServerGroup\map1_8G\MapServer\MapServerData\Script\Player\PlayerFamily.pytOnRequesJoinFamilyés      cCsx|j}|j}tjd||fƒ|dkrX|sHt|ƒqtt||ƒn|dkrtt||ƒntS(Ns3__OnRequesJoinFamily: tagFamilyID=%s,requestType=%sii(t TagFamilyIDR@R    RtAutoJoinFamilytRequestJoinTagFamilytCancelJoinTagFamilyRµ(R<RŒR;R™Rut tagFamilyIDRH((skD:\SG_ServerCode\ServerPython\ZoneServerGroup\map1_8G\MapServer\MapServerData\Script\Player\PlayerFamily.pyRFòs           cCs2|j}|dkr.tj|tjdƒndS(Nii(R@t
PlayerTaskt AddTaskValuetChConfigtTaskType_ReqOrJoinFamily(R2RŒRRH((skD:\SG_ServerCode\ServerPython\ZoneServerGroup\map1_8G\MapServer\MapServerData\Script\Player\PlayerFamily.pyt__OnRequesJoinFamily_Rets     c        CsVtj|ƒ}|stStj|ƒ\}}}d}|r•|dkrMtStjddƒ}|rêt|ƒ|kr…||dn|d}qênU|dkr¥tStjddƒ}|rêt|ƒ|krÝ||dn|d}n|rR|d}ttjƒƒ|}||krRt    j
d||||t    j |ƒ||fƒt SntS(Nit FamilyLeaveiiÿÿÿÿii<sb¼ÓÈ빫»áCDÖÐ: leaveCnt=%s,kickedCnt=%s,lastVoluntarily=%s,leaveFamilyTime=%s(%s),passTimes=%s < %s( R|tGetLeaveFamilyTimeExR@tGetLeaveFamilyInfoR²RR RHRIR    RtChangeTimeNumToStrRµ(    R2tleaveFamilyTimetleaveCntt    kickedCnttlastVoluntarilyt joinCDMinutetjoinCDMinuteListtcdTimest    passTimes((skD:\SG_ServerCode\ServerPython\ZoneServerGroup\map1_8G\MapServer\MapServerData\Script\Player\PlayerFamily.pyRG s0 0 -
     &c Csb|jƒrdS|jƒ}|jƒ}tjd||ƒ|jƒ}tjƒ}|j|ƒ}|dkrsdS|j    |ƒ}t
|j ƒƒ}t j |ƒx|D]•}|j|ƒ}    |    sÉq¨n|    jƒ}
|
rí||
kríq¨n|    jƒrÿq¨nt|    jƒdƒ} |    j ƒ| kr,q¨nt|    ||ƒdSWtjdƒtj|dƒdS(Ns!Íæ¼ÒÒ»¼ü×Ô¶¯¼ÓÈë¼Ò×壡 realmLV=%siRsûÓпÉ×Ô¶¯½øÈëµÄ¹«»á!tQuickEnterFamilyFail(RDR0R(R    RRSRRRàRRRRÂtshuffleRRRtGetFamilySettingR_RÈR7R}( R<RJtrealmLVt mainServerIDRKRRt    indexListR.RtlvMinR((skD:\SG_ServerCode\ServerPython\ZoneServerGroup\map1_8G\MapServer\MapServerData\Script\Player\PlayerFamily.pyRK)s<           cCsS|s
dStjd|ƒ}|s&dSd|}t||ƒsCdSt||ƒƒS(NitFamilysGet%s(R²tGetIpyGameDataR¢R£(tfamilyLVt    fieldNametipyDatatattrName((skD:\SG_ServerCode\ServerPython\ZoneServerGroup\map1_8G\MapServer\MapServerData\Script\Player\PlayerFamily.pyRbTs
c Cs+|jƒ}|jƒr6tjd|jƒ|ƒdStjƒ}|j|ƒ}||krutjd||ƒdStjddƒ}t    |ƒ|kr½tjdt    |ƒ|f|ƒdS|j
|ƒ}|sÖdS|j ƒ}|j ƒ|krtjd|j ƒ|f|ƒdS|j ƒrÌ|jƒ}||kr—tjddƒ}    t    |ƒ|    kr—tjdt    |ƒ|f|ƒtj|d    ƒdSn|j|ƒt|ƒtj|d
ƒt|ƒdSt|jƒd ƒ}
|jƒ|
krtjd |jƒ|
f|ƒdSt|||ƒdS( Ns%ÒѾ­Óй«»á²»ÄÜÔÙÉêÇë¼ÓÈë! familyID=%ss%ÒѾ­ÔÚÉêÇë¼ÓÈ빫»áÁбíÖÐ! familyID=%st FamilyReqJoinis"ÒѾ­´ïµ½×î´óÉêÇë¼ÓÈ빫»áÊý! %s, %ss-¹Ùְδ´ïµ½¸Ã¹«»á¼ÓÈë×îµÍÏÞÖÆ! realmLV=%s < %sisÄ¿±ê¹«»áÉêÇë¼ÓÈëÊýÒÑÂú! %s, %stjiazu_pan_141056tjiazu_pan_500807Rs*Ä¿±ê¹«»á³ÉÔ±ÒÑÂú! familyLV=%s,memberMax=%s(R0RDR    RRRtGetPlayerReqJoinFamilyIDListR²R³R RERR(RtGetReqJoinPlayerInfoR7R}tAddReqJoinPlayerIDtSendFamilyReqJoinInfoR?RbR_RRÈ( R<R-RJRKtreqFamilyIDListtmaxReqFamilyCntt    tagFamilyRftreqPlayerIDDicttmaxReqPlayerCntt    memberMax((skD:\SG_ServerCode\ServerPython\ZoneServerGroup\map1_8G\MapServer\MapServerData\Script\Player\PlayerFamily.pyRL`sN            
 
 cCsetjƒ}|jƒ}|j|ƒ}|r=|j|ƒn|j||ƒt|ƒt|ƒdS(N(RRR0REtDelReqJoinPlayerIDtDelPlayerReqJoinFamilyIDRsR?(R<R-RKRJRv((skD:\SG_ServerCode\ServerPython\ZoneServerGroup\map1_8G\MapServer\MapServerData\Script\Player\PlayerFamily.pyRM˜s  
 
cCs~|jƒ}tjƒ}|j|ƒ}| r9| r9dStjƒ}|jƒ||_t|jƒ|_    t
j ||ƒdS(N( R0RRRpR t tagMCNotifyRequestJoinFamilyInfotCleartRequestJoinFamilyIDListR t RequestCountR7Rp(R<tisForceRJRKRtR ((skD:\SG_ServerCode\ServerPython\ZoneServerGroup\map1_8G\MapServer\MapServerData\Script\Player\PlayerFamily.pyR?¤s   
    cCs#tjƒ}|j|ƒrtStS(N(RRRpRµR@(RJRK((skD:\SG_ServerCode\ServerPython\ZoneServerGroup\map1_8G\MapServer\MapServerData\Script\Player\PlayerFamily.pytIsFamilyNeedViewPlayer³s cCs#tj|t|ƒdttƒdS(N(R7R RqR”RnRo(R-((skD:\SG_ServerCode\ServerPython\ZoneServerGroup\map1_8G\MapServer\MapServerData\Script\Player\PlayerFamily.pyRs¾sc Cs°tjƒ}|j|ƒ}|s%dS|jƒ}tjƒ}tjƒ}g|_xE|j    ƒD]7\}}|j
|ƒ}tj ƒ}    ||    _ ||    _ |r¤dnd|    _tj|ƒ}
|
rm|
jƒ|    _t|    jƒ|    _|
jƒ|    _|
jƒ|    _|
jƒ|    _|
jƒ|    _|
jƒ|    _|
jƒ|    _ |
j!ƒ|    _"|
j#ƒ|    _$|
j%ƒ|    _&n|jj'|    ƒt|jƒdkr_Pq_q_Wt|jƒ|_(|S(Niiid()RRRERqR7R8R ttagMCFamilyReqJoinInfot ReqJoinListtitemsR9ttagMCFamilyReqJoinPlayerR!tReqTimetIsOnLineRet FindViewCacheRêR¯R R$R_R%R&R'R(R)R*R+R,R-R.R/RRRRR€RR:tReqCnt( R-RKRhRwtcrossPlayerMgrR RJtreqTimeR<treqInfot    viewCache((skD:\SG_ServerCode\ServerPython\ZoneServerGroup\map1_8G\MapServer\MapServerData\Script\Player\PlayerFamily.pyRqÃs@                 cCs,tjƒj|ƒ}t|||dƒdS(Nt__OnJoinFamilyReply(R    RšR®R’(R.RŒR;R2((skD:\SG_ServerCode\ServerPython\ZoneServerGroup\map1_8G\MapServer\MapServerData\Script\Player\PlayerFamily.pytOnJoinFamilyReplyñscCs7|j}|j}tjd||fƒ|jƒ}|jƒ}|dkrQdStjƒ}    |    j|ƒ}
|
svdS|
j    |ƒ} | sdSt
| t ƒs²tjd|ƒdStjd|||f|ƒ|
j ƒ} | j ƒ} |r|| krtjd|ƒdS|g} n| s1tjdƒdStjƒ}|s°x\| D]T}|
j|ƒ|j|ƒ}|sxqJnt|ƒtj|d|
jƒgƒqJWt|ƒdStjdd    ƒ}t|
jƒd
ƒ}g}x*| D]"}|
jƒ|krtj|d ƒPn|j|ƒ}|sX|sXtjd ||ƒtj|d ƒqäqXn|
j|ƒ|
j    |ƒržtjd||ƒtj|dƒqän|    j|ƒ}|rãtjd||f|ƒtj|dƒqänt|
||dtƒ|j|ƒqäWt|ƒ|r3t|d|d|ƒndS(Ns+__OnJoinFamilyReply: tagPlayerID=%s,isOK=%sisûÓÐÕÐÈËȨÏÞ£¬ÎÞ·¨ÉóºËÈËÔ±ÈëÃË!s0ÉóºËÈëÃËÉêÇë: tagPlayerID=%s,familyID=%s,isOK=%ss ²»´æÔÚ¸ÃÉêÇëÈËÔ±! tagPlayerID=%ss ûÓÐÉêÇëÈËÔ±!tjiazu_pan_592934RmiRtjiazu_lhs_202580s$ÀëÏßÍæ¼ÒÎÞ·¨¼ÓÈ빫»á! tagPlayerID=%stjiazu_hwj35_367906sÒѾ­ÊDZ¾Ã˳ÉÔ±! tagPlayerID=%stXW_JZ_InviteErr_Repeats/ÒѾ­¼ÓÈëÆäËû¹«»á! tagPlayerID=%s,tagFamilyID=%sRðRCRj( t TagPlayerIDtIsOKR    RR0RDRRRERFRnRoRqtkeysR7R8RzR9R?R}R`RsR²R³RbR_RRkRÈR@R:R,(R<RŒR;R™Rut tagPlayerIDRRJR-RKRRLRwttagPlayerIDListRŠttagCrossPlayertofflinePlayerCanJoinRtjoinOKPlayerIDListRN((skD:\SG_ServerCode\ServerPython\ZoneServerGroup\map1_8G\MapServer\MapServerData\Script\Player\PlayerFamily.pyRŽösˆ                    
 
      
cCs,tjƒj|ƒ}t|||dƒdS(Nt__OnChangeFamilyJoin(R    RšR®R’(R.RŒR;R2((skD:\SG_ServerCode\ServerPython\ZoneServerGroup\map1_8G\MapServer\MapServerData\Script\Player\PlayerFamily.pytOnChangeFamilyJoinVsc Csý|j}|j}tjd||fƒ|jƒ}|jƒ}|dkrQdStjƒ}    |    j|ƒ}
|
svdS|
j    |ƒ} | sdSt
| t ƒs²tjd|ƒdStjd|||f|ƒ|
j |ƒ|
j |ƒt|dtƒdS(Ns0__OnChangeFamilyJoin: joinReview=%s,joinLVMin=%sis ûÓÐÕÐÈËȨÏÞs4ÐÞ¸ÄÕÐÈËÉèÖÃ: familyID=%s,joinReview=%s,joinLVMin=%sR
(RRR    RR0RDRRRERFRnRot SetJoinReviewt SetJoinLVMinR,R@( R<RŒR;R™Rut
joinReviewt    joinLVMinRJR-RKRRL((skD:\SG_ServerCode\ServerPython\ZoneServerGroup\map1_8G\MapServer\MapServerData\Script\Player\PlayerFamily.pyRœ[s,              cCs,tjƒj|ƒ}t|||dƒdS(Nt__OnChangeFamilyBroadcast(R    RšR®R’(R.RŒR;R2((skD:\SG_ServerCode\ServerPython\ZoneServerGroup\map1_8G\MapServer\MapServerData\Script\Player\PlayerFamily.pytOnChangeFamilyBroadcast{sc Cså|j}|jƒ}|jƒ}|dkr1dStjƒ}|j|ƒ}    |    sVdS|    j|ƒ}
|
sodSt|
tƒs’t    j
d|ƒdS|    j |ƒt    j
dt    j |    j ƒƒt    j |ƒf|ƒt|dtƒdS(NisûÓÐÐ޸Ĺ«¸æÈ¨ÏÞs¸ü¸Ä¹«»á¹«¸æ: Family=%s,¹«¸æ=%sR
(tMsgR0RDRRRERFRntFamilyPowerID_BroadcastR    Rt SetBroadcastR°R`R,R@( R<RŒR;R™Rut    broadcastRJR-RKRRL((skD:\SG_ServerCode\ServerPython\ZoneServerGroup\map1_8G\MapServer\MapServerData\Script\Player\PlayerFamily.pyR¢€s&         2cCs,tjƒj|ƒ}t|||dƒdS(Nt__OnChangeFamilyEmblem(R    RšR®R’(R.RŒR;R2((skD:\SG_ServerCode\ServerPython\ZoneServerGroup\map1_8G\MapServer\MapServerData\Script\Player\PlayerFamily.pytOnChangeFamilyEmblemžscCs)|j}|j}tj|||ƒdS(N(R[R\RR©(R<RŒR;R™RutchangeEmblemIDRÎ((skD:\SG_ServerCode\ServerPython\ZoneServerGroup\map1_8G\MapServer\MapServerData\Script\Player\PlayerFamily.pyR¨£s        cCs,tjƒj|ƒ}t|||dƒdS(Nt__OnChangeFamilyMemLV(R    RšR®R’(R.RŒR;R2((skD:\SG_ServerCode\ServerPython\ZoneServerGroup\map1_8G\MapServer\MapServerData\Script\Player\PlayerFamily.pytOnChangeFamilyMemLV±scCst||j|jƒdS(N(tOnChangeFamilyMemberLVR!RX(R<RŒR;R™Ru((skD:\SG_ServerCode\ServerPython\ZoneServerGroup\map1_8G\MapServer\MapServerData\Script\Player\PlayerFamily.pyR«¶scCs«|s
dS|jƒ}|jƒ}|dkr2dStjƒ}|j|ƒ}|sWdS|j|ƒ}|spdS|dks‹|tjkr tj    d|ƒdS|sÜt
|t ƒs¹dS||krÜtj    d|ƒdSn|j|ƒ}    |    dkrtj    d||ƒdS|s|j ƒtjkr||j ƒkrTtj    d||ƒdS|    j ƒ|j ƒkrtj    d|    j ƒ|ƒdSqn|g}
|tjkrÅt||    ƒ|
j|ƒn¼d} xKt|jƒƒD]7} |j| ƒ} | j ƒ|kr qÞn| d7} qÞWt|jƒtj|d    ƒƒ}| |krttj|d
ƒtj    d || |fƒdSt|    |ƒ|r—|jd    ƒnt|d |
ƒtS( sαä¸ü³ÉԱְλ
    @param curPlayer: ²Ù×÷µÄÍæ¼Ò
    @param tagID: Ä¿±ê³ÉÔ±ID
    @param changeFmlv: ÐÞ¸ÄΪxxְλ
    @param isGMOP: ÊÇ·ñÊÇGMºǫ́·¢ÆðµÄ£¬Èç¹ûÊÇGM·¢ÆðµÄ£¬Ò»°ãcurPlayer´«ÈëµÄΪĿ±ê³ÉÔ±IDʵÀý
    Nis²»´æÔÚ¸ÃְλµÈ¼¶! changeFmlv=%ss²»ÄÜÈÎÃâ×Ô¼ºµÄ¼Ò×åְλs*¸ü¸Ä¼Ò×å³ÉԱְλʱĿ±ê³ÉÔ±²»´æÔÚ! tagID=%ss+Ð޸ĵÄְλ²»ÄܱÈ×Ô¼º¸ß»òƽ¼¶! changeFmlv=%ss0Ð޸ĵÄÄ¿±ê³ÉԱְλ²»ÄܱÈ×Ô¼º¸ß»òƽ¼¶! tagFmlv=%siRVtjiazu_chenxin_31379s?Ŀǰ¸ÃְλµÄÈËÊýÒѾ­´ïµ½ÉÏÏÞ! changeFmlv=%s,fmLVMemCnt=%s >= %sRC(R0RDRRRERFRÉRÊR    RRntFamilyPowerID_ChangeFmlvR”RctChangeFamilyLeaderR:RRRRbR_tDef_FmlSetAttrNameR“R7R}tChangeFamilyMemberLvR¦R,Rµ(R<ttagIDt
changeFmlvtisGMOPRJR-RKRRLt    tagMemberRCt
fmLVMemCntR.t familyMembertmaxCnt((skD:\SG_ServerCode\ServerPython\ZoneServerGroup\map1_8G\MapServer\MapServerData\Script\Player\PlayerFamily.pyR­ºsl      
     !  cCs—|jƒ}|jƒ}|jƒ}||kr4dS|j|ƒ}|r\t|tjƒn|j|ƒt|tjƒt    j
d|||fƒdS(Ns9¼Ò×åÉèÖÃÐÂ×峤! familyID=%s,newLeaderID=%s,befLeaderID=%s( R%RR0RFR²RÉt    fmlMemberRæRÊR    RÄ(Rt newLeaderMemR-t befLeaderIDt newLeaderIDt befLeaderMem((skD:\SG_ServerCode\ServerPython\ZoneServerGroup\map1_8G\MapServer\MapServerData\Script\Player\PlayerFamily.pyR°s     cCsê|jƒ}|jƒ}|jƒ}|jƒ}|j|ƒtjƒj|ƒ}|rt||ƒt    |t
ƒrtj |t |ƒƒqnt jƒjƒ}t||tjtjtj||g|ƒtj|d||gƒdS(NtXW_JZ_AppointFamily(RDR0RêRcRåR7R8R9RiRnRoRpRqR    RRRëRQRìRítDef_FamilyMemberChange_FMLVRé(R¶tchangeFamilyLVR-R³tmemNamet befFamilyLVR™R;((skD:\SG_ServerCode\ServerPython\ZoneServerGroup\map1_8G\MapServer\MapServerData\Script\Player\PlayerFamily.pyR²s      cCs°|jƒ}|j|ƒ}|s%dS|jƒ}|s;dS|jƒ}ttjƒƒ}||}|d}tjddƒ}||kr´tj    d||tj
|ƒ||ƒdStjddƒ}    g}
g} xçt d|j ƒƒD]Ð} |j | ƒ} | jƒtjkrqèn| jƒ}|rG|}||}|d}n|}d}d}| jƒ}| jƒ}| j|||| gƒ|    rè||    krè|
j|||| gƒqèqèW|
rÎ| rÎdSd}|
rû|
jdtƒ|
dd}n| jdtƒ| dd}|s#dS|jƒ}tjd||tj
|ƒ||fƒt||ƒt|d    ||gƒ|jƒ}tjd|g|jƒgd
|ƒdS( Ng ¬@tFamilyLeaderAutoChangeis\ÃËÖ÷ÀëÏß䳬¹ýÏÞÖÆÐ¡Ê±£¬²»´¦Àí×Ô¶¯´«Î»£¡familyID=%s,leaderID=%s,offTime=%s,passHours=%s < %sitreverseiÿÿÿÿsL¹«»á×Ô¶¯´«Î»: familyID=%s,leaderID=%s,offTime=%s,passHours=%s,newLeaderID=%sRCt
toServerID(RRFR8R%RHRIR²R³R    t
DebugLogExRWRRRRcRÉRÊR0R:R”tsortRµR0RÄR°R,R€t
PlayerMailt SendMailByKeyR`(RhtleaderIDt    leaderMemtoffTimeR-tcurTimetpassTimet    passHourst    needHourst priorityHourst priorityListtcommListR R/t
memOffTimetsortTimet memPassTimet memPassHourstfmLVt contribTotalttoMemberR½RÆ((skD:\SG_ServerCode\ServerPython\ZoneServerGroup\map1_8G\MapServer\MapServerData\Script\Player\PlayerFamily.pyR,sl   
 
      
            %cCsdS(N((R.RŒR;((skD:\SG_ServerCode\ServerPython\ZoneServerGroup\map1_8G\MapServer\MapServerData\Script\Player\PlayerFamily.pytOnGetFamilyInfoyscCs,tjƒj|ƒ}t|||dƒdS(Nt__OnMemLeaveFamily(R    RšR®R’(R.RŒR;R2((skD:\SG_ServerCode\ServerPython\ZoneServerGroup\map1_8G\MapServer\MapServerData\Script\Player\PlayerFamily.pyt OnLeaveFamily…sc Csˆ|jƒ}|jƒ}|dkr(dStjƒ}|j|ƒ}|sMdS|j|ƒ}    |    sfdS|    jƒ}
|jƒdkr§|
tj    kr§t
j d|ƒdSt
j d||ƒ|j |ƒt |jƒ|tjtjtjg|ƒt|||ƒt|ddƒtj|t||jƒdƒƒtj|d|jƒgƒt|dtƒ|jƒdkr„|j|ƒdSdS(Niis%×峤ÔÚ³ÉÔ±ÈËÊý´óÓÚ1ʱ²»ÄÜÖ±½ÓÍ˳ö¼Ò×åsÀ뿪¼Ò×å! familyID=%stXW_JZ_LeaveFamilyR
(R0RDRRRERFRcRRÉRÊR    Rt DeleteMemberRëRêRQRìRítDef_FamilyMemberChange_Leavet__DoPlayerLeaveFamilyByIDRiR7R RDRéR,R@t    DelFamily( R<RŒR;R™RuRJR-RKRRLRi((skD:\SG_ServerCode\ServerPython\ZoneServerGroup\map1_8G\MapServer\MapServerData\Script\Player\PlayerFamily.pyRÝŠs8     !     " cCs,tjƒj|ƒ}t|||dƒdS(Nt__OnDeleteFamilyMember(R    RšR®R’(R.RŒR;R2((skD:\SG_ServerCode\ServerPython\ZoneServerGroup\map1_8G\MapServer\MapServerData\Script\Player\PlayerFamily.pytOnDeleteFamilyMember½scCsõ|j}tjd|ƒ|jƒ}||kr6dS|jƒ}|dkrRdStjƒ}|j|ƒ}    |    swdS|    j|ƒ}
|
sdSt    |
t
ƒs°tjdƒdS|    j|ƒ} | sÉdS|
j ƒ} | j ƒ} | | krtjd|| | f|ƒdS| j ƒ}| jƒ}|    j |ƒt||tjtjtjg|ƒtj|d|gƒtjƒj|ƒ}t|    ||ƒ|rÅt|dƒtj|d|
j ƒgƒntj|t||dƒƒt|dtƒdS(Ns%__OnDeleteFamilyMember tagMemberID=%sis ûÓÐÌßÈËȨÏÞ!sCÖ»ÄÜÌß±È×Ô¼ºÖ°Î»µÍµÄ³ÉÔ±! tagMemberID=%s,tagFmlv(%s) >= curFmlv(%s)RßtXW_JZ_LeaveFamilyKickR
(tMemberIDR    RR0RDRRRERFRntFamilyPowerID_KickRcRêRàRëRQRìRítDef_FamilyMemberChange_KickOutR7RéR8R9RâRiR}R RDR,R@(R<RŒR;R™Rut tagMemberIDRJR-RKRRLR¶tcurFmlvttagFmlvt tagPlayerNameR—R™((skD:\SG_ServerCode\ServerPython\ZoneServerGroup\map1_8G\MapServer\MapServerData\Script\Player\PlayerFamily.pyRäÂsP                 cCstj||ƒdS(N(R(tOnFamilyMemberLeave(Rht leavePlayerIDR<((skD:\SG_ServerCode\ServerPython\ZoneServerGroup\map1_8G\MapServer\MapServerData\Script\Player\PlayerFamily.pyRâüsc    Cs™tjƒj|ƒ}|j}t||ƒs>tjdƒdStjddƒ\}}|r||r|tj    |||ƒ r|dSt
|||dt dƒdS(NsÃû×ÖÑéÖ¤²»Í¨¹ýt FamilyRenameit__UpdateFamilyNamei( R    RšR®tNewNameR±RR²RR|R´R’Rµ(R.RŒR;R2tnewNameR¸t
moneyValue((skD:\SG_ServerCode\ServerPython\ZoneServerGroup\map1_8G\MapServer\MapServerData\Script\Player\PlayerFamily.pytUpdateFamilyName
s     "c    Cs|j}|jƒ}|jƒ}|dkr1dStjƒ}|j|ƒ}    |    sVdS|    j|ƒ}
|
sodS|
jƒtj    kr˜t
j d|ƒdSt t j ƒƒ} tjddƒ} | r| d} t|    ƒ}|r| || krt
j dt
j|ƒ| fƒdSnt|||ƒr+dStjddƒ\}}|ro|rotj|ddi||6ƒn|    j|ƒ| r’t|    | ƒntjƒ}x]t|    jƒƒD]I}|    j|ƒ}|jƒ}|j|ƒ}|síq±nt||ƒq±Wt|d    tƒt S(
Nis·ÇÃËÖ÷²»¿É¸ÄÃû!Rðiis*¹«»á¸ÄÃûCDÖÐ! lastRenameTime=%s,cdHours=%siR»R
(!RòR0RDRRRERFRcRÉRÊR    RRHRIR²R³RRWR¼RR7RÇRõRR8R)RRR9RiR,R@Rµ(R<RŒR;R™RuRóRJR-RKRRLRÎtcdHourst    cdSecondstlastRenameTimeR¸RôRŠR.R/R=tmemCrossPlayer((skD:\SG_ServerCode\ServerPython\ZoneServerGroup\map1_8G\MapServer\MapServerData\Script\Player\PlayerFamily.pyRñsR        
       cCs™tjƒj|ƒ}|jƒ}|j}|j}| sR|tjƒjƒkrltj    |t
|ƒƒdSt j t ji|d6|gt j|ƒdS(NRN(R    RšR®R0RWt DataServerIDRR€R•RptGetTagFamilyInfoPackROt SendToServerRQtS2S_ViewTagFamilyt dirType_All(R.RŒR;R2RJRNt dataServerID((skD:\SG_ServerCode\ServerPython\ZoneServerGroup\map1_8G\MapServer\MapServerData\Script\Player\PlayerFamily.pytOnViewTagFamilyTs         )cCs'|d}tj|t|ƒ|ƒdS(NRN(R7tSendFakePackByIDRû(RTR™RJRN((skD:\SG_ServerCode\ServerPython\ZoneServerGroup\map1_8G\MapServer\MapServerData\Script\Player\PlayerFamily.pyRýbs
cCsotjƒ}|j|ƒ}|s6tjd|ƒdStjƒ}|jƒ|_|j    ƒ|_
t |j
ƒ|_ |j ƒ|_|j|jƒ}|rÌ|jƒ|_t |jƒ|_|jƒ|_n|jƒ|_|jƒ|_|jƒ|_|jƒ|_|jƒ|_|jƒ|_|j ƒ|_!t |j!ƒ|_"|j#ƒ|_$tj%ƒjƒ|_&|S(Ns&±¾·þÊý¾ÝÕÒ²»µ½Ä¿±ê¹«»á! tagFamilyID=%s('RRRER    R~R ttagSCTagFamilyInfoR%RWR`RZR t FamilyNameLenRRRFRêt
LeaderNamet LeaderNameLenR€tLeaderServerIDR_RYRRaR[RbR\RRRRRRRRR;RRú(RNRKRR t leaderMember((skD:\SG_ServerCode\ServerPython\ZoneServerGroup\map1_8G\MapServer\MapServerData\Script\Player\PlayerFamily.pyRûgs4  cCs,tjƒj|ƒ}t|||dƒdS(Nt__OnViewFamilyPage(R    RšR®R’(R.RŒR;R2((skD:\SG_ServerCode\ServerPython\ZoneServerGroup\map1_8G\MapServer\MapServerData\Script\Player\PlayerFamily.pytOnViewFamilyPagescCse|j}|j}t|jdƒ}tjƒ}|j|ƒ}    |    dkr`tjd|ƒdS|j    ƒ}
|j
|    ƒ} | j t ƒ| j ƒ} d} |sÜ||}||d}| dkrþtj| |ƒ} qþn"d}d}d} d}| d}tjƒ}||_t|jƒ|_||_||_| |_| j|
ƒ|_g|_xót||dƒD]Þ}|| kr…Pn| j|ƒ}|s qon|rÙ||jƒksÖ|t|jƒƒkroqÙqontjƒ}|d|_|jƒ|_|jƒ|_t|jƒ|_|j ƒ|_!|j"|j!ƒ}|rU|j#ƒnd|_$t|j$ƒ|_%|r‚|j&ƒn    |j&ƒ|_'|j(ƒ|_)|j*ƒ|_+|j,ƒ|_-|j&ƒ|_.|j/ƒ|_0|j1ƒ|_2|j3ƒ|_4|j5ƒ|_6|j ƒ|_7|jj8|ƒt|jƒ|_9|j9|kroPqoqoWt:j;||ƒdS(Ni2is1ÕÒ²»µ½·þÎñÆ÷IDÔÚ±¾·þÖеĹ«»á·ÖÇø! fromServerID=%siiRV(<R¤t    PageIndextmint    ShowCountRRRàR    R~RDRRËRµRt GetIntUpperR ttagMCFamilyViewListR tMsgLent    TotalPaget GetFamilyRanktRankt
FamilyListRRR`RR%ttagMCFamilyViewRWRZRRRRFRêRRR€RR_RYRRRRRRaR[RbR\RRRRR;R:t FamilyCountR7Rp(R<RŒR;R™Rutmsgt    pageIndext    showCountRKRRÐRt familyCountt    totalPaget
startIndextendIndexR R.Rt
familyViewR((skD:\SG_ServerCode\ServerPython\ZoneServerGroup\map1_8G\MapServer\MapServerData\Script\Player\PlayerFamily.pyR’s„             
 
                      *  !c
Cstjƒj|ƒ}|jƒ}|j}tjd|ƒ}|sFdS|jƒ}|jt    j
|ƒ}||kr•tj d|||f|ƒdS|j ƒ}    |j ƒ}
|     s»|
r¿dStj||    |
ƒsØdSi|d6} t|||dtdd| ƒdS(Nt FamilyDonates6½ñÈÕ¾èÏ×´ÎÊýÒÑ´ïÉÏÏÞ! donateType=%s,donateCnt=%s >= %st    donateCntt__OnFamilyMoneyDonateiRu(R    RšR®R0t
DonateTypeR²Rht GetDailyCnttNomalDictGetPropertyRQtDef_Player_Dict_FamilyDonateCntRt GetMoneyTypet GetMoneyValueR|R´R’Rµ( R.RŒR;R2RJt
donateTypeRkt dailyCntMaxRR¸RôRu((skD:\SG_ServerCode\ServerPython\ZoneServerGroup\map1_8G\MapServer\MapServerData\Script\Player\PlayerFamily.pytOnFamilyMoneyDonateçs(          cCs³|j}|jƒ}|jƒ}|dkr1dStjƒ}|j|ƒ}    |    sVdS|    j|ƒ}
|
sodS|sydSd|kr‰dS|d} tjd|ƒ} | s¯dS| j    ƒ} | j
ƒ}| sÕ| rÙdSt j |ddi|| 6ƒ| j ƒ}| d7} t j|i| tj|6dtƒ|
jƒd}t|
jƒdtjƒ}|
j|ƒ|
j|ƒtjd|| |||f|ƒt j||d    dƒtS(
NiRRtFamilyMoneyDonateR»it
isDayResetsM¼Ò×å¾èÏ×: donateType=%s,donateCnt=%s,%s,memDonateCntDay=%s,memDonateCntDay=%st    eventName(R!R0RDRRRERFR²RhR%R&R7RÇtGetAwardItemListtSetPlayerNomalDictRQR$RµR6R R4tDef_UpperLimit_DWordR+tSetDonateCntTotalR    RtGivePlayerResources(R<RŒR;R™RuR'RJR-RKRhRLRRkR¸Rôt awardItemListtmemDonateCntDaytmemDonateCntTotal((skD:\SG_ServerCode\ServerPython\ZoneServerGroup\map1_8G\MapServer\MapServerData\Script\Player\PlayerFamily.pyR sH         
 
$      cCs|s
dSt|ƒdS(N(tSyncDonateCntInfo(R2RŒR((skD:\SG_ServerCode\ServerPython\ZoneServerGroup\map1_8G\MapServer\MapServerData\Script\Player\PlayerFamily.pyt__OnFamilyMoneyDonate_Ret.s
c    Cs<d\}}i|d6}t|||dddd|ƒdS(NitaddExpt__AddFamilyExpRRu(Ni(R”R’(R2R7RŒR;Ru((skD:\SG_ServerCode\ServerPython\ZoneServerGroup\map1_8G\MapServer\MapServerData\Script\Player\PlayerFamily.pyt AddFamilyExp4s  cCsk|jƒ}|jƒ}|dkr(dStjƒ}|j|ƒ}|sMdS|jƒ}    |jƒ}
|sodS|d} |    } |
| } tjd|    |
| | f|ƒt    j
d|    ƒ}|j ƒ}xs|r<| |kr<t    j d| dƒ}|süPn| d7} | |8} |j ƒ}tjd| | |f|ƒqÊW|j | ƒ|j| ƒt|dtƒtS(NiR7s4Ôö¼Ó¹«»á¾­Ñé: curLV=%s,curExp=%s,addExp=%s,updExp=%sRgis+    ¹«»áÉý¼¶: updLV=%s,updExp=%s,lvUPExp=%sR
(R0RDRRRER_RR    RR²Rht
GetNeedExptGetIpyGameDataNotLogRÀtSetExpR,R@Rµ(R<RŒR;R™RuRJR-RKRhtcurLVtcurExpR7tupdLVtupdExpRktlvUPExp((skD:\SG_ServerCode\ServerPython\ZoneServerGroup\map1_8G\MapServer\MapServerData\Script\Player\PlayerFamily.pyR8:s<      
 
  
 
 !  c    Cs<d\}}i|d6}t|||dddd|ƒdS(NitaddContribValuet__AddFamilyContribRRu(Ni(R”R’(R2RBRŒR;Ru((skD:\SG_ServerCode\ServerPython\ZoneServerGroup\map1_8G\MapServer\MapServerData\Script\Player\PlayerFamily.pytAddFamilyContrib_s  c Csô|jƒ}|jƒ}|dkr(dStjƒ}|j|ƒ}|sMdS|j|ƒ}    |    sfdS|spdS|d}
|    jƒ|
} t|    jƒ|
t    j
ƒ} |    j | ƒ|    j | ƒt jd||
| | f|ƒt|dtƒdS(NiRBsJÔö¼Ó³ÉÔ±¹±Ï×: familyID=%s,addContribValue=%s,contribDay=%s,contribTotal=%sR
(R0RDRRRERFR2R R0RQR/R*tSetContribTotalR    RR,R@( R<RŒR;R™RuRJR-RKRhRLRBt
contribDayRÚ((skD:\SG_ServerCode\ServerPython\ZoneServerGroup\map1_8G\MapServer\MapServerData\Script\Player\PlayerFamily.pyRCes*    
   cCs,tjƒj|ƒ}t|||dƒdS(Nt__OnQueryFamilyAction(R    RšR®R’(R.RŒR;R2((skD:\SG_ServerCode\ServerPython\ZoneServerGroup\map1_8G\MapServer\MapServerData\Script\Player\PlayerFamily.pytOnQueryFamilyAction‰scCs;|j}|j}|s'|jƒ}nt|||ƒdS(N(t
ActionTypeRWRDtSendFamilyActionInfo(R<RŒR;R™RuRùR-((skD:\SG_ServerCode\ServerPython\ZoneServerGroup\map1_8G\MapServer\MapServerData\Script\Player\PlayerFamily.pyRGŽs         cCs||s
dStjƒj||ƒ}tjƒ}||_||_g|_xðt|j    ƒƒD]Ü}|j
|ƒ}tj ƒ}|j ƒ|_ |jƒ|_t|jƒ|_|jƒ|_|jƒ|_|jƒ|_|jƒ|_|jƒ|_|jƒ|_|jƒ|_t|jƒ|_ |jj!|ƒq\Wt|jƒ|_    |rht"j#||ƒdSt"j$||ƒdS(N(%RRòRóR ttagMCFamilyActionInfoRWRItFamilyActionListR)tCounttAtttagMCFamilyActiontGetTimetTimeR`R¯R R$t    GetValue1tValue1t    GetValue2tValue2t    GetValue3tValue3t    GetValue4tValue4t    GetValue5tValue5t    GetValue6tValue6t GetUserDatatUseDatat
UseDataLenR:R7RpR (R<R-RùRýR R.tfamilyActionDataRþ((skD:\SG_ServerCode\ServerPython\ZoneServerGroup\map1_8G\MapServer\MapServerData\Script\Player\PlayerFamily.pyRJ–s8              cCs†t|tƒs|g}n|s%dS|d}|jƒ}|jƒ}tjƒ}||_||_g|_xÕ|D]Í}tj    ƒ}|j
ƒ|_ |j ƒ|_ t|j ƒ|_|jƒ|_|jƒ|_|jƒ|_|jƒ|_|jƒ|_|jƒ|_|jƒ|_t|jƒ|_|jj|ƒquWt|jƒ|_ |rrt!j"||ƒdSt!j#||ƒdS(Ni($RãtlistRDt GetActionTypeR RKRWRIRLRORPRQR`R¯R R$RRRSRTRURVRWRXRYRZR[R\R]R^R_R`R:RMR7RpR (RúR<RaR-RùR Rþ((skD:\SG_ServerCode\ServerPython\ZoneServerGroup\map1_8G\MapServer\MapServerData\Script\Player\PlayerFamily.pytSendFamilyAction»s> 
                 cCsStjƒj|ƒ}|sdS|d}|d}|dkrOt||ƒndS(NRMRNR^(R    RšR›tDo_MapServer_FamilyRefresh(RTRJR2RMRN((skD:\SG_ServerCode\ServerPython\ZoneServerGroup\map1_8G\MapServer\MapServerData\Script\Player\PlayerFamily.pyRRès
 
 cCst|ƒdS(N(tResetDailyDonateCnt(R2((skD:\SG_ServerCode\ServerPython\ZoneServerGroup\map1_8G\MapServer\MapServerData\Script\Player\PlayerFamily.pyR5òs
cCs(tj|ƒt|ƒtj|ƒdS(N(R tSync_FamilyCrossInfoR5R&R=(R2((skD:\SG_ServerCode\ServerPython\ZoneServerGroup\map1_8G\MapServer\MapServerData\Script\Player\PlayerFamily.pyR6ös 
 cCstjƒjƒ}|jƒ}|d}|jddƒ}|jddƒ}|jddƒ}|jddƒ}|jddƒ}    tj|||||    ƒ|jƒ}
|jƒ} t    j
|ƒ} |
|krÞ|j |ƒn|j ƒ|kr|j |ƒn| |krt    j||ƒn| |kr{t} | rL|dkrLt} n|j|ƒt    j|tj|ƒ| r{q{n|
dkr¾|jƒdkr¾|jd    dƒ}t|||ƒnF|
dkr|jƒdkr|j
ƒtjkrônt||ƒn|jƒdS(
NRWRXiRYRZRVR[R\R](R    RRR0R“ReRfRDt GetFamilyLVR|tGetFamilyMemberLVRdt GetFamilyNamet SetFamilyNametSetFamilyMemberLVR@Rµt SetFamilyLVtNomalDictSetPropertyRQtDef_Player_Dict_FamilyLVt__OnLeaveFamilyt IPY_GameWorldRÊt__OnEnterFamilytView_FamilyInfoRefresh(R2RNR;RJRrt refreshFmLVtrefreshFamilyLVtrefreshFamilyNametrefreshEmblemIDtrefreshEmblemWordt lastFamilyIDt lastFamilyLVtlastFmLVtisLVUPR]((skD:\SG_ServerCode\ServerPython\ZoneServerGroup\map1_8G\MapServer\MapServerData\Script\Player\PlayerFamily.pyReüsF 
          
cCstj|tjƒdS(N(ROt UpdTaskValueRQRR(R2R;((skD:\SG_ServerCode\ServerPython\ZoneServerGroup\map1_8G\MapServer\MapServerData\Script\Player\PlayerFamily.pyRr2sc Cs|jdƒ|jdƒ|jdƒ|jdƒ|jdƒtj|ttjƒƒƒtj    |ƒ\}}}t
j d|||fƒt j ddƒd}}|r t jddƒ}|rït|ƒ|krâ||n|d}n|d7}t
j d|ƒn\t jdd    ƒ}|rNt|ƒ|krA||n|d}n|d7}t
j d
|ƒtj||||ƒ|rç|rçtj||ƒ}    t|    |d ƒ}
t
j d |||    |
fƒtj|||
d ƒntj|ƒtj||ƒdS(Nis:__OnLeaveFamily: isVoluntarily=%s,leaveCnt=%s,kickedCnt=%sRTiiiÿÿÿÿis!    Ôö¼ÓÖ÷¶¯À뿪´ÎÊý: leaveCnt=%sis"    Ôö¼Ó±»ÌßÀ뿪´ÎÊý: kickedCnt=%sgY@sD    ¿Û³ý»õ±Ò: delMoneyType=%s,delMoneyPer=%s,nowMoney=%s,delMoney=%st LeaveFamily(t    SetPerExptSetFamilyHornortSetFamilyActiveValuetSetLastWeekFamilyActiveValueRmR|tSetLeaveFamilyTimeExRHRIRVR    RR²R³RR tSetLeaveFamilyInfotGetMoneytPayMoneyR(tOnPlayerLeaveFamilytFBLogicRÞ( R2R]R;RYRZt_t delMoneyTypet delMoneyPertdelMoneyPerListtnowMoneytdelMoney((skD:\SG_ServerCode\ServerPython\ZoneServerGroup\map1_8G\MapServer\MapServerData\Script\Player\PlayerFamily.pyRp7s:     )
)
  cCs t}tjƒ}xtt|jƒƒD]`}|j|ƒ}|jƒ}|jtj    |ƒ}|r%t
j |tj    |dƒt }q%q%W|rœt |ƒndS(Ni(R@R²tIPY_DataRtGetFamilyDonateCounttGetFamilyDonateByIndext GetDonateTypeR#RQR$R|RnRµR5(R2tisResett
ipyDataMgrR.RkR'R((skD:\SG_ServerCode\ServerPython\ZoneServerGroup\map1_8G\MapServer\MapServerData\Script\Player\PlayerFamily.pyRf\s    cCs²g}tjƒ}xXt|jƒƒD]D}|j|ƒ}|jƒ}|jtj|ƒ}|j    |ƒq%W|swdSt
j ƒ}||_ t |j ƒ|_tj||ƒdS(N(R²RRRR‘R’R#RQR$R:R ttagSCDonateCntInfot DonateCntListR RMR•Rp(R2t donateCntListR”R.RkR'RR ((skD:\SG_ServerCode\ServerPython\ZoneServerGroup\map1_8G\MapServer\MapServerData\Script\Player\PlayerFamily.pyR5js       i(…RˆRQR    RQR|R•ReR RR&R(RÉR²RqRÉROR7RÙRR RORƒRÂRIRÛRRoR¯R¥RèRºt fmlCounsellort fmlViceLeaderR±RRRRRRR"R$R!R3R4R1R=R:RBRARURiR>RsR@R”R’R‹R˜RR‚RœR¹R­R±R¼RµRÈRëRnRmR,RRDRERIRFRSRGRKRbRLRMR?RRsRqRRŽRRœR£R¢R©R¨R¬R«R­R°R²RRÜRÞRÝRåRäRâRõRñRRýRûR    RR)R R6R9R8RDRCRHRGRJRdRRR5R6ReRrRpRfR5(((skD:\SG_ServerCode\ServerPython\ZoneServerGroup\map1_8G\MapServer\MapServerData\Script\Player\PlayerFamily.pyt<module>sú                        
 
                             
                                                      "    #    /            
        9     .        :                         +         8                  .    `                  G            M         3    :      >            &    U    .        %    $        % -    
            6        %