diff --git a/glib/glib-private.h b/glib/glib-private.h index c2e7fd401..8de380d12 100644 --- a/glib/glib-private.h +++ b/glib/glib-private.h @@ -33,8 +33,51 @@ */ #define _GLIB_ADDRESS_SANITIZER +#include + #endif +/* + * g_ignore_leak: + * @p: any pointer + * + * Tell AddressSanitizer and similar tools that if the object pointed to + * by @p is leaked, it is not a problem. Use this to suppress memory leak + * reports when a potentially unreachable pointer is deliberately not + * going to be deallocated. + */ +static inline void +g_ignore_leak (gconstpointer p) +{ +#ifdef _GLIB_ADDRESS_SANITIZER + if (p != NULL) + __lsan_ignore_object (p); +#endif +} + +/* + * g_ignore_strv_leak: + * @strv: (nullable) (array zero-terminated=1): an array of strings + * + * The same as g_ignore_leak(), but for the memory pointed to by @strv, + * and for each element of @strv. + */ +static inline void +g_ignore_strv_leak (GStrv strv) +{ +#ifdef _GLIB_ADDRESS_SANITIZER + gchar **item; + + if (strv) + { + g_ignore_leak (strv); + + for (item = strv; *item != NULL; item++) + g_ignore_leak (*item); + } +#endif +} + GMainContext * g_get_worker_context (void); gboolean g_check_setuid (void); GMainContext * g_main_context_new_with_next_id (guint next_id);