Fix debug builds under MSVC

The C spec leaves conditional evaluation inside a macro expansion as
undefined behaviour. This means we cannot use constructs like:

  GOBJECT_IF_DEBUG(OBJECTS, {
    ...
  #ifdef BLAH
    ...
  #endif
    ...});

Because compilers are entirely justified to ignore the conditional, or,
like in the case of MSVC, error out.

https://bugzilla.gnome.org/show_bug.cgi?id=769504
This commit is contained in:
Emmanuele Bassi 2016-08-04 09:33:25 +01:00
parent 64f6d14d0c
commit 5ff8579527

View File

@ -394,13 +394,22 @@ _g_object_type_init (void)
g_assert (type == G_TYPE_OBJECT); g_assert (type == G_TYPE_OBJECT);
g_value_register_transform_func (G_TYPE_OBJECT, G_TYPE_OBJECT, g_value_object_transform_value); g_value_register_transform_func (G_TYPE_OBJECT, G_TYPE_OBJECT, g_value_object_transform_value);
GOBJECT_IF_DEBUG (OBJECTS, #if G_ENABLE_DEBUG
/* We cannot use GOBJECT_IF_DEBUG here because of the G_HAS_CONSTRUCTORS
* conditional in between, as the C spec leaves conditionals inside macro
* expansions as undefined behavior. Only GCC and Clang are known to work
* but compilation breaks on MSVC.
*
* See: https://bugzilla.gnome.org/show_bug.cgi?id=769504
*/
if (_g_type_debug_flags & G_TYPE_DEBUG_OBJECTS) \
{ {
debug_objects_ht = g_hash_table_new (g_direct_hash, NULL); debug_objects_ht = g_hash_table_new (g_direct_hash, NULL);
# ifndef G_HAS_CONSTRUCTORS # ifndef G_HAS_CONSTRUCTORS
g_atexit (debug_objects_atexit); g_atexit (debug_objects_atexit);
# endif /* G_HAS_CONSTRUCTORS */ # endif /* G_HAS_CONSTRUCTORS */
}); }
#endif /* G_ENABLE_DEBUG */
} }
static void static void