ServerCmd(): Difference between revisions
Jump to navigation
Jump to search
Warning:Since
TomEdwards (talk | contribs) m (avoid C++ redir :-p) |
TomEdwards (talk | contribs) mNo edit summary |
||
Line 1: | Line 1: | ||
'''<code>ServerCmd()</code>''' is a quick and easy method for passing user input to the server available through <code>[[cbase.h]]</code>. It uploads an [[Wikipedia:ASCII|ASCII]] string, including with it information about which connected client sent it. The received strings are processed in <code> | '''<code>ServerCmd()</code>''' is a quick and easy method for passing user input to the server available through <code>[[cbase.h]]</code>. It uploads an [[Wikipedia:ASCII|ASCII]] string, including with it information about which connected client sent it. The received strings are processed in '''<code>ClientCommand()</code>''' as a <code>[[CCommand]]</code> (i.e. a string array where 0 is the command itself and 1+ are parameters). | ||
{{warning|Since <code>ServerCmd()</code> passes a full string value, it is NOT suitable for commands that will be sent frequently. Single-player mods can probably get away with the overhead, '''but multiplayer mods must send with the [[Usercmd]] instead'''.}} | {{warning|Since <code>ServerCmd()</code> passes a full string value, it is NOT suitable for commands that will be sent frequently. Single-player mods can probably get away with the overhead, '''but multiplayer mods must send with the [[Usercmd]] instead'''.}} | ||
Line 7: | Line 7: | ||
engine->ServerCmd( [[VarArgs()|VarArgs]]<span style="color:gray;">("MyCommand %i", m_iMyNumber)</span> ); ''// No variables? Pass the command as a simple string.'' | engine->ServerCmd( [[VarArgs()|VarArgs]]<span style="color:gray;">("MyCommand %i", m_iMyNumber)</span> ); ''// No variables? Pass the command as a simple string.'' | ||
''server:'' | ''server:'' | ||
bool | bool CBasePlayer::ClientCommand( const CCommand &args ) | ||
{ | { | ||
if ( ![[V_stricmp()|V_stricmp]]( args[0], "MyCommand" ) ) | if ( ![[V_stricmp()|V_stricmp]]( args[0], "MyCommand" ) ) |
Revision as of 09:06, 4 April 2008
ServerCmd()
is a quick and easy method for passing user input to the server available through cbase.h
. It uploads an ASCII string, including with it information about which connected client sent it. The received strings are processed in ClientCommand()
as a CCommand
(i.e. a string array where 0 is the command itself and 1+ are parameters).

ServerCmd()
passes a full string value, it is NOT suitable for commands that will be sent frequently. Single-player mods can probably get away with the overhead, but multiplayer mods must send with the Usercmd instead.Example
client: engine->ServerCmd( VarArgs("MyCommand %i", m_iMyNumber) ); // No variables? Pass the command as a simple string. server: bool CBasePlayer::ClientCommand( const CCommand &args ) { if ( !V_stricmp( args[0], "MyCommand" ) ) { Msg( "MyCommand received! Value: %i\n", atoi(args[1]) ); return true; } }