values: Use v_pointer for g_value_set_gtype()
authorBenjamin Otte <otte@redhat.com>
Sun, 1 Jan 2012 20:51:40 +0000 (21:51 +0100)
committerBenjamin Otte <otte@redhat.com>
Sat, 14 Jan 2012 00:15:16 +0000 (01:15 +0100)
... and g_value_get_gtype(). G_TYPE_GTYPE is a pointer type, so it's
values should use the v_pointer member. This is especially true, because
the value collectors from varargs in gvaluecollector.h use that, too.

This should only cause issues when sizeof(glong) != sizeof(gpointer),
and I'm not aware of any such platform. Maybe win64?

gobject/gvaluetypes.c

index 5636990..799dfdd 100644 (file)
@@ -1187,7 +1187,7 @@ g_value_set_gtype (GValue *value,
 {
   g_return_if_fail (G_VALUE_HOLDS_GTYPE (value));
 
-  value->data[0].v_long = v_gtype;
+  value->data[0].v_pointer = GSIZE_TO_POINTER (v_gtype);
   
 }
 
@@ -1206,7 +1206,7 @@ g_value_get_gtype (const GValue *value)
 {
   g_return_val_if_fail (G_VALUE_HOLDS_GTYPE (value), 0);
 
-  return value->data[0].v_long;
+  return GPOINTER_TO_SIZE (value->data[0].v_pointer);
 }
 
 /**