|
嘿COM,
8 K' m, e" V$ U9 F. o- [9 CNEN有点无聊和我开始思考,我写的关于如何得到从GM -喊名字一点时间NEN啧。
# e7 Z, V6 ~9 [6 U+ x8 H4 g- t后,整个看起来像这样:8 q& ?0 g v) ^, |5 g
6 p6 @3 M$ J. h {4 t1 W. b% G! n6 j+ H3 W
可我第一次补习,所以如果有批评,请说,从而提高自我。
' l7 q7 D7 g' \! P! G& j' o1 c, p我不知道我的代码是最优的,肯定有一个更好的解决办法,我还是C ++初学者。
+ }4 O6 F& l; V0 w1 x$ I5 G* m4 E; v4 a" @& d+ x( y- I
所以,当你第一次打开了FuncTextCmd.cpp和搜索$ }8 z# a* w& j/ ?
. n; H! Z- B* L4 b代码: BOOL TextCmd_System( CScanner& scanner ) 3 e/ m9 C; n, h: f9 a
在那里,您会发现:/ j( @$ |' V. ^8 z! P
代码: { #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; } 3 u3 x" Z* y8 t6 n8 y. o
现在我们引入一个新的变量,我只需调用szName的6 d4 h1 b# [2 D. j
那么整个事情看起来像这样:
W! |' E$ e2 r; G4 c7 F* y" b+ H代码: { #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; } 2 C* Q) Q6 W- w1 z6 ]8 E
变量我们也等于“[”拯救我们以后的工作XD: f) k+ l/ Y5 W: n& d
: d( I$ {% A$ z( N& y
然后,我们明确了scanner.GetLastFull测试()源;在g_DPCoreClient.SendSystem(szString)。" U. {) v5 v; `
, F8 _9 O4 N C1 b) b9 ^
整个事情是这样的:
: v; P& T6 |5 j' R% G+ D) x6 ]代码: { #ifdef __WORLDSERVER CHAR szString[512] = ""; CHAR szName[512] = "["; CUser* pUser =(CUser*)scanner.dwValue; #endif // __WORLDSERVER return TRUE; }
( `8 T+ c- E d7 T9 Q! z0 Q# i并提出了下列:
0 ?, w& L ?( N. g代码: { #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; } , A/ b8 j2 h! N5 q' B2 G+ x
现在,通用汽车应该喊这样的:
/ F* i# _* H- f* | ^ p代码: [GM Information][NAME] TEXT
8 \# O# A; L5 F" y3 ~现在,如果你仍然希望出现这种情况,例如有管理员将需要插入她的下列内容:
) c/ h7 @# v8 ~代码: { #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; } : r M1 B# B- b O# n0 s5 ~' _: Z
如果你想不仅为管理这一点,你必须始终$ j) Y- H2 O, K* M* O8 z$ w
代码: else if(pUser->m_dwAuthorization == AUTHORIZATION) strcat( szName, "Admin][" );
. W0 r! g& a: B! E6 d* G# C补充。
! e: ?: K3 D8 c# Z
$ ]9 j5 |, T4 D( B I) Z& v G) p' ^$ u( m
下面是与使用/ SYS解决不同的授权清单:5 _1 ^$ {- B6 u
代码: AUTH_GAMEMASTER1 //Gamemaster lvl 1 AUTH_GAMEMASTER2 //Gamemaster lvl 2 AUTH_GAMEMASTER3 //Gamemaster lvl 3 AUTH_ADMINISTRATOR //Administrator
6 \6 o+ g8 m, G! i8 N6 ]希望你喜欢指导,批评是欢迎的。 O7 L1 q8 m0 B1 H# r9 I$ ~
e3 j, f/ g5 _! Y8 Y制作所Pumbaaa
' a t" q w9 c3 D9 B+ V |