Some bug fixes and memory leak fixes. Local variables break randomly,

probably due to my misuse of hash tables.  Anyone have any ideas?
This commit is contained in:
Brian Koropoff 2002-03-20 22:57:26 +00:00
parent 264e9b1617
commit 388ff7b597
4 changed files with 32 additions and 25 deletions

View File

@ -255,8 +255,10 @@ PR_LoadProgs (progs_t *pr, const char *progsname, int edicts, int zone)
COM_FOpenFile (progsname, &file);
pr->progs_name = progsname;
if (file)
if (file) {
PR_LoadProgsFile (pr, file, com_filesize, edicts, zone);
Qclose (file);
}
if (!pr->progs)
return;

View File

@ -129,18 +129,7 @@ Cmd_LocalFree (void *ele, void *ptr)
{
dstring_delete (((cmd_localvar_t *)ele)->key);
dstring_delete (((cmd_localvar_t *)ele)->value);
}
unsigned long
Cmd_LocalGetHash (void *ele, void *ptr)
{
return (unsigned long) ele;
}
int
Cmd_LocalCompare (void *ele1, void *ele2, void *ptr)
{
return !strcmp(((cmd_localvar_t *)ele1)->key->str, ((cmd_localvar_t *)ele2)->key->str);
free (ele);
}
cmd_buffer_t *
@ -153,7 +142,6 @@ Cmd_NewBuffer (void)
new->line = dstring_newstr ();
new->realline = dstring_newstr ();
new->locals = Hash_NewTable (1021, Cmd_LocalGetKey, Cmd_LocalFree, 0);
Hash_SetHashCompare (new->locals, Cmd_LocalGetHash, Cmd_LocalCompare);
return new;
}
@ -165,9 +153,16 @@ Cmd_FreeBuffer (cmd_buffer_t *del)
dstring_delete (del->buffer);
dstring_delete (del->line);
dstring_delete (del->realline);
for (i = 0; i < del->maxargc; i++)
if (del->argv[i])
dstring_delete(del->argv[i]);
if (del->maxargc) {
for (i = 0; i < del->maxargc; i++)
if (del->argv[i])
dstring_delete(del->argv[i]);
free(del->argv);
}
if (del->argspace)
free(del->argspace);
if (del->args)
free(del->args);
Hash_DelTable(del->locals);
free(del);
}
@ -903,7 +898,7 @@ Cmd_ProcessVariablesRecursive (dstring_t *dstr, int start)
dstring_snip (dstr, start, i-start+1); // Nuke it, even if no match is found
if ((lvar = (cmd_localvar_t *)Hash_Find(cmd_activebuffer->locals, varname->str))) { // Local variables get precedence
dstring_insertstr (dstr, lvar->value->str, start);
n = strlen(lvar->key->str);
n = strlen(lvar->value->str);
}
else if ((cvar = Cvar_FindVar(varname->str))) {// Then cvars
dstring_insertstr (dstr, cvar->string, start); // Stick in the value of variable
@ -946,6 +941,7 @@ Cmd_ProcessMath (dstring_t *dstr)
int i, n, paren;
float value;
char *temp;
int ret = 0;
statement = dstring_newstr ();
@ -960,8 +956,10 @@ Cmd_ProcessMath (dstring_t *dstr)
if (!paren)
break;
}
else if (!dstr->str[i+n])
return -1; // Open parentheses, give up
else if (!dstr->str[i+n]) {
ret = -1;
break;
}
}
/* Copy text between parentheses into a buffer */
dstring_clearstr (statement);
@ -973,12 +971,14 @@ Cmd_ProcessMath (dstring_t *dstr)
dstring_insertstr (dstr, temp, i); // Stick in the value
i += strlen(temp) - 1;
}
else
return -2; // Math evaluation error
else {
ret = -2;
break; // Math evaluation error
}
}
}
dstring_delete (statement);
return 0;
return ret;
}
/*

View File

@ -128,8 +128,10 @@ token *EXP_ParseString (char *str)
break;
}
}
if (!(optable[n].func))
if (!(optable[n].func)) {
EXP_DestroyTokens (chain);
return 0;
}
}
}
}
@ -213,6 +215,7 @@ float EXP_Evaluate (char *str)
if (res)
{
EXP_DestroyTokens (chain);
EXP_ERROR = res;
return 0;
}
@ -268,12 +271,14 @@ exp_error_t EXP_Validate (token *chain)
EXP_InsertTokenAfter (cur, new);
}
else
EXP_DestroyTokens (chain);
return EXP_E_SYNTAX; /* Operator misuse */
}
else if (cur->generic.type == TOKEN_NUM && cur->generic.next->generic.type == TOKEN_NUM)
return EXP_E_SYNTAX; /* Double number error */
else if (cur->generic.type == TOKEN_OPAREN && cur->generic.next->generic.type == TOKEN_CPAREN)
return EXP_E_PAREN; /* Pointless parentheses */
}
paren--;

View File

@ -700,7 +700,7 @@ COM_LoadGameDirectory (const char *dir)
dir_ptr = opendir (dir);
if (!dir_ptr)
return;
goto COM_LoadGameDirectory_free;
while ((dirent = readdir (dir_ptr))) {
if (!fnmatch ("*.pak", dirent->d_name, 0)) {