mirror of https://github.com/xemu-project/xemu.git
qmp: Merge ObjectPropertyInfo and DevicePropertyInfo
ObjectPropertyInfo is more generic and only missing @description. This adds a description to ObjectPropertyInfo and removes DevicePropertyInfo so the resulting ObjectPropertyInfo can be used elsewhere. Signed-off-by: Alexey Kardashevskiy <aik@ozlabs.ru> Message-Id: <20180301130939.15875-2-aik@ozlabs.ru> Signed-off-by: Paolo Bonzini <pbonzini@redhat.com>
This commit is contained in:
parent
f29d445042
commit
35f63767dc
|
@ -1285,10 +1285,12 @@
|
||||||
# 3) A link type in the form 'link<subtype>' where subtype is a qdev
|
# 3) A link type in the form 'link<subtype>' where subtype is a qdev
|
||||||
# device type name. Link properties form the device model graph.
|
# device type name. Link properties form the device model graph.
|
||||||
#
|
#
|
||||||
|
# @description: if specified, the description of the property.
|
||||||
|
#
|
||||||
# Since: 1.2
|
# Since: 1.2
|
||||||
##
|
##
|
||||||
{ 'struct': 'ObjectPropertyInfo',
|
{ 'struct': 'ObjectPropertyInfo',
|
||||||
'data': { 'name': 'str', 'type': 'str' } }
|
'data': { 'name': 'str', 'type': 'str', '*description': 'str' } }
|
||||||
|
|
||||||
##
|
##
|
||||||
# @qom-list:
|
# @qom-list:
|
||||||
|
@ -1443,21 +1445,6 @@
|
||||||
'data': { '*implements': 'str', '*abstract': 'bool' },
|
'data': { '*implements': 'str', '*abstract': 'bool' },
|
||||||
'returns': [ 'ObjectTypeInfo' ] }
|
'returns': [ 'ObjectTypeInfo' ] }
|
||||||
|
|
||||||
##
|
|
||||||
# @DevicePropertyInfo:
|
|
||||||
#
|
|
||||||
# Information about device properties.
|
|
||||||
#
|
|
||||||
# @name: the name of the property
|
|
||||||
# @type: the typename of the property
|
|
||||||
# @description: if specified, the description of the property.
|
|
||||||
# (since 2.2)
|
|
||||||
#
|
|
||||||
# Since: 1.2
|
|
||||||
##
|
|
||||||
{ 'struct': 'DevicePropertyInfo',
|
|
||||||
'data': { 'name': 'str', 'type': 'str', '*description': 'str' } }
|
|
||||||
|
|
||||||
##
|
##
|
||||||
# @device-list-properties:
|
# @device-list-properties:
|
||||||
#
|
#
|
||||||
|
@ -1465,13 +1452,13 @@
|
||||||
#
|
#
|
||||||
# @typename: the type name of a device
|
# @typename: the type name of a device
|
||||||
#
|
#
|
||||||
# Returns: a list of DevicePropertyInfo describing a devices properties
|
# Returns: a list of ObjectPropertyInfo describing a devices properties
|
||||||
#
|
#
|
||||||
# Since: 1.2
|
# Since: 1.2
|
||||||
##
|
##
|
||||||
{ 'command': 'device-list-properties',
|
{ 'command': 'device-list-properties',
|
||||||
'data': { 'typename': 'str'},
|
'data': { 'typename': 'str'},
|
||||||
'returns': [ 'DevicePropertyInfo' ] }
|
'returns': [ 'ObjectPropertyInfo' ] }
|
||||||
|
|
||||||
##
|
##
|
||||||
# @xen-set-global-dirty-log:
|
# @xen-set-global-dirty-log:
|
||||||
|
|
|
@ -258,8 +258,8 @@ int qdev_device_help(QemuOpts *opts)
|
||||||
{
|
{
|
||||||
Error *local_err = NULL;
|
Error *local_err = NULL;
|
||||||
const char *driver;
|
const char *driver;
|
||||||
DevicePropertyInfoList *prop_list;
|
ObjectPropertyInfoList *prop_list;
|
||||||
DevicePropertyInfoList *prop;
|
ObjectPropertyInfoList *prop;
|
||||||
|
|
||||||
driver = qemu_opt_get(opts, "driver");
|
driver = qemu_opt_get(opts, "driver");
|
||||||
if (driver && is_help_option(driver)) {
|
if (driver && is_help_option(driver)) {
|
||||||
|
@ -295,7 +295,7 @@ int qdev_device_help(QemuOpts *opts)
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
qapi_free_DevicePropertyInfoList(prop_list);
|
qapi_free_ObjectPropertyInfoList(prop_list);
|
||||||
return 1;
|
return 1;
|
||||||
|
|
||||||
error:
|
error:
|
||||||
|
|
20
qmp.c
20
qmp.c
|
@ -465,12 +465,12 @@ ObjectTypeInfoList *qmp_qom_list_types(bool has_implements,
|
||||||
*
|
*
|
||||||
* The caller must free the return value.
|
* The caller must free the return value.
|
||||||
*/
|
*/
|
||||||
static DevicePropertyInfo *make_device_property_info(ObjectClass *klass,
|
static ObjectPropertyInfo *make_device_property_info(ObjectClass *klass,
|
||||||
const char *name,
|
const char *name,
|
||||||
const char *default_type,
|
const char *default_type,
|
||||||
const char *description)
|
const char *description)
|
||||||
{
|
{
|
||||||
DevicePropertyInfo *info;
|
ObjectPropertyInfo *info;
|
||||||
Property *prop;
|
Property *prop;
|
||||||
|
|
||||||
do {
|
do {
|
||||||
|
@ -510,14 +510,14 @@ static DevicePropertyInfo *make_device_property_info(ObjectClass *klass,
|
||||||
return info;
|
return info;
|
||||||
}
|
}
|
||||||
|
|
||||||
DevicePropertyInfoList *qmp_device_list_properties(const char *typename,
|
ObjectPropertyInfoList *qmp_device_list_properties(const char *typename,
|
||||||
Error **errp)
|
Error **errp)
|
||||||
{
|
{
|
||||||
ObjectClass *klass;
|
ObjectClass *klass;
|
||||||
Object *obj;
|
Object *obj;
|
||||||
ObjectProperty *prop;
|
ObjectProperty *prop;
|
||||||
ObjectPropertyIterator iter;
|
ObjectPropertyIterator iter;
|
||||||
DevicePropertyInfoList *prop_list = NULL;
|
ObjectPropertyInfoList *prop_list = NULL;
|
||||||
|
|
||||||
klass = object_class_by_name(typename);
|
klass = object_class_by_name(typename);
|
||||||
if (klass == NULL) {
|
if (klass == NULL) {
|
||||||
|
@ -542,8 +542,8 @@ DevicePropertyInfoList *qmp_device_list_properties(const char *typename,
|
||||||
|
|
||||||
object_property_iter_init(&iter, obj);
|
object_property_iter_init(&iter, obj);
|
||||||
while ((prop = object_property_iter_next(&iter))) {
|
while ((prop = object_property_iter_next(&iter))) {
|
||||||
DevicePropertyInfo *info;
|
ObjectPropertyInfo *info;
|
||||||
DevicePropertyInfoList *entry;
|
ObjectPropertyInfoList *entry;
|
||||||
|
|
||||||
/* Skip Object and DeviceState properties */
|
/* Skip Object and DeviceState properties */
|
||||||
if (strcmp(prop->name, "type") == 0 ||
|
if (strcmp(prop->name, "type") == 0 ||
|
||||||
|
|
Loading…
Reference in New Issue