diff options
author | Aleksander Morgado <aleksander@aleksander.es> | 2020-11-03 10:29:50 +0100 |
---|---|---|
committer | Aleksander Morgado <aleksander@aleksander.es> | 2020-11-14 13:39:40 +0000 |
commit | 4550dcfbdf2e1c8c4db0d7b7260144fb653c095d (patch) | |
tree | 50aada1b436481ca83c6099bebefe5b134a66ca7 /src/kerneldevice/mm-kernel-device-udev.c | |
parent | 1e1fe8fb9c9b02de5f29f33bd46575d4d88f1464 (diff) |
kerneldevice: no need to subclass the type getters
We can just subclass the methods to check whether a given property
exists and to get it as a string, and then implement in the generic
class the actual boolean/int/hex type getters common for all.
Diffstat (limited to 'src/kerneldevice/mm-kernel-device-udev.c')
-rw-r--r-- | src/kerneldevice/mm-kernel-device-udev.c | 148 |
1 files changed, 22 insertions, 126 deletions
diff --git a/src/kerneldevice/mm-kernel-device-udev.c b/src/kerneldevice/mm-kernel-device-udev.c index 8350a339..b39e58de 100644 --- a/src/kerneldevice/mm-kernel-device-udev.c +++ b/src/kerneldevice/mm-kernel-device-udev.c @@ -599,51 +599,6 @@ kernel_device_get_property (MMKernelDevice *_self, } static gboolean -kernel_device_get_property_as_boolean (MMKernelDevice *_self, - const gchar *property) -{ - MMKernelDeviceUdev *self; - - self = MM_KERNEL_DEVICE_UDEV (_self); - - if (!self->priv->device) - return FALSE; - - return g_udev_device_get_property_as_boolean (self->priv->device, property); -} - -static gint -kernel_device_get_property_as_int (MMKernelDevice *_self, - const gchar *property) -{ - MMKernelDeviceUdev *self; - - self = MM_KERNEL_DEVICE_UDEV (_self); - - if (!self->priv->device) - return -1; - - return g_udev_device_get_property_as_int (self->priv->device, property); -} - -static guint -kernel_device_get_property_as_int_hex (MMKernelDevice *_self, - const gchar *property) -{ - MMKernelDeviceUdev *self; - const gchar *s; - guint out = 0; - - self = MM_KERNEL_DEVICE_UDEV (_self); - - if (!self->priv->device) - return G_MAXUINT; - - s = g_udev_device_get_property (self->priv->device, property); - return ((s && mm_get_uint_from_hex_str (s, &out)) ? out : 0); -} - -static gboolean kernel_device_has_global_property (MMKernelDevice *_self, const gchar *property) { @@ -676,59 +631,6 @@ kernel_device_get_global_property (MMKernelDevice *_self, return kernel_device_get_property (_self, property); } -static gboolean -kernel_device_get_global_property_as_boolean (MMKernelDevice *_self, - const gchar *property) -{ - MMKernelDeviceUdev *self; - - self = MM_KERNEL_DEVICE_UDEV (_self); - - ensure_physdev (self); - if (self->priv->physdev && - g_udev_device_has_property (self->priv->physdev, property) && - g_udev_device_get_property (self->priv->physdev, property)) - return TRUE; - - return kernel_device_get_property_as_boolean (_self, property); -} - -static gint -kernel_device_get_global_property_as_int (MMKernelDevice *_self, - const gchar *property) -{ - MMKernelDeviceUdev *self; - gint value; - - self = MM_KERNEL_DEVICE_UDEV (_self); - - ensure_physdev (self); - if (self->priv->physdev && - g_udev_device_has_property (self->priv->physdev, property) && - (value = g_udev_device_get_property_as_int (self->priv->physdev, property)) >= 0) - return value; - - return kernel_device_get_property_as_int (_self, property); -} - -static guint -kernel_device_get_global_property_as_int_hex (MMKernelDevice *_self, - const gchar *property) -{ - MMKernelDeviceUdev *self; - const gchar *s; - guint out = 0; - - self = MM_KERNEL_DEVICE_UDEV (_self); - - ensure_physdev (self); - if (self->priv->physdev && - g_udev_device_has_property (self->priv->physdev, property) && - (s = g_udev_device_get_property (self->priv->physdev, property)) != NULL) - return ((s && mm_get_uint_from_hex_str (s, &out)) ? out : 0); - - return kernel_device_get_property_as_int_hex (_self, property); -} /*****************************************************************************/ @@ -903,34 +805,28 @@ mm_kernel_device_udev_class_init (MMKernelDeviceUdevClass *klass) object_class->get_property = get_property; object_class->set_property = set_property; - kernel_device_class->get_subsystem = kernel_device_get_subsystem; - kernel_device_class->get_name = kernel_device_get_name; - kernel_device_class->get_driver = kernel_device_get_driver; - kernel_device_class->get_sysfs_path = kernel_device_get_sysfs_path; - kernel_device_class->get_physdev_uid = kernel_device_get_physdev_uid; - kernel_device_class->get_physdev_vid = kernel_device_get_physdev_vid; - kernel_device_class->get_physdev_pid = kernel_device_get_physdev_pid; - kernel_device_class->get_physdev_revision = kernel_device_get_physdev_revision; - kernel_device_class->get_physdev_sysfs_path = kernel_device_get_physdev_sysfs_path; - kernel_device_class->get_physdev_subsystem = kernel_device_get_physdev_subsystem; - kernel_device_class->get_physdev_manufacturer = kernel_device_get_physdev_manufacturer; - kernel_device_class->get_physdev_product = kernel_device_get_physdev_product; - kernel_device_class->get_interface_class = kernel_device_get_interface_class; - kernel_device_class->get_interface_subclass = kernel_device_get_interface_subclass; - kernel_device_class->get_interface_protocol = kernel_device_get_interface_protocol; - kernel_device_class->get_interface_sysfs_path = kernel_device_get_interface_sysfs_path; - kernel_device_class->get_interface_description = kernel_device_get_interface_description; - kernel_device_class->cmp = kernel_device_cmp; - kernel_device_class->has_property = kernel_device_has_property; - kernel_device_class->get_property = kernel_device_get_property; - kernel_device_class->get_property_as_boolean = kernel_device_get_property_as_boolean; - kernel_device_class->get_property_as_int = kernel_device_get_property_as_int; - kernel_device_class->get_property_as_int_hex = kernel_device_get_property_as_int_hex; - kernel_device_class->has_global_property = kernel_device_has_global_property; - kernel_device_class->get_global_property = kernel_device_get_global_property; - kernel_device_class->get_global_property_as_boolean = kernel_device_get_global_property_as_boolean; - kernel_device_class->get_global_property_as_int = kernel_device_get_global_property_as_int; - kernel_device_class->get_global_property_as_int_hex = kernel_device_get_global_property_as_int_hex; + kernel_device_class->get_subsystem = kernel_device_get_subsystem; + kernel_device_class->get_name = kernel_device_get_name; + kernel_device_class->get_driver = kernel_device_get_driver; + kernel_device_class->get_sysfs_path = kernel_device_get_sysfs_path; + kernel_device_class->get_physdev_uid = kernel_device_get_physdev_uid; + kernel_device_class->get_physdev_vid = kernel_device_get_physdev_vid; + kernel_device_class->get_physdev_pid = kernel_device_get_physdev_pid; + kernel_device_class->get_physdev_revision = kernel_device_get_physdev_revision; + kernel_device_class->get_physdev_sysfs_path = kernel_device_get_physdev_sysfs_path; + kernel_device_class->get_physdev_subsystem = kernel_device_get_physdev_subsystem; + kernel_device_class->get_physdev_manufacturer = kernel_device_get_physdev_manufacturer; + kernel_device_class->get_physdev_product = kernel_device_get_physdev_product; + kernel_device_class->get_interface_class = kernel_device_get_interface_class; + kernel_device_class->get_interface_subclass = kernel_device_get_interface_subclass; + kernel_device_class->get_interface_protocol = kernel_device_get_interface_protocol; + kernel_device_class->get_interface_sysfs_path = kernel_device_get_interface_sysfs_path; + kernel_device_class->get_interface_description = kernel_device_get_interface_description; + kernel_device_class->cmp = kernel_device_cmp; + kernel_device_class->has_property = kernel_device_has_property; + kernel_device_class->get_property = kernel_device_get_property; + kernel_device_class->has_global_property = kernel_device_has_global_property; + kernel_device_class->get_global_property = kernel_device_get_global_property; properties[PROP_UDEV_DEVICE] = g_param_spec_object ("udev-device", |