do not leak memory for factions that have died.

This commit is contained in:
Enno Rehling 2016-01-11 18:17:24 +01:00
parent 20063e0e0e
commit fadc92ee52
3 changed files with 24 additions and 8 deletions

View file

@ -1065,12 +1065,7 @@ void free_gamedata(void)
defaults[i] = 0;
}
}
while (factions) {
faction *f = factions;
factions = f->next;
free_faction(f);
free(f);
}
free_factions();
free_units();
free_regions();
free_borders();

View file

@ -71,7 +71,7 @@ faction *factions;
* but you should still call funhash and remove the faction from the
* global list.
*/
void free_faction(faction * f)
static void free_faction(faction * f)
{
funhash(f);
if (f->alliance && f->alliance->_leader == f) {
@ -328,12 +328,33 @@ void write_faction_reference(const faction * f, struct storage *store)
WRITE_INT(store, (f && f->_alive) ? f->no : 0);
}
static faction *dead_factions;
void free_flist(faction **fp) {
faction * flist = *fp;
for (flist = factions; flist;) {
faction *f = flist;
flist = f->next;
free_faction(f);
free(f);
}
*fp = 0;
}
void free_factions(void) {
free_flist(&factions);
free_flist(&dead_factions);
}
void destroyfaction(faction ** fp)
{
faction * f = *fp;
unit *u = f->units;
*fp = f->next;
f->next = dead_factions;
dead_factions = f;
fset(f, FFL_QUIT);
f->_alive = false;

View file

@ -136,7 +136,7 @@ extern "C" {
int resolve_faction(variant data, void *addr);
void renumber_faction(faction * f, int no);
void free_faction(struct faction *f);
void free_factions(void);
void remove_empty_factions(void);
#ifdef SMART_INTERVALS