From 249c5ea945b7f87307e4af6ae95faf76b2549423 Mon Sep 17 00:00:00 2001 From: Colin Walters Date: Fri, 1 Jul 2005 15:44:12 +0000 Subject: 2005-07-01 Colin Walters Patch from Jonathan Matthew * glib/dbus-gvalue.c (basic_typecode_to_gtype): Fix return type. (dbus_g_value_types_init): Marshal G_TYPE_CHAR as DBUS_TYPE_BYTE, G_TYPE_LONG as DBUS_TYPE_INT32, G_TYPE_ULONG as DBUS_TYPE_UINT32, and G_TYPE_FLOAT as DBUS_TYPE_DOUBLE. --- glib/dbus-gvalue.c | 33 +++++++++++++++++++++++++++++++-- 1 file changed, 31 insertions(+), 2 deletions(-) (limited to 'glib') diff --git a/glib/dbus-gvalue.c b/glib/dbus-gvalue.c index d8ce3d2b..e2786c48 100644 --- a/glib/dbus-gvalue.c +++ b/glib/dbus-gvalue.c @@ -170,7 +170,7 @@ dbus_typecode_maps_to_basic (int typecode) return typecode_to_gtype (typecode) != G_TYPE_INVALID; } -static gboolean +static GType basic_typecode_to_gtype (int typecode) { g_assert (dbus_type_is_basic (typecode)); @@ -306,7 +306,36 @@ dbus_g_value_types_init (void) }; register_basic (DBUS_TYPE_STRING, &typedata); } - + /* fundamental GTypes that don't map 1:1 with D-BUS types */ + { + static const DBusGTypeMarshalData typedata = { + DBUS_TYPE_BYTE_AS_STRING, + &basic_vtable, + }; + set_type_metadata (G_TYPE_CHAR, &typedata); + } + { + static const DBusGTypeMarshalData typedata = { + DBUS_TYPE_INT32_AS_STRING, + &basic_vtable, + }; + set_type_metadata (G_TYPE_LONG, &typedata); + } + { + static const DBusGTypeMarshalData typedata = { + DBUS_TYPE_UINT32_AS_STRING, + &basic_vtable, + }; + set_type_metadata (G_TYPE_ULONG, &typedata); + } + { + static const DBusGTypeMarshalData typedata = { + DBUS_TYPE_DOUBLE_AS_STRING, + &basic_vtable, + }; + set_type_metadata (G_TYPE_FLOAT, &typedata); + } + /* Register complex types with builtin GType mappings */ { static const DBusGTypeMarshalVtable vtable = { -- cgit