Monitor: Fix command execution regression
authorLuiz Capitulino <lcapitulino@redhat.com>
Wed, 27 Jan 2010 20:01:17 +0000 (18:01 -0200)
committerBlue Swirl <blauwirbel@gmail.com>
Thu, 28 Jan 2010 19:09:44 +0000 (19:09 +0000)
Function is_async_return() added by commit 940cc30d0d4 assumes
that 'data', which is returned by handlers, is always a QDict.

This is not true, as QLists can also be returned, in this case
we'll get a segfault.

Fix that by checking if 'data' is a QDict.

Signed-off-by: Luiz Capitulino <lcapitulino@redhat.com>
Signed-off-by: Blue Swirl <blauwirbel@gmail.com>
monitor.c

index fbae5ce09fea722a23de26c68d6b3e7366a97192..fb7c57231a58424f5c5539e4e486323d4f448ce1 100644 (file)
--- a/monitor.c
+++ b/monitor.c
@@ -3700,7 +3700,11 @@ static void monitor_print_error(Monitor *mon)
 
 static int is_async_return(const QObject *data)
 {
-    return data && qdict_haskey(qobject_to_qdict(data), "__mon_async");
+    if (data && qobject_type(data) == QTYPE_QDICT) {
+        return qdict_haskey(qobject_to_qdict(data), "__mon_async");
+    }
+
+    return 0;
 }
 
 static void monitor_call_handler(Monitor *mon, const mon_cmd_t *cmd,