X-Git-Url: https://plomlompom.com/repos/feed.xml?a=blobdiff_plain;f=src%2Frexit.c;h=7bd4440ab7d429607788a657c76f13e81916bcfc;hb=c0a785104a8081e7911647345285da9e9ed22907;hp=2497c034014a6e3d6b585b9d6a9b306aa6cc41c8;hpb=f8325a4ea617b15315183d7a8027c0b913c91034;p=plomrogue diff --git a/src/rexit.c b/src/rexit.c index 2497c03..7bd4440 100644 --- a/src/rexit.c +++ b/src/rexit.c @@ -10,11 +10,12 @@ #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 */ /* The clean-up routine and the flag resource by which it decides what to do. */ -static uint8_t cleanup_flags = 0x00; +static uint32_t cleanup_flags = 0x0000; static void cleanup(struct World * world); @@ -47,6 +48,22 @@ static void cleanup(struct World * world) { free_command_db(world); } + if (cleanup_flags & CLEANUP_WIN_INFO) + { + free(world->wins.info->_title); + } + if (cleanup_flags & CLEANUP_WIN_MAP) + { + free(world->wins.map->_title); + } + if (cleanup_flags & CLEANUP_WIN_LOG) + { + free(world->wins.log->_title); + } + if (cleanup_flags & CLEANUP_WIN_KEYS) + { + free(world->wins.keys->_title); + } }