summaryrefslogtreecommitdiff
diff options
context:
space:
mode:
authorFernando Fernandez Mancera <ffmancera@riseup.net>2020-12-01 11:28:00 +0100
committerFernando Fernandez Mancera <ffmancera@riseup.net>2020-12-01 16:45:36 +0100
commitfda6b702bacfa1e35ac68f2b22ad9e67b8f3dade (patch)
tree021fc35ce733eed8bc5e509472070c36e38ae949
parent526b484be1981b4bfcc5e48d5480c6ac7ccd8b66 (diff)
downloadNetworkManager-fda6b702bacfa1e35ac68f2b22ad9e67b8f3dade.tar.gz
veth: peer property is D-Bus object path not a string
Signed-off-by: Fernando Fernandez Mancera <ffmancera@riseup.net>
-rw-r--r--libnm/nm-device-veth.c47
-rw-r--r--libnm/nm-device-veth.h2
2 files changed, 22 insertions, 27 deletions
diff --git a/libnm/nm-device-veth.c b/libnm/nm-device-veth.c
index ba51ae6455..9f00cd8a6e 100644
--- a/libnm/nm-device-veth.c
+++ b/libnm/nm-device-veth.c
@@ -19,7 +19,7 @@
NM_GOBJECT_PROPERTIES_DEFINE_BASE(PROP_PEER, );
typedef struct {
- char *peer;
+ NMLDBusPropertyO peer;
} NMDeviceVethPrivate;
struct _NMDeviceVeth {
@@ -42,16 +42,16 @@ G_DEFINE_TYPE(NMDeviceVeth, nm_device_veth, NM_TYPE_DEVICE_ETHERNET)
* nm_device_veth_get_peer:
* @device: a #NMDeviceVeth
*
- * Returns: the device's peer name
+ * Returns: (transfer none): the device's peer device
*
* Since: 1.30
**/
-const char *
+NMDevice *
nm_device_veth_get_peer(NMDeviceVeth *device)
{
- g_return_val_if_fail(NM_IS_DEVICE_VETH(device), NULL);
+ g_return_val_if_fail(NM_IS_DEVICE_VETH(device), FALSE);
- return _nml_coerce_property_str_not_empty(NM_DEVICE_VETH_GET_PRIVATE(device)->peer);
+ return nml_dbus_property_o_get_obj(&NM_DEVICE_VETH_GET_PRIVATE(device)->peer);
}
static GType
@@ -69,7 +69,7 @@ get_property(GObject *object, guint prop_id, GValue *value, GParamSpec *pspec)
switch (prop_id) {
case PROP_PEER:
- g_value_set_string(value, nm_device_veth_get_peer(device));
+ g_value_set_object(value, nm_device_veth_get_peer(device));
break;
default:
G_OBJECT_WARN_INVALID_PROPERTY_ID(object, prop_id, pspec);
@@ -81,22 +81,16 @@ static void
nm_device_veth_init(NMDeviceVeth *device)
{}
-static void
-finalize(GObject *object)
-{
- NMDeviceVethPrivate *priv = NM_DEVICE_VETH_GET_PRIVATE(object);
-
- g_free(priv->peer);
-
- G_OBJECT_CLASS(nm_device_veth_parent_class)->finalize(object);
-}
-
-const NMLDBusMetaIface _nml_dbus_meta_iface_nm_device_veth = NML_DBUS_META_IFACE_INIT_PROP(
- NM_DBUS_INTERFACE_DEVICE_VETH,
- nm_device_veth_get_type,
- NML_DBUS_META_INTERFACE_PRIO_INSTANTIATE_20,
- NML_DBUS_META_IFACE_DBUS_PROPERTIES(
- NML_DBUS_META_PROPERTY_INIT_S("peer", PROP_PEER, NMDeviceVeth, _priv.peer), ), );
+const NMLDBusMetaIface _nml_dbus_meta_iface_nm_device_veth =
+ NML_DBUS_META_IFACE_INIT_PROP(NM_DBUS_INTERFACE_DEVICE_VETH,
+ nm_device_veth_get_type,
+ NML_DBUS_META_INTERFACE_PRIO_INSTANTIATE_20,
+ NML_DBUS_META_IFACE_DBUS_PROPERTIES(
+ NML_DBUS_META_PROPERTY_INIT_O_PROP("Peer",
+ PROP_PEER,
+ NMDeviceVeth,
+ _priv.peer,
+ nm_device_get_type), ), );
static void
nm_device_veth_class_init(NMDeviceVethClass *klass)
@@ -106,23 +100,24 @@ nm_device_veth_class_init(NMDeviceVethClass *klass)
NMDeviceClass *device_class = NM_DEVICE_CLASS(klass);
object_class->get_property = get_property;
- object_class->finalize = finalize;
_NM_OBJECT_CLASS_INIT_PRIV_PTR_DIRECT(nm_object_class, NMDeviceVeth);
+ _NM_OBJECT_CLASS_INIT_PROPERTY_O_FIELDS_1(nm_object_class, NMDeviceVethPrivate, peer);
+
device_class->get_setting_type = get_setting_type;
/**
* NMDeviceVeth:peer:
*
- * The device's peer name.
+ * The device's peer device.
*
* Since: 1.30
**/
- obj_properties[PROP_PEER] = g_param_spec_string(NM_DEVICE_VETH_PEER,
+ obj_properties[PROP_PEER] = g_param_spec_object(NM_DEVICE_VETH_PEER,
"",
"",
- NULL,
+ NM_TYPE_DEVICE,
G_PARAM_READABLE | G_PARAM_STATIC_STRINGS);
_nml_dbus_meta_class_init_with_properties(object_class, &_nml_dbus_meta_iface_nm_device_veth);
diff --git a/libnm/nm-device-veth.h b/libnm/nm-device-veth.h
index eb03d28055..8aef13964c 100644
--- a/libnm/nm-device-veth.h
+++ b/libnm/nm-device-veth.h
@@ -34,7 +34,7 @@ NM_AVAILABLE_IN_1_30
GType nm_device_veth_get_type(void);
NM_AVAILABLE_IN_1_30
-const char *nm_device_veth_get_peer(NMDeviceVeth *device);
+NMDevice *nm_device_veth_get_peer(NMDeviceVeth *device);
G_END_DECLS