--- src/adapter.c | 36 +++++++++++++++++++++++------------- 1 files changed, 23 insertions(+), 13 deletions(-) diff --git a/src/adapter.c b/src/adapter.c index 908704d..8a10607 100644 --- a/src/adapter.c +++ b/src/adapter.c @@ -3144,13 +3144,24 @@ static int pairing_is_legacy(bdaddr_t *local, bdaddr_t *peer, gboolean eir, return 0; } +static char *read_stored_data(bdaddr_t *local, bdaddr_t *peer, const char *file) +{ + char local_addr[18], peer_addr[18], filename[PATH_MAX + 1]; + + ba2str(local, local_addr); + ba2str(peer, peer_addr); + + create_name(filename, PATH_MAX, STORAGEDIR, local_addr, file); + + return textfile_get(filename, peer_addr); +} + void adapter_update_found_devices(struct btd_adapter *adapter, bdaddr_t *bdaddr, uint32_t class, int8_t rssi, uint8_t *data) { - char local_addr[18], peer_addr[18], filename[PATH_MAX + 1]; struct remote_dev_info *dev; struct eir_data eir_data; - char *alias, *name; + char *name; gboolean new_dev, legacy; name_status_t name_status; const char *dev_name; @@ -3170,15 +3181,7 @@ void adapter_update_found_devices(struct btd_adapter *adapter, bdaddr_t *bdaddr, else name_status = NAME_NOT_REQUIRED; - ba2str(&adapter->bdaddr, local_addr); - ba2str(bdaddr, peer_addr); - - create_name(filename, PATH_MAX, STORAGEDIR, local_addr, "aliases"); - alias = textfile_get(filename, peer_addr); - - create_name(filename, PATH_MAX, STORAGEDIR, local_addr, "names"); - name = textfile_get(filename, peer_addr); - + name = read_stored_data(&adapter->bdaddr, bdaddr, "names"); if (pairing_is_legacy(&adapter->bdaddr, bdaddr, data ? TRUE : FALSE, name ? TRUE : FALSE, &legacy) < 0) @@ -3200,18 +3203,22 @@ void adapter_update_found_devices(struct btd_adapter *adapter, bdaddr_t *bdaddr, dev = get_found_dev(adapter, bdaddr, &new_dev); if (new_dev) { + char *alias; if (dev_name) dev->name = g_strdup(dev_name); - if (alias) + alias = read_stored_data(&adapter->bdaddr, bdaddr, "aliases"); + if (alias) { dev->alias = g_strdup(alias); + free(alias); + } dev->le = FALSE; dev->class = class; dev->legacy = legacy; dev->name_status = name_status; } else if (dev->rssi == rssi) - return; + goto done; dev->rssi = rssi; @@ -3222,6 +3229,9 @@ void adapter_update_found_devices(struct btd_adapter *adapter, bdaddr_t *bdaddr, g_slist_foreach(eir_data.services, dev_prepend_uuid, dev); adapter_emit_device_found(adapter, dev); + +done: + free(name); } int adapter_remove_found_device(struct btd_adapter *adapter, bdaddr_t *bdaddr) -- 1.7.5.rc3 -- To unsubscribe from this list: send the line "unsubscribe linux-bluetooth" in the body of a message to majordomo@xxxxxxxxxxxxxxx More majordomo info at http://vger.kernel.org/majordomo-info.html