Add boxed types definition for GLib
authorGiovanni Campagna <gcampagna@src.gnome.org>
Fri, 3 Jun 2011 23:10:42 +0000 (19:10 -0400)
committerColin Walters <walters@verbum.org>
Sat, 4 Jun 2011 17:48:42 +0000 (13:48 -0400)
Use the new glib-boxed.h header from gobject to pair structure
definitions with boxed types in the GLib namespace, improving the
introspection coverage and removing some hacks.

Some fixes from Colin Walters <walters@verbum.org>

https://bugzilla.gnome.org/show_bug.cgi?id=646635

Makefile-gir.am
giscanner/gdumpparser.py

index 2d237493f76e6a492c0899ce7b0a074f7971b98b..f32190ffde84132a71843d91e8d0bd78a673c66c 100644 (file)
@@ -3,7 +3,7 @@ SUBSTITUTED_GIRSOURCES =
 
 STATIC_GIRSOURCES =               \
         gir/DBus-1.0.gir           \
-        gir/DBusGLib-1.0.gir           \
+        gir/DBusGLib-1.0.gir        \
         gir/fontconfig-2.0.gir      \
         gir/freetype2-2.0.gir       \
         gir/GL-1.0.gir              \
@@ -62,7 +62,7 @@ else
 GLIB_LIBRARY=glib-2.0
 endif
 
-GLib_2_0_gir_LIBS = $(GLIB_LIBRARY)
+GLib_2_0_gir_LIBS = $(GLIB_LIBRARY) $(GOBJECT_LIBRARY)
 GLib_2_0_gir_SCANNERFLAGS = \
             --external-library \
             --reparse-validate \
@@ -80,7 +80,8 @@ GLib_2_0_gir_CFLAGS = \
             -D__G_I18N_LIB_H__
 GLib_2_0_gir_FILES =  \
                 $(GLIB_LIBDIR)/glib-2.0/include/glibconfig.h \
-       $(GLIB_INCLUDEDIR)/glib/*.h \
+               $(GLIB_INCLUDEDIR)/glib/*.h \
+               $(GLIB_INCLUDEDIR)/gobject/glib-types.h \
                 gir/glib-2.0.c
 
 BUILT_GIRSOURCES += GLib-2.0.gir
@@ -100,7 +101,6 @@ GOBJECT_LIBRARY=gobject-2.0
 endif
 
 GObject-2.0.gir: GLib-2.0.gir
-
 GObject_2_0_gir_LIBS = $(GOBJECT_LIBRARY)
 GObject_2_0_gir_SCANNERFLAGS = \
             --external-library \
@@ -114,9 +114,11 @@ GObject_2_0_gir_PACKAGES = gobject-2.0
 GObject_2_0_gir_INCLUDES = GLib-2.0
 GObject_2_0_gir_CFLAGS = \
             -DGOBJECT_COMPILATION \
-                -I$(GOBJECT_INCLUDEDIR) \
+            -I$(GOBJECT_INCLUDEDIR) \
             -I$(GOBJECT_LIBDIR)/glib-2.0/include
-GObject_2_0_gir_FILES = $(GLIB_INCLUDEDIR)/gobject/*.h gir/gobject-2.0.c
+GObject_2_0_gir_FILES = \
+       $(filter-out $(GOBJECT_INCLUDEDIR)/gobject/glib-types.h, $(wildcard $(GOBJECT_INCLUDEDIR)/gobject/*.h)) \
+       gir/gobject-2.0.c
 
 BUILT_GIRSOURCES += GObject-2.0.gir
 
index 7e8f31f536f73143308a88a74476db3f8837edb9..650e19489721b03f8e27fb82d15ade71743ffe3e 100644 (file)
@@ -133,14 +133,6 @@ class GDumpParser(object):
         for node in to_remove:
             self._namespace.remove(node)
 
-        if self._namespace.name == 'GLib':
-            variant = self._namespace.get('Variant')
-            assert variant is not None
-            variant.add_gtype('GVariant', 'g_variant_get_gtype')
-            variant.c_symbol_prefix = 'variant'
-            # Work around scanner bug
-            variant.disguised = False
-
     # Helper functions
 
     def _execute_binary_get_tree(self):
@@ -209,9 +201,6 @@ blob containing data gleaned from GObject's primitive introspection."""
             self._initparse_get_type_function(func)
 
     def _initparse_get_type_function(self, func):
-        if self._namespace.name == 'GLib':
-            # No GObjects in GLib
-            return False
         if (self._namespace.name == 'GObject' and
             func.symbol in ('g_object_get_type', 'g_initially_unowned_get_type')):
             # We handle these internally, see _create_gobject
@@ -455,14 +444,13 @@ different --identifier-prefix.""" % (xmlnode.attrib['name'], self._namespace.ide
         node.parent_chain = parent_types
 
     def _introspect_fundamental(self, xmlnode):
-        # We only care about types that can be instantiatable, other
-        # fundamental types such as the Clutter.Fixed/CoglFixed registers
-        # are not yet interesting from an introspection perspective and
-        # are ignored
-        if not xmlnode.attrib.get('instantiatable', False):
+        type_name = xmlnode.attrib['name']
+        if type_name == 'GVariant':
+            # HACK: make GVariant a boxed to avoid looking up GInitiallyUnowned
+            # when computing the default transfer ownership
+            self._introspect_boxed(xmlnode)
             return
 
-        type_name = xmlnode.attrib['name']
         is_abstract = bool(xmlnode.attrib.get('abstract', False))
         (get_type, c_symbol_prefix) = self._split_type_and_symbol_prefix(xmlnode)
         try: