Monitor: Fix command execution regression
Function is_async_return() added by commit 940cc30d0d
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>
This commit is contained in:
parent
8f4efc5588
commit
82617d7ce3
@ -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,
|
||||
|
Loading…
Reference in New Issue
Block a user