mirror of
https://github.com/qemu/qemu.git
synced 2025-08-02 12:45:00 +00:00

Commit ab45015a96
"qobject: Let qobject_from_jsonf() fail instead of
abort" fails to accomplish its stated aim: the function can still
abort due to its use of &error_abort.
Its rationale for letting it fail is that all remaining users cope
fine with failure. Well, they're just fine with aborting, too; it's
what they do on failure.
Simply reverting the broken commit would bring back the unfortunate
asymmetry between qobject_from_jsonf() and qobject_from_jsonv(): one
aborts, the other returns null. So also rename it to
qobject_from_jsonf_nofail().
Signed-off-by: Markus Armbruster <armbru@redhat.com>
Reviewed-by: Thomas Huth <thuth@redhat.com>
Reviewed-by: Eric Blake <eblake@redhat.com>
Message-Id: <20180806065344.7103-7-armbru@redhat.com>
30 lines
750 B
C
30 lines
750 B
C
/*
|
|
* QObject JSON integration
|
|
*
|
|
* Copyright IBM, Corp. 2009
|
|
*
|
|
* Authors:
|
|
* Anthony Liguori <aliguori@us.ibm.com>
|
|
*
|
|
* This work is licensed under the terms of the GNU LGPL, version 2.1 or later.
|
|
* See the COPYING.LIB file in the top-level directory.
|
|
*
|
|
*/
|
|
|
|
#ifndef QJSON_H
|
|
#define QJSON_H
|
|
|
|
QObject *qobject_from_json(const char *string, Error **errp);
|
|
QObject *qobject_from_jsonv(const char *string, va_list *ap, Error **errp)
|
|
GCC_FMT_ATTR(1, 0);
|
|
|
|
QObject *qobject_from_jsonf_nofail(const char *string, ...)
|
|
GCC_FMT_ATTR(1, 2);
|
|
QDict *qdict_from_jsonf_nofail(const char *string, ...)
|
|
GCC_FMT_ATTR(1, 2);
|
|
|
|
QString *qobject_to_json(const QObject *obj);
|
|
QString *qobject_to_json_pretty(const QObject *obj);
|
|
|
|
#endif /* QJSON_H */
|