mirror of
https://gitlab.freedesktop.org/NetworkManager/NetworkManager.git
synced 2026-01-04 02:50:17 +01:00
core: assert that nm_dbus_utils_get_property() returns a variant of the expected type
g_dbus_gvalue_to_gvariant() doesn't check/assert that the value has the right variant signature, if the value is already a GVariant. Add an assertion.
This commit is contained in:
parent
51b7d351fa
commit
5e84143378
1 changed files with 18 additions and 4 deletions
|
|
@ -72,21 +72,35 @@ nm_dbus_utils_get_property (GObject *obj,
|
|||
const char *signature,
|
||||
const char *property_name)
|
||||
{
|
||||
GParamSpec *pspec;
|
||||
nm_auto_unset_gvalue GValue value = G_VALUE_INIT;
|
||||
GParamSpec *pspec;
|
||||
GVariant *variant;
|
||||
|
||||
nm_assert (G_IS_OBJECT (obj));
|
||||
nm_assert (g_variant_type_string_is_valid (signature));
|
||||
nm_assert (property_name && property_name[0]);
|
||||
|
||||
pspec = g_object_class_find_property (G_OBJECT_GET_CLASS (obj), property_name);
|
||||
if (!pspec)
|
||||
g_return_val_if_reached (NULL);
|
||||
|
||||
nm_assert (pspec);
|
||||
|
||||
nm_assert ( pspec->value_type != G_TYPE_VARIANT
|
||||
|| nm_streq ((char *) (((GParamSpecVariant *) pspec)->type), signature));
|
||||
|
||||
g_value_init (&value, pspec->value_type);
|
||||
|
||||
g_object_get_property (obj, property_name, &value);
|
||||
|
||||
variant = g_dbus_gvalue_to_gvariant (&value, G_VARIANT_TYPE (signature));
|
||||
|
||||
nm_assert ( !variant
|
||||
|| g_variant_is_of_type (variant, G_VARIANT_TYPE (signature)));
|
||||
|
||||
/* returns never-floating variant */
|
||||
return g_dbus_gvalue_to_gvariant (&value, G_VARIANT_TYPE (signature));
|
||||
nm_assert ( !variant
|
||||
|| !g_variant_is_floating (variant));
|
||||
|
||||
return variant;
|
||||
}
|
||||
|
||||
/*****************************************************************************/
|
||||
|
|
|
|||
Loading…
Add table
Reference in a new issue