X-Git-Url: https://plomlompom.com/repos/test.html?a=blobdiff_plain;f=src%2Frexit.h;h=f376e5ead2b063ada2a8cbcddc22622b6f510d58;hb=6907fb5902bd50d590b6886e6b30090db5b47444;hp=d4b19d7e70a7af7ce15d067bf14268f614119552;hpb=a974cdd6664ac23668baf50cdafe80b8c8838b1c;p=plomrogue
diff --git a/src/rexit.h b/src/rexit.h
index d4b19d7..f376e5e 100644
--- a/src/rexit.h
+++ b/src/rexit.h
@@ -9,6 +9,7 @@
+#include /* for uint8_t */
struct World;
struct Map;
@@ -20,10 +21,17 @@ struct Map;
*/
enum cleanup_flag
{
- CLEANUP_NCURSES = 0x01,
- CLEANUP_MAP = 0x02,
- CLEANUP_KEYBINDINGS = 0x04,
- CLEANUP_LOG = 0x08
+ CLEANUP_NCURSES = 0x0001,
+ CLEANUP_MAP = 0x0002,
+ CLEANUP_KEYBINDINGS = 0x0004,
+ CLEANUP_LOG = 0x0008,
+ CLEANUP_COMMAND_DB = 0x0010,
+ CLEANUP_MAP_OBJECTS = 0x0020,
+ CLEANUP_MAP_OBJECT_DEFS = 0x0040,
+ CLEANUP_WIN_INFO = 0x0080,
+ CLEANUP_WIN_LOG = 0x0100,
+ CLEANUP_WIN_MAP = 0x0200,
+ CLEANUP_WIN_KEYS = 0x0400
};
extern void set_cleanup_flag(enum cleanup_flag flag);
@@ -34,11 +42,12 @@ extern void exit_game(struct World * world);
-/* If fail != 0, exit with an error message "msg" and clean up. (For "fail",
- * pass the result of functions that return non-zero as an error status and
- * thereby avoid bloating up the code with if-error-conditionals.)
+/* If "err" == 0, do nothing. Else, clean up and exit with an error message that
+ * consists, first, of "msg" or (if "msg" is a NULL pointer) a generic "Details
+ * unknown", secondly of "err" as the "internal error code", and thirdly of
+ * errno if it is non-zero.
*/
-extern void exit_err(unsigned char fail, struct World * world, char * msg);
+extern void exit_err(uint8_t err, struct World * world, char * msg);