diff options
Diffstat (limited to 'glib/dbus-gvalue.c')
-rw-r--r-- | glib/dbus-gvalue.c | 33 |
1 files changed, 31 insertions, 2 deletions
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 = { |