From: black Date: Tue, 19 Jul 2005 20:53:45 +0000 (+0000) Subject: -Added $parameter parsing to the alias and $cvar parsing to the cmd system. X-Git-Tag: xonotic-v0.1.0preview~4665 X-Git-Url: https://git.rm.cloudns.org/?a=commitdiff_plain;h=ad09ce8c5c329628d46ae8e6ba596e5cb5c37cc6;p=xonotic%2Fdarkplaces.git -Added $parameter parsing to the alias and $cvar parsing to the cmd system. E.g.: alias test "connect $1" test "127.0.0.1" set testcvar "127.0.0.1" connect $testcvar TODO: Add the extension description and the extension to the extension list. git-svn-id: svn://svn.icculus.org/twilight/trunk/darkplaces@5539 d7cf8633-e32d-0410-b094-e92efae38249 --- diff --git a/cmd.c b/cmd.c index 41c38794..870f1809 100644 --- a/cmd.c +++ b/cmd.c @@ -394,6 +394,51 @@ cmd_source_t cmd_source; static cmd_function_t *cmd_functions; // possible commands to execute +/* +============ +Cmd_ExecuteAlias + +Called for aliases and fills in the alias into the cbuffer +============ +*/ +static void Cmd_ExecuteAlias (cmdalias_t *alias) +{ + const char *text = alias->value; + + while( COM_ParseTokenConsole( &text ) ) + { + Cbuf_AddText( "\"" ); + + if( com_token[0] == '$' ) + { + int argNum; + argNum = atoi( &com_token[1] ); + + // no number at all? + if( argNum == 0 ) + { + Cbuf_AddText( com_token ); + } + else if( argNum >= Cmd_Argc() ) + { + Con_Printf( "Warning: Not enough parameters passed to alias '%s', at least %i expected:\n %s\n", alias->name, argNum, alias->value ); + Cbuf_AddText( com_token ); + } + else + { + Cbuf_AddText( Cmd_Argv( argNum ) ); + } + } + else + { + Cbuf_AddText( com_token ); + } + + Cbuf_AddText( "\"" ); + } + Cbuf_AddText( "\n" ); +} + /* ======== Cmd_List @@ -836,7 +881,7 @@ void Cmd_ExecuteString (const char *text, cmd_source_t src) { if (!strcasecmp (cmd_argv[0], a->name)) { - Cbuf_InsertText (a->value); + Cmd_ExecuteAlias(a); cmd_tokenizebufferpos = oldpos; return; } diff --git a/common.c b/common.c index a8d0a9f4..3849138c 100644 --- a/common.c +++ b/common.c @@ -783,7 +783,6 @@ skipwhite: } com_token[len] = 0; *datapointer = data+1; - return true; } else { @@ -800,8 +799,30 @@ skipwhite: } com_token[len] = 0; *datapointer = data; - return true; } + + // check for $cvar + if (com_token[0] == '$' && com_token[1]) + { + cvar_t *cvar; + + cvar = Cvar_FindVar(&com_token[1]); + if (cvar) + { + strcpy(com_token, cvar->string); + } + else if( com_token[1] == '$' ) + { + // remove the first $ + char *pos; + + for( pos = com_token ; *pos ; pos++ ) + { + *pos = *(pos + 1); + } + } + } + return true; } diff --git a/todo b/todo index 44e79812..afa64721 100644 --- a/todo +++ b/todo @@ -12,7 +12,12 @@ -d (flum) bug darkplaces client: corona on your own muzzleflash is annoying when looking down because it can be seen, disable corona on all muzzleflashes (flum) -d (mashakos) bug darkplaces input: fix the mouse move when console is raised in glx, probably by ignoring the first move after console raise (mashakos) -d (romi) feature darkplaces editlights: add coronasize setting to rtlights (romi) --d feature darkplaces server: add sv_playerphysicsqc cvar to allow engine to ignore SV_PlayerPhysics function, this would also have to change the reported extensions (Gleeb) +-d feature darkplaces server: add sv_playerphysicsqc cvar to allow engine to ignore +SV_PlayerPhysics function, this would also have to change the reported extensions (Gleeb) +-d bug darkplaces prvm: assignment to world is not producing an error after world spawn stage (Spike) +-d feature darkplaces server: add filename/line number reporting to progs stack and opcode printouts (Spike) +-d feature darkplaces console: expand parameters such as $cvar to use the value of the cvar, DP_CON_EXPANDCVAR (up2nogood) +-d feature darkplaces console: make aliases given parameters insert the parameters in place of $1, $2, $* macros in the alias string, add this as DP_CON_ALIASPARAMETERS (up2nogood) 0 bug darkplaces WGL client: figure out why GDI input has stuttering problems with gl_finish 0 mode (Kinn, Urre, romi, Spike, Black) 0 bug darkplaces WGL client: fix GDI input init/shutdown, it is using weird mouse acceleration and not restoring it on exit (innovati) 0 bug darkplaces WGL/GLX/SDL client bug: if sound is unavailable (causing a freeze waiting for it to become available), the config is reset (SavageX) @@ -44,7 +49,6 @@ 0 bug darkplaces protocol: models sometimes staying in nexuiz after a big battle, entities that don't exist on the server anymore (Spike) 0 bug darkplaces protocol: sometimes players are invisible in nexuiz, showing only their gun model, this may be related to svc_precache messages not being sent during signon (Vermeulen) 0 bug darkplaces prvm: add back the leak checking http://cvs.icculus.org/cvs/twilight/darkplaces/prvm_cmds.c?r1=1.67&r2=1.68 (Black) -0 bug darkplaces prvm: assignment to world is not producing an error after world spawn stage (Spike) 0 bug darkplaces renderer: animated textures are not being lit by static rtlights (LordHavoc) 0 bug darkplaces renderer: do bloom effect before world crosshair and coronas and things (KrimZon) 0 bug darkplaces renderer: lit sprites (which use R_CompleteLightPoint) are being lit blue by glow_color 108 dlights (Cheapy) @@ -141,7 +145,6 @@ 0 feature darkplaces server: add a DP_QC_WARNING extension which has a "warning" builtin that does a PF_WARNING just to print the requested message, opcode dump, and stack trace (FrikaC) 0 feature darkplaces server: add a clipmask thingy to allow QC to mask off collisions as it wishes (Uffe) 0 feature darkplaces server: add cl_prydoncursor_centeredcursor cvar and PRYDON_CLIENTCURSOR_CENTEREDCURSOR extension (Wazat) -0 feature darkplaces server: add filename/line number reporting to progs stack and opcode printouts (Spike) 0 feature darkplaces server: add sv_antilag cvar which would upgrade the aim() builtin to aim at the creature the player's prydon cursor trace was hitting (Spike) 0 feature darkplaces server: make fopen builtin have the ability to disable fopen builtin access to read /, read data/, write data/, or disable fopen builtin entirely 0 feature darkplaces server: make noclip/fly cheats use MOVETYPE_CHEATNOCLIP/MOVETYPE_CHEATFLY which would have the nicer movement interface (Spikester) @@ -251,8 +254,6 @@ 2 feature darkplaces client: make CL_Video use TEXF_FRAGMENT again by adding general, transparent support for it in all drawqueue functions (so you dont need to call FragmentLocation) (Black) 2 feature darkplaces client: make tab completion able to complete map names when using a map or changelevel command (Zenex) 2 feature darkplaces console: add a "maps" command which takes the list from "dir maps/*.bsp" and prints the actual names of all the levels according to their worldspawn.message keys (RPG, Zenex) -2 feature darkplaces console: expand parameters such as $cvar to use the value of the cvar, DP_CON_EXPANDCVAR (up2nogood) -2 feature darkplaces console: make aliases given parameters insert the parameters in place of $1, $2, $* macros in the alias string, add this as DP_CON_ALIASPARAMETERS (up2nogood) 2 feature darkplaces image: add scaling capabilities to Image_CopyMux 2 feature darkplaces loader: add support for fuhquake naming of map textures (textures/start/quake.tga style) 2 feature darkplaces menu: implement menu_clearkeyconfig and menu_keyconfig and the corresponding menu (diGGer)