|
@@ -46,7 +46,7 @@ enum ErrorHandlerType {
|
|
|
|
|
|
// Pointer to the error handler printing function. Reassign to any function to have errors printed.
|
|
|
// Parameters: userdata, function, file, line, error, explanation, type.
|
|
|
-typedef void (*ErrorHandlerFunc)(void *, const char *, const char *, int p_line, const char *, const char *, ErrorHandlerType p_type);
|
|
|
+typedef void (*ErrorHandlerFunc)(void *, const char *, const char *, int p_line, const char *, const char *, bool p_editor_notify, ErrorHandlerType p_type);
|
|
|
|
|
|
struct ErrorHandlerList {
|
|
|
ErrorHandlerFunc errfunc = nullptr;
|
|
@@ -61,14 +61,14 @@ void add_error_handler(ErrorHandlerList *p_handler);
|
|
|
void remove_error_handler(ErrorHandlerList *p_handler);
|
|
|
|
|
|
// Functions used by the error macros.
|
|
|
-void _err_print_error(const char *p_function, const char *p_file, int p_line, const char *p_error, ErrorHandlerType p_type = ERR_HANDLER_ERROR);
|
|
|
-void _err_print_error(const char *p_function, const char *p_file, int p_line, const String &p_error, ErrorHandlerType p_type = ERR_HANDLER_ERROR);
|
|
|
-void _err_print_error(const char *p_function, const char *p_file, int p_line, const char *p_error, const char *p_message, ErrorHandlerType p_type = ERR_HANDLER_ERROR);
|
|
|
-void _err_print_error(const char *p_function, const char *p_file, int p_line, const String &p_error, const char *p_message, ErrorHandlerType p_type = ERR_HANDLER_ERROR);
|
|
|
-void _err_print_error(const char *p_function, const char *p_file, int p_line, const char *p_error, const String &p_message, ErrorHandlerType p_type = ERR_HANDLER_ERROR);
|
|
|
-void _err_print_error(const char *p_function, const char *p_file, int p_line, const String &p_error, const String &p_message, ErrorHandlerType p_type = ERR_HANDLER_ERROR);
|
|
|
-void _err_print_index_error(const char *p_function, const char *p_file, int p_line, int64_t p_index, int64_t p_size, const char *p_index_str, const char *p_size_str, const char *p_message = "", bool fatal = false);
|
|
|
-void _err_print_index_error(const char *p_function, const char *p_file, int p_line, int64_t p_index, int64_t p_size, const char *p_index_str, const char *p_size_str, const String &p_message, bool fatal = false);
|
|
|
+void _err_print_error(const char *p_function, const char *p_file, int p_line, const char *p_error, bool p_editor_notify = false, ErrorHandlerType p_type = ERR_HANDLER_ERROR);
|
|
|
+void _err_print_error(const char *p_function, const char *p_file, int p_line, const String &p_error, bool p_editor_notify = false, ErrorHandlerType p_type = ERR_HANDLER_ERROR);
|
|
|
+void _err_print_error(const char *p_function, const char *p_file, int p_line, const char *p_error, const char *p_message, bool p_editor_notify = false, ErrorHandlerType p_type = ERR_HANDLER_ERROR);
|
|
|
+void _err_print_error(const char *p_function, const char *p_file, int p_line, const String &p_error, const char *p_message, bool p_editor_notify = false, ErrorHandlerType p_type = ERR_HANDLER_ERROR);
|
|
|
+void _err_print_error(const char *p_function, const char *p_file, int p_line, const char *p_error, const String &p_message, bool p_editor_notify = false, ErrorHandlerType p_type = ERR_HANDLER_ERROR);
|
|
|
+void _err_print_error(const char *p_function, const char *p_file, int p_line, const String &p_error, const String &p_message, bool p_editor_notify = false, ErrorHandlerType p_type = ERR_HANDLER_ERROR);
|
|
|
+void _err_print_index_error(const char *p_function, const char *p_file, int p_line, int64_t p_index, int64_t p_size, const char *p_index_str, const char *p_size_str, const char *p_message = "", bool p_editor_notify = false, bool fatal = false);
|
|
|
+void _err_print_index_error(const char *p_function, const char *p_file, int p_line, int64_t p_index, int64_t p_size, const char *p_index_str, const char *p_size_str, const String &p_message, bool p_editor_notify = false, bool fatal = false);
|
|
|
|
|
|
#ifdef __GNUC__
|
|
|
//#define FUNCTION_STR __PRETTY_FUNCTION__ - too annoying
|
|
@@ -135,6 +135,17 @@ void _err_print_index_error(const char *p_function, const char *p_file, int p_li
|
|
|
} else \
|
|
|
((void)0)
|
|
|
|
|
|
+/**
|
|
|
+ * Ensures an integer index `m_index` is less than `m_size` and greater than or equal to 0.
|
|
|
+ * If not, prints `m_msg`, notifies in the editor, and the current function returns.
|
|
|
+ */
|
|
|
+#define ERR_FAIL_INDEX_EDMSG(m_index, m_size, m_msg) \
|
|
|
+ if (unlikely((m_index) < 0 || (m_index) >= (m_size))) { \
|
|
|
+ _err_print_index_error(FUNCTION_STR, __FILE__, __LINE__, m_index, m_size, _STR(m_index), _STR(m_size), m_msg, true); \
|
|
|
+ return; \
|
|
|
+ } else \
|
|
|
+ ((void)0)
|
|
|
+
|
|
|
/**
|
|
|
* Try using `ERR_FAIL_INDEX_V_MSG`.
|
|
|
* Only use this macro if there is no sensible error message.
|
|
@@ -160,6 +171,17 @@ void _err_print_index_error(const char *p_function, const char *p_file, int p_li
|
|
|
} else \
|
|
|
((void)0)
|
|
|
|
|
|
+/**
|
|
|
+ * Ensures an integer index `m_index` is less than `m_size` and greater than or equal to 0.
|
|
|
+ * If not, prints `m_msg`, notifies in the editor, and the current function returns `m_retval`.
|
|
|
+ */
|
|
|
+#define ERR_FAIL_INDEX_V_EDMSG(m_index, m_size, m_retval, m_msg) \
|
|
|
+ if (unlikely((m_index) < 0 || (m_index) >= (m_size))) { \
|
|
|
+ _err_print_index_error(FUNCTION_STR, __FILE__, __LINE__, m_index, m_size, _STR(m_index), _STR(m_size), m_msg, true); \
|
|
|
+ return m_retval; \
|
|
|
+ } else \
|
|
|
+ ((void)0)
|
|
|
+
|
|
|
/**
|
|
|
* Try using `ERR_FAIL_INDEX_MSG` or `ERR_FAIL_INDEX_V_MSG`.
|
|
|
* Only use this macro if there is no sensible fallback i.e. the error is unrecoverable, and
|
|
@@ -215,6 +237,16 @@ void _err_print_index_error(const char *p_function, const char *p_file, int p_li
|
|
|
return; \
|
|
|
} else \
|
|
|
((void)0)
|
|
|
+/**
|
|
|
+ * Ensures an unsigned integer index `m_index` is less than `m_size`.
|
|
|
+ * If not, prints `m_msg`, notifies in the editor, and the current function returns.
|
|
|
+ */
|
|
|
+#define ERR_FAIL_UNSIGNED_INDEX_EDMSG(m_index, m_size, m_msg) \
|
|
|
+ if (unlikely((m_index) >= (m_size))) { \
|
|
|
+ _err_print_index_error(FUNCTION_STR, __FILE__, __LINE__, m_index, m_size, _STR(m_index), _STR(m_size), m_msg, true); \
|
|
|
+ return; \
|
|
|
+ } else \
|
|
|
+ ((void)0)
|
|
|
|
|
|
/**
|
|
|
* Try using `ERR_FAIL_UNSIGNED_INDEX_V_MSG`.
|
|
@@ -241,6 +273,17 @@ void _err_print_index_error(const char *p_function, const char *p_file, int p_li
|
|
|
} else \
|
|
|
((void)0)
|
|
|
|
|
|
+/**
|
|
|
+ * Ensures an unsigned integer index `m_index` is less than `m_size`.
|
|
|
+ * If not, prints `m_msg`, notifies in the editor, and the current function returns `m_retval`.
|
|
|
+ */
|
|
|
+#define ERR_FAIL_UNSIGNED_INDEX_V_EDMSG(m_index, m_size, m_retval, m_msg) \
|
|
|
+ if (unlikely((m_index) >= (m_size))) { \
|
|
|
+ _err_print_index_error(FUNCTION_STR, __FILE__, __LINE__, m_index, m_size, _STR(m_index), _STR(m_size), m_msg, true); \
|
|
|
+ return m_retval; \
|
|
|
+ } else \
|
|
|
+ ((void)0)
|
|
|
+
|
|
|
/**
|
|
|
* Try using `ERR_FAIL_UNSIGNED_INDEX_MSG` or `ERR_FAIL_UNSIGNED_INDEX_V_MSG`.
|
|
|
* Only use this macro if there is no sensible fallback i.e. the error is unrecoverable, and
|
|
@@ -297,6 +340,17 @@ void _err_print_index_error(const char *p_function, const char *p_file, int p_li
|
|
|
} else \
|
|
|
((void)0)
|
|
|
|
|
|
+/**
|
|
|
+ * Ensures a pointer `m_param` is not null.
|
|
|
+ * If it is null, prints `m_msg`, notifies in the editor, and the current function returns.
|
|
|
+ */
|
|
|
+#define ERR_FAIL_NULL_EDMSG(m_param, m_msg) \
|
|
|
+ if (unlikely(m_param == nullptr)) { \
|
|
|
+ _err_print_error(FUNCTION_STR, __FILE__, __LINE__, "Parameter \"" _STR(m_param) "\" is null.", m_msg, true); \
|
|
|
+ return; \
|
|
|
+ } else \
|
|
|
+ ((void)0)
|
|
|
+
|
|
|
/**
|
|
|
* Try using `ERR_FAIL_NULL_V_MSG`.
|
|
|
* Only use this macro if there is no sensible error message.
|
|
@@ -322,6 +376,17 @@ void _err_print_index_error(const char *p_function, const char *p_file, int p_li
|
|
|
} else \
|
|
|
((void)0)
|
|
|
|
|
|
+/**
|
|
|
+ * Ensures a pointer `m_param` is not null.
|
|
|
+ * If it is null, prints `m_msg`, notifies in the editor, and the current function returns `m_retval`.
|
|
|
+ */
|
|
|
+#define ERR_FAIL_NULL_V_EDMSG(m_param, m_retval, m_msg) \
|
|
|
+ if (unlikely(m_param == nullptr)) { \
|
|
|
+ _err_print_error(FUNCTION_STR, __FILE__, __LINE__, "Parameter \"" _STR(m_param) "\" is null.", m_msg, true); \
|
|
|
+ return m_retval; \
|
|
|
+ } else \
|
|
|
+ ((void)0)
|
|
|
+
|
|
|
/**
|
|
|
* Try using `ERR_FAIL_COND_MSG`.
|
|
|
* Only use this macro if there is no sensible error message.
|
|
@@ -352,6 +417,20 @@ void _err_print_index_error(const char *p_function, const char *p_file, int p_li
|
|
|
} else \
|
|
|
((void)0)
|
|
|
|
|
|
+/**
|
|
|
+ * Ensures `m_cond` is false.
|
|
|
+ * If `m_cond` is true, prints `m_msg`, notifies in the editor, and the current function returns.
|
|
|
+ *
|
|
|
+ * If checking for null use ERR_FAIL_NULL_MSG instead.
|
|
|
+ * If checking index bounds use ERR_FAIL_INDEX_MSG instead.
|
|
|
+ */
|
|
|
+#define ERR_FAIL_COND_EDMSG(m_cond, m_msg) \
|
|
|
+ if (unlikely(m_cond)) { \
|
|
|
+ _err_print_error(FUNCTION_STR, __FILE__, __LINE__, "Condition \"" _STR(m_cond) "\" is true.", m_msg, true); \
|
|
|
+ return; \
|
|
|
+ } else \
|
|
|
+ ((void)0)
|
|
|
+
|
|
|
/**
|
|
|
* Try using `ERR_FAIL_COND_V_MSG`.
|
|
|
* Only use this macro if there is no sensible error message.
|
|
@@ -382,6 +461,20 @@ void _err_print_index_error(const char *p_function, const char *p_file, int p_li
|
|
|
} else \
|
|
|
((void)0)
|
|
|
|
|
|
+/**
|
|
|
+ * Ensures `m_cond` is false.
|
|
|
+ * If `m_cond` is true, prints `m_msg`, notifies in the editor, and the current function returns `m_retval`.
|
|
|
+ *
|
|
|
+ * If checking for null use ERR_FAIL_NULL_V_MSG instead.
|
|
|
+ * If checking index bounds use ERR_FAIL_INDEX_V_MSG instead.
|
|
|
+ */
|
|
|
+#define ERR_FAIL_COND_V_EDMSG(m_cond, m_retval, m_msg) \
|
|
|
+ if (unlikely(m_cond)) { \
|
|
|
+ _err_print_error(FUNCTION_STR, __FILE__, __LINE__, "Condition \"" _STR(m_cond) "\" is true. Returning: " _STR(m_retval), m_msg, true); \
|
|
|
+ return m_retval; \
|
|
|
+ } else \
|
|
|
+ ((void)0)
|
|
|
+
|
|
|
/**
|
|
|
* Try using `ERR_CONTINUE_MSG`.
|
|
|
* Only use this macro if there is no sensible error message.
|
|
@@ -407,6 +500,17 @@ void _err_print_index_error(const char *p_function, const char *p_file, int p_li
|
|
|
} else \
|
|
|
((void)0)
|
|
|
|
|
|
+/**
|
|
|
+ * Ensures `m_cond` is false.
|
|
|
+ * If `m_cond` is true, prints `m_msg`, notifies in the editor, and the current loop continues.
|
|
|
+ */
|
|
|
+#define ERR_CONTINUE_EDMSG(m_cond, m_msg) \
|
|
|
+ if (unlikely(m_cond)) { \
|
|
|
+ _err_print_error(FUNCTION_STR, __FILE__, __LINE__, "Condition \"" _STR(m_cond) "\" is true. Continuing.", m_msg, true); \
|
|
|
+ continue; \
|
|
|
+ } else \
|
|
|
+ ((void)0)
|
|
|
+
|
|
|
/**
|
|
|
* Try using `ERR_BREAK_MSG`.
|
|
|
* Only use this macro if there is no sensible error message.
|
|
@@ -432,6 +536,17 @@ void _err_print_index_error(const char *p_function, const char *p_file, int p_li
|
|
|
} else \
|
|
|
((void)0)
|
|
|
|
|
|
+/**
|
|
|
+ * Ensures `m_cond` is false.
|
|
|
+ * If `m_cond` is true, prints `m_msg`, notifies in the editor, and the current loop breaks.
|
|
|
+ */
|
|
|
+#define ERR_BREAK_EDMSG(m_cond, m_msg) \
|
|
|
+ if (unlikely(m_cond)) { \
|
|
|
+ _err_print_error(FUNCTION_STR, __FILE__, __LINE__, "Condition \"" _STR(m_cond) "\" is true. Breaking.", m_msg, true); \
|
|
|
+ break; \
|
|
|
+ } else \
|
|
|
+ ((void)0)
|
|
|
+
|
|
|
/**
|
|
|
* Try using `ERR_FAIL_COND_MSG` or `ERR_FAIL_COND_V_MSG`.
|
|
|
* Only use this macro if there is no sensible fallback i.e. the error is unrecoverable, and
|
|
@@ -490,6 +605,19 @@ void _err_print_index_error(const char *p_function, const char *p_file, int p_li
|
|
|
} else \
|
|
|
((void)0)
|
|
|
|
|
|
+/**
|
|
|
+ * Try using `ERR_FAIL_COND_MSG`.
|
|
|
+ * Only use this macro if more complex error detection or recovery is required.
|
|
|
+ *
|
|
|
+ * Prints `m_msg`, notifies in the editor, and the current function returns.
|
|
|
+ */
|
|
|
+#define ERR_FAIL_EDMSG(m_msg) \
|
|
|
+ if (true) { \
|
|
|
+ _err_print_error(FUNCTION_STR, __FILE__, __LINE__, "Method/function failed.", m_msg, true); \
|
|
|
+ return; \
|
|
|
+ } else \
|
|
|
+ ((void)0)
|
|
|
+
|
|
|
/**
|
|
|
* Try using `ERR_FAIL_COND_V_MSG` or `ERR_FAIL_V_MSG`.
|
|
|
* Only use this macro if more complex error detection or recovery is required, and
|
|
@@ -517,6 +645,19 @@ void _err_print_index_error(const char *p_function, const char *p_file, int p_li
|
|
|
} else \
|
|
|
((void)0)
|
|
|
|
|
|
+/**
|
|
|
+ * Try using `ERR_FAIL_COND_V_MSG`.
|
|
|
+ * Only use this macro if more complex error detection or recovery is required.
|
|
|
+ *
|
|
|
+ * Prints `m_msg`, notifies in the editor, and the current function returns `m_retval`.
|
|
|
+ */
|
|
|
+#define ERR_FAIL_V_EDMSG(m_retval, m_msg) \
|
|
|
+ if (true) { \
|
|
|
+ _err_print_error(FUNCTION_STR, __FILE__, __LINE__, "Method/function failed. Returning: " _STR(m_retval), m_msg, true); \
|
|
|
+ return m_retval; \
|
|
|
+ } else \
|
|
|
+ ((void)0)
|
|
|
+
|
|
|
/**
|
|
|
* Try using `ERR_FAIL_COND_MSG`, `ERR_FAIL_COND_V_MSG`, `ERR_CONTINUE_MSG` or ERR_BREAK_MSG.
|
|
|
* Only use this macro at the start of a function that has not been implemented yet, or
|
|
@@ -527,6 +668,16 @@ void _err_print_index_error(const char *p_function, const char *p_file, int p_li
|
|
|
#define ERR_PRINT(m_msg) \
|
|
|
_err_print_error(FUNCTION_STR, __FILE__, __LINE__, m_msg)
|
|
|
|
|
|
+/**
|
|
|
+ * Try using `ERR_FAIL_COND_MSG`, `ERR_FAIL_COND_V_MSG`, `ERR_CONTINUE_MSG` or ERR_BREAK_MSG.
|
|
|
+ * Only use this macro at the start of a function that has not been implemented yet, or
|
|
|
+ * if more complex error detection or recovery is required.
|
|
|
+ *
|
|
|
+ * Prints `m_msg` and notifies the editor.
|
|
|
+ */
|
|
|
+#define ERR_PRINT_ED(m_msg) \
|
|
|
+ _err_print_error(FUNCTION_STR, __FILE__, __LINE__, m_msg, )
|
|
|
+
|
|
|
/**
|
|
|
* Prints `m_msg` once during the application lifetime.
|
|
|
*/
|
|
@@ -540,6 +691,19 @@ void _err_print_index_error(const char *p_function, const char *p_file, int p_li
|
|
|
} else \
|
|
|
((void)0)
|
|
|
|
|
|
+/**
|
|
|
+ * Prints `m_msg` and notifies the editor once during the application lifetime.
|
|
|
+ */
|
|
|
+#define ERR_PRINT_ONCE_ED(m_msg) \
|
|
|
+ if (true) { \
|
|
|
+ static bool first_print = true; \
|
|
|
+ if (first_print) { \
|
|
|
+ _err_print_error(FUNCTION_STR, __FILE__, __LINE__, m_msg, true); \
|
|
|
+ first_print = false; \
|
|
|
+ } \
|
|
|
+ } else \
|
|
|
+ ((void)0)
|
|
|
+
|
|
|
// Print warning message macros.
|
|
|
|
|
|
/**
|
|
@@ -548,51 +712,74 @@ void _err_print_index_error(const char *p_function, const char *p_file, int p_li
|
|
|
* If warning about deprecated usage, use `WARN_DEPRECATED` or `WARN_DEPRECATED_MSG` instead.
|
|
|
*/
|
|
|
#define WARN_PRINT(m_msg) \
|
|
|
- _err_print_error(FUNCTION_STR, __FILE__, __LINE__, m_msg, ERR_HANDLER_WARNING)
|
|
|
+ _err_print_error(FUNCTION_STR, __FILE__, __LINE__, m_msg, false, ERR_HANDLER_WARNING)
|
|
|
+
|
|
|
+/**
|
|
|
+ * Prints `m_msg` and notifies the editor.
|
|
|
+ *
|
|
|
+ * If warning about deprecated usage, use `WARN_DEPRECATED` or `WARN_DEPRECATED_MSG` instead.
|
|
|
+ */
|
|
|
+#define WARN_PRINT_ED(m_msg) \
|
|
|
+ _err_print_error(FUNCTION_STR, __FILE__, __LINE__, m_msg, true, ERR_HANDLER_WARNING)
|
|
|
|
|
|
/**
|
|
|
* Prints `m_msg` once during the application lifetime.
|
|
|
*
|
|
|
* If warning about deprecated usage, use `WARN_DEPRECATED` or `WARN_DEPRECATED_MSG` instead.
|
|
|
*/
|
|
|
-#define WARN_PRINT_ONCE(m_msg) \
|
|
|
- if (true) { \
|
|
|
- static bool first_print = true; \
|
|
|
- if (first_print) { \
|
|
|
- _err_print_error(FUNCTION_STR, __FILE__, __LINE__, m_msg, ERR_HANDLER_WARNING); \
|
|
|
- first_print = false; \
|
|
|
- } \
|
|
|
- } else \
|
|
|
+#define WARN_PRINT_ONCE(m_msg) \
|
|
|
+ if (true) { \
|
|
|
+ static bool first_print = true; \
|
|
|
+ if (first_print) { \
|
|
|
+ _err_print_error(FUNCTION_STR, __FILE__, __LINE__, m_msg, false, ERR_HANDLER_WARNING); \
|
|
|
+ first_print = false; \
|
|
|
+ } \
|
|
|
+ } else \
|
|
|
((void)0)
|
|
|
|
|
|
-// Print deprecated warning message macros.
|
|
|
-
|
|
|
/**
|
|
|
- * Warns that the current function is deprecated.
|
|
|
+ * Prints `m_msg` and notifies the editor once during the application lifetime.
|
|
|
+ *
|
|
|
+ * If warning about deprecated usage, use `WARN_DEPRECATED` or `WARN_DEPRECATED_MSG` instead.
|
|
|
*/
|
|
|
-#define WARN_DEPRECATED \
|
|
|
- if (true) { \
|
|
|
- static SafeFlag warning_shown; \
|
|
|
- if (!warning_shown.is_set()) { \
|
|
|
- _err_print_error(FUNCTION_STR, __FILE__, __LINE__, "This method has been deprecated and will be removed in the future.", ERR_HANDLER_WARNING); \
|
|
|
- warning_shown.set(); \
|
|
|
- } \
|
|
|
- } else \
|
|
|
+#define WARN_PRINT_ONCE_ED(m_msg) \
|
|
|
+ if (true) { \
|
|
|
+ static bool first_print = true; \
|
|
|
+ if (first_print) { \
|
|
|
+ _err_print_error(FUNCTION_STR, __FILE__, __LINE__, m_msg, true, ERR_HANDLER_WARNING); \
|
|
|
+ first_print = false; \
|
|
|
+ } \
|
|
|
+ } else \
|
|
|
((void)0)
|
|
|
|
|
|
+// Print deprecated warning message macros.
|
|
|
+
|
|
|
/**
|
|
|
- * Warns that the current function is deprecated and prints `m_msg`.
|
|
|
+ * Warns that the current function is deprecated.
|
|
|
*/
|
|
|
-#define WARN_DEPRECATED_MSG(m_msg) \
|
|
|
+#define WARN_DEPRECATED \
|
|
|
if (true) { \
|
|
|
static SafeFlag warning_shown; \
|
|
|
if (!warning_shown.is_set()) { \
|
|
|
- _err_print_error(FUNCTION_STR, __FILE__, __LINE__, "This method has been deprecated and will be removed in the future.", m_msg, ERR_HANDLER_WARNING); \
|
|
|
+ _err_print_error(FUNCTION_STR, __FILE__, __LINE__, "This method has been deprecated and will be removed in the future.", false, ERR_HANDLER_WARNING); \
|
|
|
warning_shown.set(); \
|
|
|
} \
|
|
|
} else \
|
|
|
((void)0)
|
|
|
|
|
|
+/**
|
|
|
+ * Warns that the current function is deprecated and prints `m_msg`.
|
|
|
+ */
|
|
|
+#define WARN_DEPRECATED_MSG(m_msg) \
|
|
|
+ if (true) { \
|
|
|
+ static SafeFlag warning_shown; \
|
|
|
+ if (!warning_shown.is_set()) { \
|
|
|
+ _err_print_error(FUNCTION_STR, __FILE__, __LINE__, "This method has been deprecated and will be removed in the future.", m_msg, false, ERR_HANDLER_WARNING); \
|
|
|
+ warning_shown.set(); \
|
|
|
+ } \
|
|
|
+ } else \
|
|
|
+ ((void)0)
|
|
|
+
|
|
|
/**
|
|
|
* Do not use.
|
|
|
* If the application should never reach this point use CRASH_NOW_MSG(m_msg) to explain why.
|