2004-12-23 13:58:39 +01:00
|
|
|
#include "free.h"
|
2005-03-03 13:46:48 +01:00
|
|
|
#include "user.h"
|
2004-12-30 17:48:19 +01:00
|
|
|
#include "variables.h"
|
2004-12-23 13:58:39 +01:00
|
|
|
|
|
|
|
/**
|
|
|
|
Free all memory allocated by the program.
|
|
|
|
This mainly means we have to free a lot of GStrings
|
|
|
|
and GArrays. */
|
|
|
|
void
|
|
|
|
free_memory(void)
|
|
|
|
{
|
2004-12-30 17:48:19 +01:00
|
|
|
free_variables();
|
2005-04-06 10:49:55 +02:00
|
|
|
free_country(FALSE);
|
2005-04-04 12:36:04 +02:00
|
|
|
free_users(FALSE);
|
2005-01-09 21:21:22 +01:00
|
|
|
free_live_game(&live_game_temp);
|
2005-04-04 12:36:04 +02:00
|
|
|
free_support_dirs();
|
2005-01-09 21:21:22 +01:00
|
|
|
}
|
|
|
|
|
2005-03-03 13:46:48 +01:00
|
|
|
/** Free the users array. */
|
|
|
|
void
|
2005-04-04 12:36:04 +02:00
|
|
|
free_users(gboolean reset)
|
2005-03-03 13:46:48 +01:00
|
|
|
{
|
|
|
|
gint i;
|
|
|
|
|
|
|
|
if(users == NULL)
|
2005-04-04 12:36:04 +02:00
|
|
|
{
|
|
|
|
if(reset)
|
|
|
|
users = g_array_new(FALSE, FALSE, sizeof(User));
|
2005-03-03 13:46:48 +01:00
|
|
|
return;
|
2005-04-04 12:36:04 +02:00
|
|
|
}
|
2005-03-03 13:46:48 +01:00
|
|
|
|
|
|
|
for(i=0;i<users->len;i++)
|
|
|
|
free_user(&usr(i));
|
|
|
|
|
|
|
|
free_g_array(&users);
|
2005-04-04 12:36:04 +02:00
|
|
|
|
|
|
|
if(reset)
|
|
|
|
users = g_array_new(FALSE, FALSE, sizeof(User));
|
2005-03-03 13:46:48 +01:00
|
|
|
}
|
|
|
|
|
|
|
|
/** Free the memory the user occupies.
|
|
|
|
@param user The user we free. */
|
|
|
|
void
|
|
|
|
free_user(User *user)
|
|
|
|
{
|
2005-03-18 23:03:23 +01:00
|
|
|
gint i;
|
|
|
|
|
2005-03-03 13:46:48 +01:00
|
|
|
free_g_string(&user->name);
|
|
|
|
free_live_game(&user->live_game);
|
2005-03-24 08:42:24 +01:00
|
|
|
free_option_list(&user->options, FALSE);
|
2005-03-18 23:03:23 +01:00
|
|
|
|
|
|
|
for(i=0;i<user->events->len;i++)
|
|
|
|
free_event(&g_array_index(user->events, Event, i));
|
|
|
|
|
|
|
|
free_g_array(&user->events);
|
|
|
|
}
|
|
|
|
|
|
|
|
/** Free a user event. */
|
|
|
|
void
|
|
|
|
free_event(Event *event)
|
|
|
|
{
|
2005-03-19 21:04:08 +01:00
|
|
|
free_g_string(&event->value_string);
|
2005-03-03 13:46:48 +01:00
|
|
|
}
|
|
|
|
|
|
|
|
/** Free an array of options.
|
|
|
|
@param array The array we free.
|
|
|
|
@param reset Whether to create the array anew (empty).
|
|
|
|
@see #Option */
|
|
|
|
void
|
2005-03-24 08:42:24 +01:00
|
|
|
free_option_list(OptionList *optionlist, gboolean reset)
|
2005-03-03 13:46:48 +01:00
|
|
|
{
|
|
|
|
gint i;
|
|
|
|
|
2005-03-24 08:42:24 +01:00
|
|
|
if(optionlist->list == NULL)
|
2005-03-03 13:46:48 +01:00
|
|
|
{
|
|
|
|
if(reset)
|
2005-03-24 08:42:24 +01:00
|
|
|
{
|
|
|
|
optionlist->list = g_array_new(FALSE, FALSE, sizeof(Option));
|
|
|
|
g_datalist_init(&optionlist->datalist);
|
|
|
|
}
|
2005-03-03 13:46:48 +01:00
|
|
|
|
|
|
|
return;
|
|
|
|
}
|
|
|
|
|
2005-03-24 08:42:24 +01:00
|
|
|
for(i=0;i<optionlist->list->len;i++)
|
2005-03-03 13:46:48 +01:00
|
|
|
{
|
2005-03-24 08:42:24 +01:00
|
|
|
free_g_string(&g_array_index(optionlist->list, Option, i).name);
|
|
|
|
free_g_string(&g_array_index(optionlist->list, Option, i).string_value);
|
2005-03-03 13:46:48 +01:00
|
|
|
}
|
|
|
|
|
2005-03-24 08:42:24 +01:00
|
|
|
free_g_array(&optionlist->list);
|
2005-03-03 13:46:48 +01:00
|
|
|
|
|
|
|
if(reset)
|
2005-03-24 08:42:24 +01:00
|
|
|
{
|
|
|
|
optionlist->list = g_array_new(FALSE, FALSE, sizeof(Option));
|
|
|
|
g_datalist_init(&optionlist->datalist);
|
|
|
|
}
|
2005-03-03 13:46:48 +01:00
|
|
|
}
|
|
|
|
|
2005-01-09 21:21:22 +01:00
|
|
|
/** Free a live game variable. */
|
|
|
|
void
|
|
|
|
free_live_game(LiveGame *match)
|
|
|
|
{
|
2005-03-10 21:59:39 +01:00
|
|
|
gint i, j, k;
|
2005-01-09 21:21:22 +01:00
|
|
|
|
|
|
|
if(match->units == NULL)
|
|
|
|
return;
|
|
|
|
|
|
|
|
for(i=0;i<match->units->len;i++)
|
|
|
|
free_g_string(&g_array_index(match->units, LiveGameUnit, i).event.commentary);
|
2005-03-10 21:59:39 +01:00
|
|
|
|
|
|
|
for(i=0;i<2;i++)
|
|
|
|
{
|
|
|
|
for(j=0;j<LIVE_GAME_STAT_ARRAY_END;j++)
|
|
|
|
{
|
2005-03-11 13:17:48 +01:00
|
|
|
for(k=0;k<match->stats.players[i][j]->len;k++)
|
|
|
|
free_g_string((GString**)&g_ptr_array_index(match->stats.players[i][j], k));
|
2005-03-10 21:59:39 +01:00
|
|
|
|
2005-03-11 13:17:48 +01:00
|
|
|
free_g_ptr_array(&match->stats.players[i][j]);
|
2005-03-10 21:59:39 +01:00
|
|
|
}
|
|
|
|
}
|
2005-01-09 21:21:22 +01:00
|
|
|
|
|
|
|
free_g_array(&match->units);
|
2004-12-23 13:58:39 +01:00
|
|
|
}
|
|
|
|
|
2005-01-09 21:21:22 +01:00
|
|
|
|
2004-12-23 13:58:39 +01:00
|
|
|
/**
|
|
|
|
Free the main variable of the game, #country.
|
|
|
|
*/
|
|
|
|
void
|
2005-04-06 10:49:55 +02:00
|
|
|
free_country(gboolean reset)
|
2004-12-23 13:58:39 +01:00
|
|
|
{
|
|
|
|
gint i;
|
|
|
|
GString **strings[3] =
|
2004-12-30 17:48:19 +01:00
|
|
|
{&country.name, &country.symbol, &country.sid};
|
2004-12-23 13:58:39 +01:00
|
|
|
|
|
|
|
for(i=0;i<3;i++)
|
2005-04-06 10:49:55 +02:00
|
|
|
{
|
2004-12-30 17:48:19 +01:00
|
|
|
free_g_string(strings[i]);
|
2005-04-06 10:49:55 +02:00
|
|
|
if(reset)
|
|
|
|
*strings[i] = g_string_new("");
|
|
|
|
}
|
2004-12-23 13:58:39 +01:00
|
|
|
|
2005-04-06 10:49:55 +02:00
|
|
|
free_leagues_array(&ligs, reset);
|
2004-12-23 13:58:39 +01:00
|
|
|
|
2005-04-06 10:49:55 +02:00
|
|
|
free_cups_array(&cps, reset);
|
2004-12-30 17:48:19 +01:00
|
|
|
}
|
|
|
|
|
|
|
|
/**
|
|
|
|
Free the memory occupied by a leagues array.
|
|
|
|
@param leagues The pointer to the array we free.
|
|
|
|
*/
|
|
|
|
void
|
2005-04-04 12:36:04 +02:00
|
|
|
free_leagues_array(GArray **leagues, gboolean reset)
|
2004-12-30 17:48:19 +01:00
|
|
|
{
|
|
|
|
gint i;
|
|
|
|
|
|
|
|
if(*leagues == NULL)
|
2005-04-04 12:36:04 +02:00
|
|
|
{
|
|
|
|
if(reset)
|
|
|
|
*leagues = g_array_new(FALSE, FALSE, sizeof(League));
|
2004-12-30 17:48:19 +01:00
|
|
|
return;
|
2005-04-04 12:36:04 +02:00
|
|
|
}
|
2004-12-30 17:48:19 +01:00
|
|
|
|
|
|
|
for(i=0;i<(*leagues)->len;i++)
|
|
|
|
free_league(&g_array_index(*leagues, League, i));
|
|
|
|
|
|
|
|
free_g_array(leagues);
|
2005-04-04 12:36:04 +02:00
|
|
|
|
|
|
|
if(reset)
|
|
|
|
*leagues = g_array_new(FALSE, FALSE, sizeof(League));
|
2004-12-23 13:58:39 +01:00
|
|
|
}
|
|
|
|
|
|
|
|
/**
|
|
|
|
Free the memory occupied by a league.
|
|
|
|
@param league The pointer to the league we free.
|
|
|
|
*/
|
|
|
|
void
|
|
|
|
free_league(League *league)
|
|
|
|
{
|
|
|
|
gint i;
|
2005-03-15 16:10:57 +01:00
|
|
|
GString **strings[6] =
|
2004-12-23 13:58:39 +01:00
|
|
|
{&league->name,
|
|
|
|
&league->short_name,
|
|
|
|
&league->symbol,
|
2004-12-30 17:48:19 +01:00
|
|
|
&league->sid,
|
|
|
|
&league->prom_rel.prom_games_dest_sid,
|
|
|
|
&league->table.name};
|
2004-12-23 13:58:39 +01:00
|
|
|
GArray **arrays[3] =
|
|
|
|
{&league->teams,
|
|
|
|
&league->prom_rel.elements,
|
|
|
|
&league->table.elements};
|
|
|
|
|
2005-03-15 16:10:57 +01:00
|
|
|
for(i=0;i<6;i++)
|
2004-12-30 17:48:19 +01:00
|
|
|
free_g_string(strings[i]);
|
2004-12-23 13:58:39 +01:00
|
|
|
|
|
|
|
if(league->teams != NULL)
|
2005-04-10 18:34:27 +02:00
|
|
|
free_teams_array(&league->teams, FALSE);
|
2004-12-23 13:58:39 +01:00
|
|
|
|
|
|
|
for(i=0;i<3;i++)
|
2004-12-30 17:48:19 +01:00
|
|
|
free_g_array(arrays[i]);
|
2005-01-09 21:21:22 +01:00
|
|
|
|
2005-04-10 18:34:27 +02:00
|
|
|
free_fixtures_array(&league->fixtures, FALSE);
|
2004-12-30 17:48:19 +01:00
|
|
|
}
|
|
|
|
|
|
|
|
/** Free the memory occupied by a teams array.
|
|
|
|
@param teams The pointer to the array we free. */
|
|
|
|
void
|
2005-04-10 18:34:27 +02:00
|
|
|
free_teams_array(GArray **teams, gboolean reset)
|
2004-12-30 17:48:19 +01:00
|
|
|
{
|
|
|
|
gint i;
|
|
|
|
|
|
|
|
if(*teams == NULL)
|
2005-04-10 18:34:27 +02:00
|
|
|
{
|
|
|
|
if(reset)
|
|
|
|
*teams = g_array_new(FALSE, FALSE, sizeof(Team));
|
2004-12-30 17:48:19 +01:00
|
|
|
return;
|
2005-04-10 18:34:27 +02:00
|
|
|
}
|
2004-12-30 17:48:19 +01:00
|
|
|
|
|
|
|
for(i=0;i<(*teams)->len;i++)
|
|
|
|
free_team(&g_array_index(*teams, Team, i));
|
|
|
|
|
|
|
|
free_g_array(teams);
|
2005-04-10 18:34:27 +02:00
|
|
|
|
|
|
|
if(reset)
|
|
|
|
*teams = g_array_new(FALSE, FALSE, sizeof(Team));
|
2004-12-23 13:58:39 +01:00
|
|
|
}
|
|
|
|
|
|
|
|
/**
|
|
|
|
Free the memory occupied by a team.
|
2004-12-30 17:48:19 +01:00
|
|
|
@param tm The pointer to the team we free.
|
2004-12-23 13:58:39 +01:00
|
|
|
*/
|
|
|
|
void
|
2004-12-30 17:48:19 +01:00
|
|
|
free_team(Team *tm)
|
2004-12-23 13:58:39 +01:00
|
|
|
{
|
2004-12-30 17:48:19 +01:00
|
|
|
gint i;
|
|
|
|
|
|
|
|
free_g_string(&tm->name);
|
|
|
|
|
|
|
|
if(tm->players != NULL)
|
2004-12-23 13:58:39 +01:00
|
|
|
{
|
2004-12-30 17:48:19 +01:00
|
|
|
for(i=0;i<tm->players->len;i++)
|
|
|
|
free_player(&g_array_index(tm->players, Player, i));
|
|
|
|
|
|
|
|
free_g_array(&tm->players);
|
2004-12-23 13:58:39 +01:00
|
|
|
}
|
|
|
|
}
|
2004-12-30 17:48:19 +01:00
|
|
|
|
|
|
|
/** Free the memory occupied by a player.
|
|
|
|
@param pl The pointer to the player we free. */
|
|
|
|
void
|
|
|
|
free_player(Player *pl)
|
|
|
|
{
|
|
|
|
free_g_string(&pl->name);
|
|
|
|
|
|
|
|
free_g_array(&pl->cards);
|
|
|
|
|
|
|
|
/* todo: free history */
|
|
|
|
}
|
|
|
|
|
|
|
|
/**
|
|
|
|
Free the memory occupied by a cups array.
|
|
|
|
@param cups The pointer to the array we free.
|
|
|
|
*/
|
|
|
|
void
|
2005-04-04 12:36:04 +02:00
|
|
|
free_cups_array(GArray **cups, gboolean reset)
|
2004-12-30 17:48:19 +01:00
|
|
|
{
|
|
|
|
gint i;
|
|
|
|
|
|
|
|
if(*cups == NULL)
|
2005-04-04 12:36:04 +02:00
|
|
|
{
|
|
|
|
if(reset)
|
|
|
|
*cups = g_array_new(FALSE, FALSE, sizeof(Cup));
|
2004-12-30 17:48:19 +01:00
|
|
|
return;
|
2005-04-04 12:36:04 +02:00
|
|
|
}
|
2004-12-30 17:48:19 +01:00
|
|
|
|
|
|
|
for(i=0;i<(*cups)->len;i++)
|
|
|
|
free_cup(&g_array_index(*cups, Cup, i));
|
|
|
|
|
|
|
|
free_g_array(cups);
|
2005-04-04 12:36:04 +02:00
|
|
|
|
|
|
|
if(reset)
|
|
|
|
*cups = g_array_new(FALSE, FALSE, sizeof(Cup));
|
2004-12-30 17:48:19 +01:00
|
|
|
}
|
|
|
|
|
|
|
|
/**
|
|
|
|
Free the memory occupied by a cup.
|
|
|
|
@param cup The pointer to the cup we free.
|
|
|
|
*/
|
|
|
|
void
|
|
|
|
free_cup(Cup *cup)
|
|
|
|
{
|
|
|
|
gint i;
|
|
|
|
GString **strings[4] =
|
|
|
|
{&cup->name,
|
|
|
|
&cup->short_name,
|
|
|
|
&cup->symbol,
|
|
|
|
&cup->sid};
|
2005-04-10 18:34:27 +02:00
|
|
|
GArray **arrays[2] =
|
2004-12-30 17:48:19 +01:00
|
|
|
{&cup->choose_teams,
|
2005-04-10 18:34:27 +02:00
|
|
|
&cup->rounds};
|
2004-12-30 17:48:19 +01:00
|
|
|
|
|
|
|
for(i=0;i<4;i++)
|
|
|
|
free_g_string(strings[i]);
|
|
|
|
|
|
|
|
if(cup->choose_teams != NULL)
|
|
|
|
for(i=0;i<cup->choose_teams->len;i++)
|
|
|
|
free_cup_choose_team(&g_array_index(cup->choose_teams, CupChooseTeam, i));
|
|
|
|
free_cup_choose_team(&cup->choose_team_user);
|
|
|
|
|
2005-04-10 18:34:27 +02:00
|
|
|
free_teams_array(&cup->teams, FALSE);
|
2004-12-30 17:48:19 +01:00
|
|
|
|
2005-04-10 18:34:27 +02:00
|
|
|
for(i=0;i<2;i++)
|
2004-12-30 17:48:19 +01:00
|
|
|
free_g_array(arrays[i]);
|
2005-01-09 21:21:22 +01:00
|
|
|
|
2005-04-10 18:34:27 +02:00
|
|
|
free_fixtures_array(&cup->fixtures, FALSE);
|
2005-01-09 21:21:22 +01:00
|
|
|
|
|
|
|
free_g_ptr_array(&cup->bye);
|
|
|
|
free_g_ptr_array(&cup->user_teams);
|
|
|
|
|
2005-04-10 18:34:27 +02:00
|
|
|
free_cup_tables(cup->tables, FALSE);
|
|
|
|
}
|
|
|
|
|
|
|
|
/** Free an array of fixtures. */
|
|
|
|
void
|
|
|
|
free_fixtures_array(GArray **fixtures, gboolean reset)
|
|
|
|
{
|
|
|
|
gint i;
|
|
|
|
|
|
|
|
if(*fixtures == NULL)
|
|
|
|
{
|
|
|
|
if(reset)
|
|
|
|
*fixtures = g_array_new(FALSE, FALSE, sizeof(Fixture));
|
|
|
|
return;
|
|
|
|
}
|
|
|
|
|
|
|
|
for(i=0;i<*fixtures->len;i++)
|
|
|
|
{
|
|
|
|
g_string_free(g_array_index(*fixtures, Fixture, i).team_names[0], TRUE);
|
|
|
|
g_string_free(g_array_index(*fixtures, Fixture, i).team_names[1], TRUE);
|
|
|
|
}
|
|
|
|
|
|
|
|
free_g_array(fixtures);
|
|
|
|
|
|
|
|
if(reset)
|
|
|
|
*fixtures = g_array_new(FALSE, FALSE, sizeof(Fixture));
|
2005-01-09 21:21:22 +01:00
|
|
|
}
|
|
|
|
|
|
|
|
/** Free the memory occupied by the cup tables.
|
|
|
|
@param tables The array containing the tables. */
|
|
|
|
void
|
2005-04-10 18:34:27 +02:00
|
|
|
free_cup_tables(GArray *tables, gboolean reset)
|
2005-01-09 21:21:22 +01:00
|
|
|
{
|
|
|
|
gint i;
|
|
|
|
|
|
|
|
if(tables == NULL)
|
2005-04-10 18:34:27 +02:00
|
|
|
{
|
|
|
|
if(reset)
|
|
|
|
tables = g_array_new(FALSE, FALSE, sizeof(Table));
|
|
|
|
|
2005-01-09 21:21:22 +01:00
|
|
|
return;
|
2005-04-10 18:34:27 +02:00
|
|
|
}
|
2005-01-09 21:21:22 +01:00
|
|
|
|
|
|
|
for(i=0;i<tables->len;i++)
|
|
|
|
{
|
|
|
|
free_g_string(&g_array_index(tables, Table, i).name);
|
|
|
|
free_g_array(&g_array_index(tables, Table, i).elements);
|
|
|
|
}
|
|
|
|
|
|
|
|
free_g_array(&tables);
|
2005-04-10 18:34:27 +02:00
|
|
|
|
|
|
|
if(reset)
|
|
|
|
tables = g_array_new(FALSE, FALSE, sizeof(Table));
|
2004-12-30 17:48:19 +01:00
|
|
|
}
|
|
|
|
|
|
|
|
/**
|
|
|
|
Free the memory occupied by a CupChooseTeam.
|
|
|
|
@param cup_choose_team The pointer to the team we free.
|
|
|
|
*/
|
|
|
|
void
|
|
|
|
free_cup_choose_team(CupChooseTeam *cup_choose_team)
|
|
|
|
{
|
|
|
|
free_g_string(&cup_choose_team->sid);
|
|
|
|
}
|
|
|
|
|
|
|
|
/** Free some global variables (except for the country variable). */
|
|
|
|
void
|
|
|
|
free_variables(void)
|
|
|
|
{
|
|
|
|
free_g_string_array(&player_names);
|
|
|
|
|
2005-01-09 21:21:22 +01:00
|
|
|
free_g_array(&transfer_list);
|
2005-03-03 13:46:48 +01:00
|
|
|
|
2005-03-24 08:42:24 +01:00
|
|
|
free_option_list(&options, FALSE);
|
|
|
|
free_option_list(&constants, FALSE);
|
2005-04-04 12:36:04 +02:00
|
|
|
|
|
|
|
free_g_string(&save_file);
|
2004-12-30 17:48:19 +01:00
|
|
|
}
|
|
|
|
|
|
|
|
/**
|
|
|
|
Free a GPtrArray containing GStrings.
|
|
|
|
@param array The array to be freed.
|
|
|
|
*/
|
|
|
|
void
|
|
|
|
free_g_string_array(GPtrArray **array)
|
|
|
|
{
|
|
|
|
gint i;
|
|
|
|
|
|
|
|
if(*array == NULL)
|
|
|
|
return;
|
|
|
|
|
|
|
|
for(i=0;i<(*array)->len;i++)
|
|
|
|
free_g_string((GString**)&g_ptr_array_index(*array, i));
|
|
|
|
|
2005-01-09 21:21:22 +01:00
|
|
|
free_g_ptr_array(array);
|
|
|
|
}
|
|
|
|
|
|
|
|
/** Free a GString if it isn't NULL.
|
|
|
|
@param string The string to be freed. */
|
|
|
|
void
|
|
|
|
free_g_string(GString **string)
|
|
|
|
{
|
|
|
|
if(*string == NULL)
|
|
|
|
return;
|
|
|
|
|
|
|
|
g_string_free(*string, TRUE);
|
|
|
|
|
|
|
|
*string = NULL;
|
|
|
|
}
|
|
|
|
|
|
|
|
/** Free a GArray if it isn't NULL.
|
|
|
|
@param array The array to be freed. */
|
|
|
|
void
|
|
|
|
free_g_array(GArray **array)
|
|
|
|
{
|
|
|
|
if(*array == NULL)
|
|
|
|
return;
|
|
|
|
|
|
|
|
g_array_free(*array, TRUE);
|
|
|
|
|
|
|
|
*array = NULL;
|
|
|
|
}
|
|
|
|
|
|
|
|
/** Free a GPtrArray if it isn't NULL.
|
|
|
|
@param array The array to be freed. */
|
|
|
|
void
|
|
|
|
free_g_ptr_array(GPtrArray **array)
|
|
|
|
{
|
|
|
|
if(*array == NULL)
|
|
|
|
return;
|
|
|
|
|
2004-12-30 17:48:19 +01:00
|
|
|
g_ptr_array_free(*array, TRUE);
|
|
|
|
|
|
|
|
*array = NULL;
|
|
|
|
}
|
2005-04-04 12:36:04 +02:00
|
|
|
|
|
|
|
/** Free the glist containing the support directories. */
|
|
|
|
void
|
|
|
|
free_support_dirs(void)
|
|
|
|
{
|
|
|
|
GList *elem = support_directories;
|
|
|
|
|
|
|
|
if(elem == NULL)
|
|
|
|
return;
|
|
|
|
|
|
|
|
while(elem)
|
|
|
|
{
|
|
|
|
g_free ((gchar*)elem->data);
|
|
|
|
elem = elem->next;
|
|
|
|
}
|
|
|
|
|
|
|
|
g_list_free(support_directories);
|
|
|
|
support_directories = NULL;
|
|
|
|
}
|