|
嘿COM,
% N4 A, f, `/ M: c0 |' B. J4 LNEN有点无聊和我开始思考,我写的关于如何得到从GM -喊名字一点时间NEN啧。
4 g' x1 q* g- [$ O后,整个看起来像这样:: |. R3 ^5 w+ y% A- ~0 p- Z) u
- v% `' V0 D+ h! y
/ x. N( X' [1 ~" F' [
可我第一次补习,所以如果有批评,请说,从而提高自我。
" D0 r" v2 I' _% H2 X7 Q1 o我不知道我的代码是最优的,肯定有一个更好的解决办法,我还是C ++初学者。* c% }" E, g( T. ~4 L
4 N, U- e* u- F9 k: Y! k所以,当你第一次打开了FuncTextCmd.cpp和搜索1 p3 _: m" n# F0 p; C# h" A
@6 L2 h1 g' I7 X
代码: BOOL TextCmd_System( CScanner& scanner ) : r- q' f- `% \
在那里,您会发现:; K% w- W+ n, }6 t) M
代码: { #ifdef __WORLDSERVER CHAR szString[512] = ""; CUser* pUser =(CUser*)scanner.dwValue; scanner.GetLastFull(); if( strlen( scanner.token ) >= 512 ) return TRUE; strcpy( szString, scanner.token ); StringTrimRight( szString ); g_DPCoreClient.SendSystem( szString ); #endif // __WORLDSERVER return TRUE; }
- G# b0 ^+ J/ u* \, q2 z% g7 c现在我们引入一个新的变量,我只需调用szName的
2 x: o. P( V0 k7 r7 @* w1 p0 K那么整个事情看起来像这样:
$ B @; R) w. R7 X+ u- ]9 q4 i7 W代码: { #ifdef __WORLDSERVER CHAR szString[512] = ""; CHARszName[512] = "["; CUser* pUser =(CUser*)scanner.dwValue; scanner.GetLastFull(); if( strlen( scanner.token ) >= 512 ) return TRUE; strcpy( szString, scanner.token ); StringTrimRight( szString ); g_DPCoreClient.SendSystem( szString ); #endif // __WORLDSERVER return TRUE; } 1 w5 Y2 e/ v/ ]% ?$ S) _
变量我们也等于“[”拯救我们以后的工作XD7 X4 e+ J) @! `# w
/ @% ~9 h9 q# g" U! |1 b
然后,我们明确了scanner.GetLastFull测试()源;在g_DPCoreClient.SendSystem(szString)。5 ]* t; c* f0 g/ R
, Y$ L! f8 i$ Q+ S8 P整个事情是这样的:9 `5 f7 _! g1 a" r' `
代码: { #ifdef __WORLDSERVER CHAR szString[512] = ""; CHAR szName[512] = "["; CUser* pUser =(CUser*)scanner.dwValue; #endif // __WORLDSERVER return TRUE; } 4 a5 |% ~4 E$ G" {, ~* |" O; _
并提出了下列:, P9 P4 B& R; U' T
代码: { #ifdef __WORLDSERVER CHAR szString[512] = ""; CHAR szName[512] = "["; CUser* pUser =(CUser*)scanner.dwValue; strcat( szName, pUser->GetName()); strcat( szName, "]: "); scanner.GetLastFull(); if( strlen( scanner.token ) >= 512 ) return TRUE; strcpy( szString, scanner.token ); StringTrimRight( szString ); strcat( szName, szString ); g_DPCoreClient.SendSystem( szName ); #endif // __WORLDSERVER return TRUE; }
8 l- r5 X: m! F5 O) R A现在,通用汽车应该喊这样的:6 m* v( H4 C% L) u! G
代码: [GM Information][NAME] TEXT
3 g% ^3 x5 c6 h0 K- q! N& J' i现在,如果你仍然希望出现这种情况,例如有管理员将需要插入她的下列内容:4 J* A9 G2 W K5 _
代码: { #ifdef __WORLDSERVER CHAR szString[512] = ""; CHAR szName[512] = "["; CUser* pUser =(CUser*)scanner.dwValue; //FüR ADMIN if(pUser->m_dwAuthorization ==AUTH_ADMINISTRATOR) strcat( szName,"Admin][" ); strcat( szName, "TestGM][" ); strcat( szName, pUser->GetName()); strcat( szName, "]: "); scanner.GetLastFull(); if( strlen( scanner.token ) >= 512 ) return TRUE; strcpy( szString, scanner.token ); StringTrimRight( szString ); strcat( szName, szString ); g_DPCoreClient.SendSystem( szName ); #endif // __WORLDSERVER return TRUE; }
0 R" _( `: n3 g6 m, W8 _如果你想不仅为管理这一点,你必须始终) J+ \6 b, s1 b/ U
代码: else if(pUser->m_dwAuthorization == AUTHORIZATION) strcat( szName, "Admin][" );
2 c0 l2 d) _2 H$ [- R# ?* V5 s- o5 V6 N* w补充。
) z* i) v( o$ n `; `. [$ a4 F0 ~ _
2 J9 s. f. E4 a9 }$ s( l
; e* J! Y/ V6 k+ h. \7 x下面是与使用/ SYS解决不同的授权清单:/ k2 z1 [/ h* L# t1 f
代码: AUTH_GAMEMASTER1 //Gamemaster lvl 1 AUTH_GAMEMASTER2 //Gamemaster lvl 2 AUTH_GAMEMASTER3 //Gamemaster lvl 3 AUTH_ADMINISTRATOR //Administrator 3 g. X3 b* y O3 M5 h
希望你喜欢指导,批评是欢迎的。
7 @! E! s \, d: H% @2 K" D8 y0 @: m1 ~5 d7 a M2 m, K
制作所Pumbaaa " U1 K2 b7 S2 ?3 a6 M1 @
|