mirror of
https://git.code.sf.net/p/quake/quakeforge
synced 2025-01-17 22:50:51 +00:00
Nuke PR_GarbageCollect as it's both redundant with the new temp strings
and wrong anyway (could free strings it wasn't supposed to). Don't free the string pointed to by a strref since it's already been implicity freed (whole memory space nuked). Fixes new map crash.
This commit is contained in:
parent
043c1ce466
commit
a533761770
4 changed files with 4 additions and 68 deletions
|
@ -227,7 +227,6 @@ int PR_SetTempString(progs_t *pr, const char *s);
|
||||||
int PR_NewString (progs_t *pr);
|
int PR_NewString (progs_t *pr);
|
||||||
void PR_FreeString (progs_t *pr, int str);
|
void PR_FreeString (progs_t *pr, int str);
|
||||||
void PR_FreeTempStrings (progs_t *pr);
|
void PR_FreeTempStrings (progs_t *pr);
|
||||||
void PR_GarbageCollect (progs_t *pr);
|
|
||||||
|
|
||||||
//
|
//
|
||||||
// PR Resources stuff
|
// PR Resources stuff
|
||||||
|
|
|
@ -137,9 +137,12 @@ strref_free (void *_sr, void *_pr)
|
||||||
progs_t *pr = (progs_t*)_pr;
|
progs_t *pr = (progs_t*)_pr;
|
||||||
strref_t *sr = (strref_t*)_sr;
|
strref_t *sr = (strref_t*)_sr;
|
||||||
|
|
||||||
|
// Since this is only ever called by Hash_FlushTable, the memory pointed
|
||||||
|
// to by sr->string or sr->dstring has already been lost in the progs
|
||||||
|
// load/reload and thus there's no need to free it.
|
||||||
|
|
||||||
// free the string and ref only if it's not a static string
|
// free the string and ref only if it's not a static string
|
||||||
if (sr < pr->static_strings || sr >= pr->static_strings + pr->num_strings) {
|
if (sr < pr->static_strings || sr >= pr->static_strings + pr->num_strings) {
|
||||||
PR_Zone_Free (pr, sr->string);
|
|
||||||
free_string_ref (pr, sr);
|
free_string_ref (pr, sr);
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
@ -188,53 +191,6 @@ PR_LoadStrings (progs_t *pr)
|
||||||
return 1;
|
return 1;
|
||||||
}
|
}
|
||||||
|
|
||||||
void
|
|
||||||
PR_GarbageCollect (progs_t *pr)
|
|
||||||
{
|
|
||||||
const char *str;
|
|
||||||
unsigned int i;
|
|
||||||
int j;
|
|
||||||
ddef_t *def;
|
|
||||||
strref_t *sr;
|
|
||||||
|
|
||||||
for (i = 0; i < pr->dyn_str_size; i++)
|
|
||||||
for (j = 0; j < 1024; j++)
|
|
||||||
pr->dynamic_strings[i][j].count = 0;
|
|
||||||
for (i = 0; i < pr->progs->numglobaldefs; i++) {
|
|
||||||
def = &pr->pr_globaldefs[i];
|
|
||||||
if ((def->type & ~DEF_SAVEGLOBAL) == ev_string) {
|
|
||||||
str = G_GSTRING (pr, def->ofs);
|
|
||||||
if (str) {
|
|
||||||
sr = Hash_Find (pr->strref_hash, str);
|
|
||||||
if (sr)
|
|
||||||
sr->count++;
|
|
||||||
}
|
|
||||||
}
|
|
||||||
}
|
|
||||||
for (i = 0; i < pr->progs->numfielddefs; i++) {
|
|
||||||
def = &pr->pr_fielddefs[i];
|
|
||||||
if ((def->type & ~DEF_SAVEGLOBAL) == ev_string) {
|
|
||||||
for (j = 0; j < *pr->num_edicts; j++) {
|
|
||||||
str = E_GSTRING (pr, EDICT_NUM (pr, j), def->ofs);
|
|
||||||
if (str) {
|
|
||||||
sr = Hash_Find (pr->strref_hash, str);
|
|
||||||
if (sr)
|
|
||||||
sr->count++;
|
|
||||||
}
|
|
||||||
}
|
|
||||||
}
|
|
||||||
}
|
|
||||||
for (i = 0; i < pr->dyn_str_size; i++) {
|
|
||||||
for (j = 0; j < 1024; j++) {
|
|
||||||
sr = &pr->dynamic_strings[i][j];
|
|
||||||
if (sr->string && !sr->count) {
|
|
||||||
Hash_Del (pr->strref_hash, sr->string);
|
|
||||||
strref_free (sr, pr);
|
|
||||||
}
|
|
||||||
}
|
|
||||||
}
|
|
||||||
}
|
|
||||||
|
|
||||||
static inline strref_t *
|
static inline strref_t *
|
||||||
get_strref (progs_t *pr, int num)
|
get_strref (progs_t *pr, int num)
|
||||||
{
|
{
|
||||||
|
|
|
@ -1901,18 +1901,6 @@ SV_CheckVars (void)
|
||||||
static void
|
static void
|
||||||
SV_GarbageCollect (void)
|
SV_GarbageCollect (void)
|
||||||
{
|
{
|
||||||
if (pr_gc->int_val == 1
|
|
||||||
|| (pr_gc->int_val == 2 && sv_pr_state.progs->version == PROG_VERSION)) {
|
|
||||||
pr_gc_count++;
|
|
||||||
if (pr_gc_count >= pr_gc_interval->int_val) {
|
|
||||||
pr_gc_count = 0;
|
|
||||||
PR_GarbageCollect (&sv_pr_state);
|
|
||||||
}
|
|
||||||
} else {
|
|
||||||
// Make sure the count gets reset if the gc is disabled. I
|
|
||||||
// could use a callback, but I'm lazy
|
|
||||||
pr_gc_count = 0;
|
|
||||||
}
|
|
||||||
Object_Garbage_Collect ();
|
Object_Garbage_Collect ();
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
|
@ -55,12 +55,6 @@ bi_print (progs_t *pr)
|
||||||
fprintf (stdout, "%s", str);
|
fprintf (stdout, "%s", str);
|
||||||
}
|
}
|
||||||
|
|
||||||
static void
|
|
||||||
bi_GarbageCollect (progs_t *pr)
|
|
||||||
{
|
|
||||||
PR_GarbageCollect (pr);
|
|
||||||
}
|
|
||||||
|
|
||||||
static void
|
static void
|
||||||
bi_errno (progs_t *pr)
|
bi_errno (progs_t *pr)
|
||||||
{
|
{
|
||||||
|
@ -183,7 +177,6 @@ void
|
||||||
BI_Init (progs_t *pr)
|
BI_Init (progs_t *pr)
|
||||||
{
|
{
|
||||||
PR_AddBuiltin (pr, "print", bi_print, 1);
|
PR_AddBuiltin (pr, "print", bi_print, 1);
|
||||||
PR_AddBuiltin (pr, "GarbageCollect", bi_GarbageCollect, 2);
|
|
||||||
PR_AddBuiltin (pr, "errno", bi_errno, 3);
|
PR_AddBuiltin (pr, "errno", bi_errno, 3);
|
||||||
PR_AddBuiltin (pr, "strerror", bi_strerror, 4);
|
PR_AddBuiltin (pr, "strerror", bi_strerror, 4);
|
||||||
PR_AddBuiltin (pr, "open", bi_open, 5);
|
PR_AddBuiltin (pr, "open", bi_open, 5);
|
||||||
|
|
Loading…
Reference in a new issue