mirror of
https://gitlab.freedesktop.org/NetworkManager/NetworkManager.git
synced 2026-01-01 04:50:11 +01:00
libnm-util: call virtual compare_property in nm_connection_diff
nm_connection_diff must also use the virtual functions like nm_connection_compare. This way, settings can overwrite the default comparison of individual properties. Signed-off-by: Thomas Haller <thaller@redhat.com>
This commit is contained in:
parent
4fba2260f3
commit
6abc7b78f6
1 changed files with 7 additions and 10 deletions
|
|
@ -699,22 +699,19 @@ nm_setting_diff (NMSetting *a,
|
|||
continue;
|
||||
|
||||
if (b) {
|
||||
g_value_init (&a_value, prop_spec->value_type);
|
||||
g_object_get_property (G_OBJECT (a), prop_spec->name, &a_value);
|
||||
|
||||
g_value_init (&b_value, prop_spec->value_type);
|
||||
g_object_get_property (G_OBJECT (b), prop_spec->name, &b_value);
|
||||
|
||||
different = !!g_param_values_cmp (prop_spec, &a_value, &b_value);
|
||||
different = !NM_SETTING_GET_CLASS (a)->compare_property (a, b, prop_spec, flags);
|
||||
if (different) {
|
||||
g_value_init (&a_value, prop_spec->value_type);
|
||||
g_value_init (&b_value, prop_spec->value_type);
|
||||
|
||||
if (!g_param_value_defaults (prop_spec, &a_value))
|
||||
r |= a_result;
|
||||
if (!g_param_value_defaults (prop_spec, &b_value))
|
||||
r |= b_result;
|
||||
}
|
||||
|
||||
g_value_unset (&a_value);
|
||||
g_value_unset (&b_value);
|
||||
g_value_unset (&a_value);
|
||||
g_value_unset (&b_value);
|
||||
}
|
||||
} else
|
||||
r = a_result; /* only in A */
|
||||
|
||||
|
|
|
|||
Loading…
Add table
Reference in a new issue