qom: Clean up object_property_get_enum()'s error value

object_property_get_enum() is the only object_property_FOO() that is
documented to return an undefined value on error.  It does no such
thing, actually: it returns 0 on some errors, and -1 on others.

Needlessly complicated.  Always return -1 on error, and adjust the
contract.

Signed-off-by: Markus Armbruster <armbru@redhat.com>
Reviewed-by: Greg Kurz <groug@kaod.org>
Reviewed-by: Daniel P. Berrangé <berrange@redhat.com>
Message-Id: <20200917125540.597786-2-armbru@redhat.com>
Signed-off-by: Eduardo Habkost <ehabkost@redhat.com>
This commit is contained in:
Markus Armbruster 2020-09-17 14:55:39 +02:00 committed by Eduardo Habkost
parent 04dcf4b5db
commit d20f616e8f
3 changed files with 8 additions and 6 deletions

View File

@ -1687,9 +1687,9 @@ uint64_t object_property_get_uint(Object *obj, const char *name,
* @typename: the name of the enum data type * @typename: the name of the enum data type
* @errp: returns an error if this function fails * @errp: returns an error if this function fails
* *
* Returns: the value of the property, converted to an integer, or * Returns: the value of the property, converted to an integer (which
* undefined if an error occurs (including when the property value is not * can't be negative), or -1 on error (including when the property
* an enum). * value is not an enum).
*/ */
int object_property_get_enum(Object *obj, const char *name, int object_property_get_enum(Object *obj, const char *name,
const char *typename, Error **errp); const char *typename, Error **errp);

View File

@ -1564,21 +1564,21 @@ int object_property_get_enum(Object *obj, const char *name,
EnumProperty *enumprop; EnumProperty *enumprop;
if (prop == NULL) { if (prop == NULL) {
return 0; return -1;
} }
if (!g_str_equal(prop->type, typename)) { if (!g_str_equal(prop->type, typename)) {
error_setg(errp, "Property %s on %s is not '%s' enum type", error_setg(errp, "Property %s on %s is not '%s' enum type",
name, object_class_get_name( name, object_class_get_name(
object_get_class(obj)), typename); object_get_class(obj)), typename);
return 0; return -1;
} }
enumprop = prop->opaque; enumprop = prop->opaque;
str = object_property_get_str(obj, name, errp); str = object_property_get_str(obj, name, errp);
if (!str) { if (!str) {
return 0; return -1;
} }
ret = qapi_enum_parse(enumprop->lookup, str, -1, errp); ret = qapi_enum_parse(enumprop->lookup, str, -1, errp);

View File

@ -491,6 +491,7 @@ static void test_dummy_getenum(void)
"av", "av",
"BadAnimal", "BadAnimal",
&err); &err);
g_assert(val == -1);
error_free_or_abort(&err); error_free_or_abort(&err);
/* A non-enum property name */ /* A non-enum property name */
@ -498,6 +499,7 @@ static void test_dummy_getenum(void)
"iv", "iv",
"DummyAnimal", "DummyAnimal",
&err); &err);
g_assert(val == -1);
error_free_or_abort(&err); error_free_or_abort(&err);
object_unparent(OBJECT(dobj)); object_unparent(OBJECT(dobj));