forked from github/server
do not leak memory for factions that have died.
This commit is contained in:
parent
20063e0e0e
commit
fadc92ee52
3 changed files with 24 additions and 8 deletions
|
@ -1065,12 +1065,7 @@ void free_gamedata(void)
|
||||||
defaults[i] = 0;
|
defaults[i] = 0;
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
while (factions) {
|
free_factions();
|
||||||
faction *f = factions;
|
|
||||||
factions = f->next;
|
|
||||||
free_faction(f);
|
|
||||||
free(f);
|
|
||||||
}
|
|
||||||
free_units();
|
free_units();
|
||||||
free_regions();
|
free_regions();
|
||||||
free_borders();
|
free_borders();
|
||||||
|
|
|
@ -71,7 +71,7 @@ faction *factions;
|
||||||
* but you should still call funhash and remove the faction from the
|
* but you should still call funhash and remove the faction from the
|
||||||
* global list.
|
* global list.
|
||||||
*/
|
*/
|
||||||
void free_faction(faction * f)
|
static void free_faction(faction * f)
|
||||||
{
|
{
|
||||||
funhash(f);
|
funhash(f);
|
||||||
if (f->alliance && f->alliance->_leader == 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);
|
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)
|
void destroyfaction(faction ** fp)
|
||||||
{
|
{
|
||||||
faction * f = *fp;
|
faction * f = *fp;
|
||||||
unit *u = f->units;
|
unit *u = f->units;
|
||||||
|
|
||||||
*fp = f->next;
|
*fp = f->next;
|
||||||
|
f->next = dead_factions;
|
||||||
|
dead_factions = f;
|
||||||
|
|
||||||
fset(f, FFL_QUIT);
|
fset(f, FFL_QUIT);
|
||||||
f->_alive = false;
|
f->_alive = false;
|
||||||
|
|
||||||
|
|
|
@ -136,7 +136,7 @@ extern "C" {
|
||||||
int resolve_faction(variant data, void *addr);
|
int resolve_faction(variant data, void *addr);
|
||||||
|
|
||||||
void renumber_faction(faction * f, int no);
|
void renumber_faction(faction * f, int no);
|
||||||
void free_faction(struct faction *f);
|
void free_factions(void);
|
||||||
void remove_empty_factions(void);
|
void remove_empty_factions(void);
|
||||||
|
|
||||||
#ifdef SMART_INTERVALS
|
#ifdef SMART_INTERVALS
|
||||||
|
|
Loading…
Reference in a new issue