From 35c2fd92f827e61193b554e79c029948468e8b8c Mon Sep 17 00:00:00 2001 From: =?UTF-8?q?Jo=C3=A3o=20Paulo=20Rechi=20Vita?= Date: Tue, 4 Sep 2012 16:04:31 -0300 Subject: [PATCH] core: Add compare function for bdaddr in a struct btd_device This is a utility function similar to device_address_cmp but comparing bdaddr instead of the string representing the address. This way is possible to avoid allocating two buffers to temporarily hold the strings, two sprintf() calls to generate the strings from the bdaddr arrays, and a string comparison, substituting all of it for one memcmp() call. --- src/device.c | 5 +++++ src/device.h | 1 + 2 files changed, 6 insertions(+) diff --git a/src/device.c b/src/device.c index d2bac97d4..c65f0b7ba 100644 --- a/src/device.c +++ b/src/device.c @@ -1228,6 +1228,11 @@ gint device_address_cmp(struct btd_device *device, const gchar *address) return strcasecmp(addr, address); } +gint device_bdaddr_cmp(struct btd_device *device, bdaddr_t *bdaddr) +{ + return bacmp(&device->bdaddr, bdaddr); +} + static gboolean record_has_uuid(const sdp_record_t *rec, const char *profile_uuid) { diff --git a/src/device.h b/src/device.h index edc64b991..f1d95c6d5 100644 --- a/src/device.h +++ b/src/device.h @@ -77,6 +77,7 @@ uint16_t btd_device_get_product(struct btd_device *device); uint16_t btd_device_get_version(struct btd_device *device); void device_remove(struct btd_device *device, gboolean remove_stored); gint device_address_cmp(struct btd_device *device, const gchar *address); +gint device_bdaddr_cmp(struct btd_device *device, bdaddr_t *bdaddr); int device_browse_primary(struct btd_device *device, DBusConnection *conn, DBusMessage *msg, gboolean secure); int device_browse_sdp(struct btd_device *device, DBusConnection *conn, -- 2.47.3