#include "stdafx.h"
#include "core/alloc_func.hpp"
#include "core/math_func.hpp"
#include "string_func.h"
#include "console_internal.h"
#include "network/network.h"
#include "network/network_func.h"
#include <stdarg.h>
Go to the source code of this file.
Defines | |
#define | ICON_BUFFER 79 |
#define | ICON_HISTORY_SIZE 20 |
#define | ICON_LINE_HEIGHT 12 |
#define | ICON_RIGHT_BORDERWIDTH 10 |
#define | ICON_BOTTOM_BORDERWIDTH 12 |
#define | ICON_MAX_ALIAS_LINES 40 |
#define | ICON_TOKEN_COUNT 20 |
#define | IConsoleAddSorted(_base, item_new, IConsoleType, type) |
Perhaps ugly macro, but this saves us the trouble of writing the same function three types, just with different variables. | |
Functions | |
void | IConsoleInit () |
static void | IConsoleWriteToLogFile (const char *string) |
bool | CloseConsoleLogIfActive () |
void | IConsoleFree () |
void | IConsolePrint (ConsoleColour colour_code, const char *string) |
Handle the printing of text entered into the console or redirected there by any other means. | |
void CDECL | IConsolePrintF (ConsoleColour colour_code, const char *s,...) |
Handle the printing of text entered into the console or redirected there by any other means. | |
void | IConsoleDebug (const char *dbg, const char *string) |
It is possible to print debugging information to the console, which is achieved by using this function. | |
void | IConsoleWarning (const char *string) |
It is possible to print warnings to the console. | |
void | IConsoleError (const char *string) |
It is possible to print error information to the console. | |
bool | GetArgumentInteger (uint32 *value, const char *arg) |
Change a string into its number representation. | |
static void | IConsoleHookAdd (IConsoleHooks *hooks, IConsoleHookTypes type, IConsoleHook *proc) |
General internal hooking code that is the same for both commands and variables. | |
static bool | IConsoleHookHandle (const IConsoleHooks *hooks, IConsoleHookTypes type) |
Handle any special hook triggers. | |
void | IConsoleCmdHookAdd (const char *name, IConsoleHookTypes type, IConsoleHook *proc) |
Add a hook to a command that will be triggered at certain points. | |
void | IConsoleVarHookAdd (const char *name, IConsoleHookTypes type, IConsoleHook *proc) |
Add a hook to a variable that will be triggered at certain points. | |
void | IConsoleCmdRegister (const char *name, IConsoleCmdProc *proc) |
Register a new command to be used in the console. | |
IConsoleCmd * | IConsoleCmdGet (const char *name) |
Find the command pointed to by its string. | |
void | IConsoleAliasRegister (const char *name, const char *cmd) |
Register a an alias for an already existing command in the console. | |
IConsoleAlias * | IConsoleAliasGet (const char *name) |
Find the alias pointed to by its string. | |
static int | IConsoleCopyInParams (char *dst, const char *src, uint bufpos) |
copy in an argument into the aliasstream | |
static void | IConsoleAliasExec (const IConsoleAlias *alias, byte tokencount, char *tokens[ICON_TOKEN_COUNT]) |
An alias is just another name for a command, or for more commands Execute it as well. | |
void | IConsoleVarStringRegister (const char *name, void *addr, uint32 size, const char *help) |
Special function for adding string-type variables. | |
void | IConsoleVarRegister (const char *name, void *addr, IConsoleVarTypes type, const char *help) |
Register a new variable to be used in the console. | |
IConsoleVar * | IConsoleVarGet (const char *name) |
Find the variable pointed to by its string. | |
static void | IConsoleVarSetValue (const IConsoleVar *var, uint32 value) |
Set a new value to a console variable. | |
static void | IConsoleVarSetStringvalue (const IConsoleVar *var, const char *value) |
Set a new value to a string-type variable. | |
static uint32 | IConsoleVarGetValue (const IConsoleVar *var) |
Query the current value of a variable and return it. | |
static char * | IConsoleVarGetStringValue (const IConsoleVar *var) |
Get the value of the variable and put it into a printable string form so we can use it for printing. | |
void | IConsoleVarPrintGetValue (const IConsoleVar *var) |
Print out the value of the variable when asked. | |
void | IConsoleVarPrintSetValue (const IConsoleVar *var) |
Print out the value of the variable after it has been assigned a new value, thus giving us feedback on the action. | |
void | IConsoleVarExec (const IConsoleVar *var, byte tokencount, char *token[ICON_TOKEN_COUNT]) |
Execute a variable command. | |
void | IConsoleVarProcAdd (const char *name, IConsoleCmdProc *proc) |
Add a callback function to the variable. | |
void | IConsoleCmdExec (const char *cmdstr) |
Execute a given command passed to us. | |
Variables | |
IConsoleCmd * | _iconsole_cmds |
list of registred commands | |
IConsoleVar * | _iconsole_vars |
list of registred vars | |
IConsoleAlias * | _iconsole_aliases |
list of registred aliases | |
byte | _stdlib_developer = 1 |
bool | _stdlib_con_developer = false |
FILE * | _iconsole_output_file |
Definition in file console.cpp.
#define IConsoleAddSorted | ( | _base, | |||
item_new, | |||||
IConsoleType, | |||||
type | ) |
Perhaps ugly macro, but this saves us the trouble of writing the same function three types, just with different variables.
Yes, templates would be handy. It was either this define or an even more ugly void* magic function
Definition at line 277 of file console.cpp.
Referenced by IConsoleAliasRegister(), IConsoleCmdRegister(), and IConsoleVarRegister().
bool GetArgumentInteger | ( | uint32 * | value, | |
const char * | arg | |||
) |
Change a string into its number representation.
Supports decimal and hexadecimal numbers as well as 'on'/'off' 'true'/'false'
*value | the variable a successful conversion will be put in | |
*arg | the string to be converted |
Definition at line 172 of file console.cpp.
Referenced by IConsoleVarExec().
static void IConsoleAliasExec | ( | const IConsoleAlias * | alias, | |
byte | tokencount, | |||
char * | tokens[ICON_TOKEN_COUNT] | |||
) | [static] |
An alias is just another name for a command, or for more commands Execute it as well.
*alias | is the alias of the command | |
tokencount | the number of parameters passed | |
*tokens | are the parameters given to the original command (0 is the first param) |
Definition at line 401 of file console.cpp.
References IConsoleAlias::cmdline, ICON_MAX_STREAMSIZE, IConsoleCmdExec(), IConsoleCopyInParams(), IConsoleError(), IConsolePrintF(), lengthof, and IConsoleAlias::name.
Referenced by IConsoleCmdExec().
IConsoleAlias* IConsoleAliasGet | ( | const char * | name | ) |
Find the alias pointed to by its string.
name | alias to be found |
Definition at line 373 of file console.cpp.
References IConsoleAlias::name, and IConsoleAlias::next.
Referenced by IConsoleCmdExec().
void IConsoleAliasRegister | ( | const char * | name, | |
const char * | cmd | |||
) |
Register a an alias for an already existing command in the console.
name | name of the alias that will be used | |
cmd | name of the command that 'name' will be alias of |
Definition at line 355 of file console.cpp.
References IConsoleAlias::cmdline, IConsoleAddSorted, IConsoleAlias::name, and IConsoleAlias::next.
void IConsoleCmdExec | ( | const char * | cmdstr | ) |
Execute a given command passed to us.
First chop it up into individual tokens (seperated by spaces), then execute it if possible
cmdstr | string to be parsed and executed |
Definition at line 751 of file console.cpp.
References CS_ALPHANUMERAL, IConsoleVar::hook, ICON_MAX_STREAMSIZE, IConsoleAliasExec(), IConsoleAliasGet(), IConsoleCmdGet(), IConsoleError(), IConsoleHookHandle(), IConsolePrintF(), IConsoleVarExec(), IConsoleVarGet(), IsValidChar(), and lengthof.
Referenced by IConsoleAliasExec().
IConsoleCmd* IConsoleCmdGet | ( | const char * | name | ) |
Find the command pointed to by its string.
name | command to be found |
Definition at line 340 of file console.cpp.
References _iconsole_cmds.
Referenced by IConsoleCmdExec(), and IConsoleCmdHookAdd().
void IConsoleCmdHookAdd | ( | const char * | name, | |
IConsoleHookTypes | type, | |||
IConsoleHook * | proc | |||
) |
Add a hook to a command that will be triggered at certain points.
name | name of the command that the hook is added to | |
type | type of hook that is added (ACCESS, BEFORE and AFTER change) | |
proc | function called when the hook criteria is met |
Definition at line 252 of file console.cpp.
References IConsoleCmdGet(), and IConsoleHookAdd().
void IConsoleCmdRegister | ( | const char * | name, | |
IConsoleCmdProc * | proc | |||
) |
Register a new command to be used in the console.
name | name of the command that will be used | |
proc | function that will be called upon execution of command |
Definition at line 319 of file console.cpp.
References _iconsole_cmds, and IConsoleAddSorted.
void IConsoleDebug | ( | const char * | dbg, | |
const char * | string | |||
) |
It is possible to print debugging information to the console, which is achieved by using this function.
Can only be used by debug() in debug.cpp. You need at least a level 2 (developer) for debugging messages to show up
dbg | debugging category | |
string | debugging message |
Definition at line 139 of file console.cpp.
References IConsolePrintF().
void IConsoleError | ( | const char * | string | ) |
It is possible to print error information to the console.
This can include game errors, or errors in general you would want the user to notice
Definition at line 160 of file console.cpp.
References IConsolePrintF().
Referenced by IConsoleAliasExec(), IConsoleCmdExec(), and IConsoleVarExec().
static void IConsoleHookAdd | ( | IConsoleHooks * | hooks, | |
IConsoleHookTypes | type, | |||
IConsoleHook * | proc | |||
) | [static] |
General internal hooking code that is the same for both commands and variables.
hooks | IConsoleHooks structure that will be set according to | |
type | type access trigger | |
proc | function called when the hook criteria is met |
Definition at line 199 of file console.cpp.
Referenced by IConsoleCmdHookAdd(), and IConsoleVarHookAdd().
static bool IConsoleHookHandle | ( | const IConsoleHooks * | hooks, | |
IConsoleHookTypes | type | |||
) | [static] |
Handle any special hook triggers.
If the hook type is met check if there is a function associated with that and if so, execute it
hooks | IConsoleHooks structure that will be checked | |
type | type of hook, trigger that needs to be activated |
Definition at line 225 of file console.cpp.
Referenced by IConsoleCmdExec(), IConsoleVarSetStringvalue(), and IConsoleVarSetValue().
void IConsolePrint | ( | ConsoleColour | colour_code, | |
const char * | string | |||
) |
Handle the printing of text entered into the console or redirected there by any other means.
Text can be redirected to other clients in a network game as well as to a logfile. If the network server is a dedicated server, all activities are also logged. All lines to print are added to a temporary buffer which can be used as a history to print them onscreen
colour_code | the colour of the command. Red in case of errors, etc. | |
string | the message entered or output on the console (notice, error, etc.) |
Definition at line 85 of file console.cpp.
References IConsoleGUIPrint(), str_strip_colours(), and str_validate().
Referenced by IConsolePrintF().
void CDECL IConsolePrintF | ( | ConsoleColour | colour_code, | |
const char * | s, | |||
... | ||||
) |
Handle the printing of text entered into the console or redirected there by any other means.
Uses printf() style format, for more information look at IConsolePrint()
Definition at line 119 of file console.cpp.
References buf, ICON_MAX_STREAMSIZE, and IConsolePrint().
Referenced by IConsoleAliasExec(), IConsoleCmdExec(), IConsoleDebug(), IConsoleError(), IConsoleGetSetting(), IConsoleListSettings(), IConsoleVarExec(), IConsoleVarPrintGetValue(), IConsoleVarPrintSetValue(), and IConsoleWarning().
void IConsoleVarExec | ( | const IConsoleVar * | var, | |
byte | tokencount, | |||
char * | token[ICON_TOKEN_COUNT] | |||
) |
Execute a variable command.
Without any parameters, print out its value with parameters it assigns a new value to the variable
*var | the variable that we will be querying/changing | |
tokencount | how many additional parameters have been given to the commandline | |
*token | the actual parameters the variable was called with |
Definition at line 685 of file console.cpp.
References GetArgumentInteger(), IConsoleError(), IConsolePrintF(), IConsoleVarGetValue(), IConsoleVarPrintGetValue(), IConsoleVarSetStringvalue(), IConsoleVarSetValue(), IConsoleVar::proc, and IConsoleVar::type.
Referenced by IConsoleCmdExec().
IConsoleVar* IConsoleVarGet | ( | const char * | name | ) |
Find the variable pointed to by its string.
name | variable to be found |
Definition at line 520 of file console.cpp.
References IConsoleVar::name, and IConsoleVar::next.
Referenced by IConsoleCmdExec(), IConsoleVarHookAdd(), IConsoleVarProcAdd(), and IConsoleVarStringRegister().
static uint32 IConsoleVarGetValue | ( | const IConsoleVar * | var | ) | [static] |
Query the current value of a variable and return it.
*var | the variable queried |
Definition at line 586 of file console.cpp.
References IConsoleVar::addr, and IConsoleVar::type.
Referenced by IConsoleVarExec().
void IConsoleVarHookAdd | ( | const char * | name, | |
IConsoleHookTypes | type, | |||
IConsoleHook * | proc | |||
) |
Add a hook to a variable that will be triggered at certain points.
name | name of the variable that the hook is added to | |
type | type of hook that is added (ACCESS, BEFORE and AFTER change) | |
proc | function called when the hook criteria is met |
Definition at line 265 of file console.cpp.
References IConsoleVar::hook, IConsoleHookAdd(), and IConsoleVarGet().
void IConsoleVarProcAdd | ( | const char * | name, | |
IConsoleCmdProc * | proc | |||
) |
Add a callback function to the variable.
Some variables need very special processing, which can only be done with custom code
name | name of the variable the callback function is added to | |
proc | the function called |
Definition at line 739 of file console.cpp.
References IConsoleVarGet(), and IConsoleVar::proc.
void IConsoleVarRegister | ( | const char * | name, | |
void * | addr, | |||
IConsoleVarTypes | type, | |||
const char * | help | |||
) |
Register a new variable to be used in the console.
name | name of the variable that will be used | |
addr | memory location the variable will point to | |
help | the help string shown for the variable | |
type | the type of the variable (simple atomic) so we know which values it can get |
Definition at line 495 of file console.cpp.
References IConsoleVar::addr, IConsoleVar::help, IConsoleVar::hook, IConsoleAddSorted, IConsoleVar::name, IConsoleVar::next, IConsoleVar::proc, and IConsoleVar::type.
Referenced by IConsoleVarStringRegister().
static void IConsoleVarSetStringvalue | ( | const IConsoleVar * | var, | |
const char * | value | |||
) | [static] |
Set a new value to a string-type variable.
Basically this means to copy the new value over to the container.
*var | the variable in question | |
*value | the new value |
Definition at line 570 of file console.cpp.
References IConsoleVar::addr, IConsoleVar::hook, IConsoleHookHandle(), IConsoleVarPrintSetValue(), IConsoleVar::size, ttd_strlcpy(), and IConsoleVar::type.
Referenced by IConsoleVarExec().
static void IConsoleVarSetValue | ( | const IConsoleVar * | var, | |
uint32 | value | |||
) | [static] |
Set a new value to a console variable.
*var | the variable being set/changed | |
value | the new value given to the variable, cast properly |
Definition at line 535 of file console.cpp.
References IConsoleVar::addr, IConsoleVar::hook, IConsoleHookHandle(), IConsoleVarPrintSetValue(), and IConsoleVar::type.
Referenced by IConsoleVarExec().
void IConsoleVarStringRegister | ( | const char * | name, | |
void * | addr, | |||
uint32 | size, | |||
const char * | help | |||
) |
Special function for adding string-type variables.
They in addition also need a 'size' value saying how long their string buffer is.
name | name of the variable that will be used | |
addr | memory location the variable will point to | |
size | the length of the string buffer | |
help | the help string shown for the variable For more information see IConsoleVarRegister() |
Definition at line 480 of file console.cpp.
References IConsoleVarGet(), IConsoleVarRegister(), and IConsoleVar::size.
void IConsoleWarning | ( | const char * | string | ) |
It is possible to print warnings to the console.
These are mostly errors or mishaps, but non-fatal. You need at least a level 1 (developer) for debugging messages to show up
Definition at line 150 of file console.cpp.
References IConsolePrintF().