Changed the behavior of field::get with a null field separator to match

that of for loops.  Added support for var++, var--, var += foo, var -= foo,
var *= foo, and var /= foo.
This commit is contained in:
Brian Koropoff 2002-12-10 00:04:15 +00:00
parent b62795217a
commit 74ee0cfd0e
4 changed files with 105 additions and 17 deletions

View file

@ -41,8 +41,10 @@ typedef struct gib_var_s {
void GIB_Var_Set_Local (cbuf_t *cbuf, const char *key, const char *value); void GIB_Var_Set_Local (cbuf_t *cbuf, const char *key, const char *value);
void GIB_Var_Set_Global (const char *key, const char *value); void GIB_Var_Set_Global (const char *key, const char *value);
void GIB_Var_Set (cbuf_t *cbuf, char *key, const char *value);
const char *GIB_Var_Get_Local (cbuf_t *cbuf, const char *key); const char *GIB_Var_Get_Local (cbuf_t *cbuf, const char *key);
const char *GIB_Var_Get_Global (const char *key); const char *GIB_Var_Get_Global (const char *key);
const char *GIB_Var_Get (cbuf_t *cbuf, char *key);
const char *GIB_Var_Get_Key (void *ele, void *ptr); const char *GIB_Var_Get_Key (void *ele, void *ptr);
void GIB_Var_Free (void *ele, void *ptr); void GIB_Var_Free (void *ele, void *ptr);
void GIB_Var_Free_Global (const char *key); void GIB_Var_Free_Global (const char *key);

View file

@ -314,9 +314,17 @@ GIB_Field_Get_f (void)
field = atoi (GIB_Argv(2)); field = atoi (GIB_Argv(2));
if (GIB_Argc() == 4) if (GIB_Argc() == 4)
ifs = GIB_Argv (3); ifs = GIB_Argv (3);
else if (!(ifs = GIB_Var_Get_Local (cbuf_active, "ifs"))) else if (!(ifs = GIB_Var_Get_Local (cbuf_active, "ifs")))
ifs = " \t\n\r"; ifs = " \t\n\r";
if (!*ifs) {
if (field < strlen(GIB_Argv(1))) {
GIB_Argv(1)[field+1] = 0;
GIB_Return (GIB_Argv(1)+field);
} else
GIB_Return ("");
return;
}
for (list = GIB_Argv(1); *list && strchr(ifs, *list); list++); for (list = GIB_Argv(1); *list && strchr(ifs, *list); list++);
while (field) { while (field) {
while (!strchr(ifs, *list)) while (!strchr(ifs, *list))

View file

@ -37,9 +37,11 @@ static const char rcsid[] =
#include <ctype.h> #include <ctype.h>
#include <string.h> #include <string.h>
#include <stdlib.h>
#include "QF/sys.h" #include "QF/sys.h"
#include "QF/dstring.h" #include "QF/dstring.h"
#include "QF/va.h"
#include "QF/cmd.h" #include "QF/cmd.h"
#include "QF/cbuf.h" #include "QF/cbuf.h"
#include "QF/gib_buffer.h" #include "QF/gib_buffer.h"
@ -491,6 +493,68 @@ FILTER_ERROR:
return; return;
} }
inline qboolean
GIB_Parse_Execute_Varexp (cbuf_t *cbuf)
{
char *s;
const char *v;
double newval, other;
cbuf_args_t *args = cbuf->args;
if (args->argc == 1) {
s = args->argv[0]->str + strlen(args->argv[0]->str) - 2;
if (!strcmp (s, "++") || !strcmp (s, "--")) {
*s = 0;
if ((v = GIB_Var_Get (cbuf, args->argv[0]->str)))
newval = atof (v);
else
newval = 0.0;
switch (s[1]) {
case '+':
newval++;
break;
case '-':
newval--;
}
GIB_Var_Set (cbuf, args->argv[0]->str, va("%.10g", newval));
return true;
} else
return false;
} else if (args->argc == 3 && strlen(args->argv[1]->str) <= 2 && strchr(args->argv[1]->str, '=')) {
s = args->argv[1]->str;
if (*s == '=') {
GIB_Var_Set (cbuf, args->argv[0]->str, args->argv[2]->str);
return true;
} else if (s[1] == '=') {
if ((v = GIB_Var_Get (cbuf, args->argv[0]->str)))
newval = atof (v);
else
newval = 0.0;
other = atof (args->argv[2]->str);
switch (*s) {
case '+':
newval += other;
break;
case '-':
newval -= other;
break;
case '*':
newval *= other;
break;
case '/':
newval /= other;
break;
default:
return false;
}
GIB_Var_Set (cbuf, args->argv[0]->str, va("%.10g", newval));
return true;
} else
return false;
} else
return false;
}
/* /*
GIB_Parse_Execute_Line GIB_Parse_Execute_Line
@ -503,7 +567,7 @@ FILTER_ERROR:
Assignment to a local/global variable Assignment to a local/global variable
Normal quake console commands Normal quake console commands
*/ */
static void void
GIB_Parse_Execute_Line (cbuf_t *cbuf) GIB_Parse_Execute_Line (cbuf_t *cbuf)
{ {
cbuf_args_t *args = cbuf->args; cbuf_args_t *args = cbuf->args;
@ -518,20 +582,7 @@ GIB_Parse_Execute_Line (cbuf_t *cbuf)
cbuf_active->down = sub; cbuf_active->down = sub;
sub->up = cbuf_active; sub->up = cbuf_active;
cbuf_active->state = CBUF_STATE_STACK; cbuf_active->state = CBUF_STATE_STACK;
} else if (args->argc == 3 && !strcmp (args->argv[1]->str, "=")) { } else if (!GIB_Parse_Execute_Varexp(cbuf))
// First, determine global versus local
int glob = 0;
char *c = 0;
if ((c = strchr (args->argv[0]->str, '.'))) // Only check stem
*c = 0;
glob = (!GIB_Var_Get_Local (cbuf, args->argv[0]->str) && GIB_Var_Get_Global (args->argv[0]->str));
if (c)
*c = '.';
if (glob)
GIB_Var_Set_Global (args->argv[0]->str, args->argv[2]->str); // Set the global
else
GIB_Var_Set_Local (cbuf, args->argv[0]->str, args->argv[2]->str); // Set the local
} else
Cmd_Command (cbuf->args); Cmd_Command (cbuf->args);
dstring_clearstr (cbuf->line); dstring_clearstr (cbuf->line);
// If this is a looping buffer and it is now empty, // If this is a looping buffer and it is now empty,

View file

@ -165,6 +165,33 @@ GIB_Var_Get_Global (const char *key)
return 0; return 0;
} }
const char *
GIB_Var_Get (cbuf_t *cbuf, char *key)
{
const char *v;
if ((v = GIB_Var_Get_Local (cbuf, key)) || (v = GIB_Var_Get_Global (key)))
return v;
else
return 0;
}
void
GIB_Var_Set (cbuf_t *cbuf, char *key, const char *value)
{
int glob = 0;
char *c = 0;
if ((c = strchr (key, '.'))) // Only check stem
*c = 0;
glob = (!GIB_Var_Get_Local (cbuf, key) && GIB_Var_Get_Global (key));
if (c)
*c = '.';
if (glob)
GIB_Var_Set_Global (key, value); // Set the global
else
GIB_Var_Set_Local (cbuf, key, value); // Set the local
}
void void
GIB_Var_Free_Global (const char *key) GIB_Var_Free_Global (const char *key)
{ {