use g_type_is_a() to check for object_type being a G_TYPE_OBJECT, not
authorTim Janik <timj@gtk.org>
Fri, 9 Mar 2001 09:14:32 +0000 (09:14 +0000)
committerTim Janik <timj@src.gnome.org>
Fri, 9 Mar 2001 09:14:32 +0000 (09:14 +0000)
Fri Mar  9 10:14:00 2001  Tim Janik  <timj@gtk.org>

        * gparamspecs.c (g_param_spec_object): use g_type_is_a() to check
        for object_type being a G_TYPE_OBJECT, not G_TYPE_IS_OBJECT(), since
        that wouldn't allow interface types.

        * gtype.c (g_type_interface_add_prerequisite): arg, fixed small cnp bug
        with bad implications and an off-by-one error.

docs/reference/glib/tmpl/glib-unused.sgml
docs/reference/glib/tmpl/trees-binary.sgml
gobject/ChangeLog
gobject/gparamspecs.c
gobject/gtype.c

index ac05685f35bf997d9d9678415cbdade474ffa099..6d653cbfbb74d0a8be9de27aca6821bf6f219685 100644 (file)
@@ -156,6 +156,21 @@ Turns the argument into a string literal by using the '#' stringizing operator.
 
 @x: text to convert to a literal string.
 
+<!-- ##### FUNCTION g_tree_lookup_extended ##### -->
+<para>
+Gets the original key and the associated value and a gboolean which is 
+TRUE if the key was found. This is useful if you need to free the memory 
+allocated for the original key, for example before calling g_tree_remove().
+Since a #GTree is automatically balanced as key/value pairs are added, 
+key lookup is very fast.
+</para>
+
+@tree: a #GTree.
+@lookup_key: the key to look up.
+@orig_key: returns the original key.
+@value: returns the value associated with the key.
+@Returns: TRUE if the key was found in the #GTree.
+
 <!-- ##### MACRO getcwd ##### -->
 <para>
 
index 58fa334768e0313ab6c0fc1701c9c7096644423a..c68e739eb796fa55e657fa10294b357a32520b85 100644 (file)
@@ -124,22 +124,6 @@ added, key lookup is very fast.
 @Returns: the value corresponding to the key.
 
 
-<!-- ##### FUNCTION g_tree_lookup_extended ##### -->
-<para>
-Gets the original key and the associated value and a gboolean which is 
-TRUE if the key was found. This is useful if you need to free the memory 
-allocated for the original key, for example before calling g_tree_remove().
-Since a #GTree is automatically balanced as key/value pairs are added, 
-key lookup is very fast.
-</para>
-
-@tree: a #GTree.
-@lookup_key: the key to look up.
-@orig_key: returns the original key.
-@value: returns the value associated with the key.
-@Returns: TRUE if the key was found in the #GTree.
-
-
 <!-- ##### FUNCTION g_tree_search ##### -->
 <para>
 Searches a #GTree using an alternative form of the comparison function.
index a966cb8e8d79cbd3a473abe76768a32749e502a6..309a18a4aff9205f94166b9f6db2cde48d449f4d 100644 (file)
@@ -1,3 +1,12 @@
+Fri Mar  9 10:14:00 2001  Tim Janik  <timj@gtk.org>
+
+       * gparamspecs.c (g_param_spec_object): use g_type_is_a() to check
+       for object_type being a G_TYPE_OBJECT, not G_TYPE_IS_OBJECT(), since
+       that wouldn't allow interface types.
+
+       * gtype.c (g_type_interface_add_prerequisite): arg, fixed small cnp bug
+       with bad implications and an off-by-one error.
+
 Thu Mar  8 16:34:22 2001  Owen Taylor  <otaylor@redhat.com>
 
        * gvaluetransform.c: Include <string.h> for memcpy.
index 35f60e015f42541066e09209c7e0870b48478e1b..d305f2c149a6a46ed1859ad6744f2a560b56dab1 100644 (file)
@@ -1587,7 +1587,7 @@ g_param_spec_object (const gchar *name,
 {
   GParamSpecObject *ospec;
   
-  g_return_val_if_fail (G_TYPE_IS_OBJECT (object_type), NULL);
+  g_return_val_if_fail (g_type_is_a (object_type, G_TYPE_OBJECT), NULL);
   
   ospec = g_param_spec_internal (G_TYPE_PARAM_OBJECT,
                                 name,
index 6f745038841066e5bf4f8bcc931e9a01d7d14841..06a7303b5ae3023b3947edfb113f9f94dbb7f1e2 100644 (file)
@@ -1141,7 +1141,7 @@ g_type_interface_add_prerequisite (GType interface_type,
 
   G_WRITE_LOCK (&type_rw_lock);
   iface = lookup_type_node_L (interface_type);
-  prerequisite_node = lookup_type_node_L (interface_type);
+  prerequisite_node = lookup_type_node_L (prerequisite_type);
   if (!iface || !prerequisite_node || !NODE_IS_IFACE (iface))
     {
       g_warning ("interface type `%s' or prerequisite type `%s' invalid",
@@ -1164,7 +1164,7 @@ g_type_interface_add_prerequisite (GType interface_type,
     {
       guint i;
 
-      for (i = 0; i < prerequisite_node->n_supers; i++)
+      for (i = 0; i < prerequisite_node->n_supers + 1; i++)
        type_iface_add_prerequisite_W (iface, lookup_type_node_L (prerequisite_node->supers[i]));
     }
   else if (NODE_IS_IFACE (prerequisite_node))