X-Git-Url: https://plomlompom.com/repos/?a=blobdiff_plain;f=src%2Frexit.c;h=85e2bfc328798fdb3085bfa9676118084073176a;hb=0399a31b31047ab82348f733d6c56524258d1188;hp=f7bb3f23e8553132a8ad2a84c72be0448cb61b31;hpb=7bebc9943d1648d56968146b17c9459affb183c6;p=plomrogue diff --git a/src/rexit.c b/src/rexit.c index f7bb3f2..85e2bfc 100644 --- a/src/rexit.c +++ b/src/rexit.c @@ -2,16 +2,20 @@ #include "rexit.h" #include /* for exit(), free(), defines EXIT_SUCESS, EXIT_FAILURE */ -#include /* for printf() */ +#include /* for printf(), perror() */ +#include /* for uint8_t */ #include /* for endwin() */ +#include /* for errno */ #include "main.h" /* for World struct */ #include "map.h" /* for Map struct */ #include "keybindings.h" /* for KeysWinData, KeyBinding structs */ +#include "command_db.h" /* for free_command_db() */ +#include "windows.h" /* for Win struct, free_win() */ /* The clean-up routine and the flag resource by which it decides what to do. */ -static unsigned char cleanup_flags = 0x00; +static uint32_t cleanup_flags = 0x0000; static void cleanup(struct World * world); @@ -40,6 +44,26 @@ static void cleanup(struct World * world) { free(world->log); } + if (cleanup_flags & CLEANUP_COMMAND_DB) + { + free_command_db(world); + } + if (cleanup_flags & CLEANUP_WIN_INFO) + { + free_win(world->wins.info); + } + if (cleanup_flags & CLEANUP_WIN_MAP) + { + free_win(world->wins.map); + } + if (cleanup_flags & CLEANUP_WIN_LOG) + { + free_win(world->wins.log); + } + if (cleanup_flags & CLEANUP_WIN_KEYS) + { + free_win(world->wins.keys); + } } @@ -59,9 +83,22 @@ extern void exit_game(struct World * world) -extern void exit_err(struct World * world, char * msg) +extern void exit_err(uint8_t err, struct World * world, char * msg) { + if (0 == err) + { + return; + } cleanup(world); - printf(msg); + if (NULL == msg) + { + msg = "Details unknown."; + } + printf("Aborted PlomRogue due to error. %s\nInternal error code: %d\n", + msg, err); + if (0 != errno) + { + perror("errno states"); + } exit(EXIT_FAILURE); }