From: José Roberto de Souza Date: Tue, 16 Oct 2012 22:35:50 +0000 (+0000) Subject: edbus: Fix type check of solo structs X-Git-Tag: upstream/1.7.8~172 X-Git-Url: http://review.tizen.org/git/?a=commitdiff_plain;h=a9990a1833e7c85c86b662499fa3c760f05c184e;p=platform%2Fupstream%2Feldbus.git edbus: Fix type check of solo structs When reading messages that contain structs the type that comes from the wire (and obtained with dbus_message_iter_get_arg_type()) is 'r'. However 'r' never appears in a signature and dbus_signature_iter_* returns '('. Ref: http://dbus.freedesktop.org/doc/dbus-specification.html#message-protocol-signatures "STRUCT has a type code, ASCII character 'r', but this type code does not appear in signatures. Instead, ASCII characters '(' and ')' are used to mark the beginning and end of the struct. So for example, a struct containing two integers would have this signature:" Patch by: José Roberto de Souza SVN revision: 78072 --- diff --git a/src/lib/edbus_message.c b/src/lib/edbus_message.c index fcbdb57..3b18c41 100644 --- a/src/lib/edbus_message.c +++ b/src/lib/edbus_message.c @@ -705,7 +705,12 @@ edbus_message_iter_arguments_vget(EDBus_Message_Iter *iter, const char *signatur dbus_free(iter_sig); dbus_signature_iter_next(&signature_iter); - EINA_SAFETY_ON_FALSE_RETURN_VAL(c == current_type, EINA_FALSE); + + if ((c != current_type) && !(current_type == 'r' && c == '(')) + { + ERR("Type in iterator different of signature"); + return EINA_FALSE; + } if (dbus_type_is_basic(current_type)) get_basic(current_type, &iter->dbus_iterator, MAKE_PTR_FROM_VA_LIST(ap));