| Index: chrome/browser/ui/bluetooth/bluetooth_chooser_controller.cc
|
| diff --git a/chrome/browser/ui/bluetooth/bluetooth_chooser_controller.cc b/chrome/browser/ui/bluetooth/bluetooth_chooser_controller.cc
|
| index 0b096bcb932d486ab574effcb06e4dfa164c2d6d..49dccb9597a74dc264ad4d833939de0df9a7e93d 100644
|
| --- a/chrome/browser/ui/bluetooth/bluetooth_chooser_controller.cc
|
| +++ b/chrome/browser/ui/bluetooth/bluetooth_chooser_controller.cc
|
| @@ -50,19 +50,21 @@ base::string16 BluetoothChooserController::GetOkButtonLabel() const {
|
| }
|
|
|
| size_t BluetoothChooserController::NumOptions() const {
|
| - return device_names_and_ids_.size();
|
| + return device_ids_.size();
|
| }
|
|
|
| base::string16 BluetoothChooserController::GetOption(size_t index) const {
|
| - DCHECK_LT(index, device_names_and_ids_.size());
|
| - const base::string16& device_name = device_names_and_ids_[index].first;
|
| - const auto& it = device_name_map_.find(device_name);
|
| + DCHECK_LT(index, device_ids_.size());
|
| + const std::string& device_id = device_ids_[index];
|
| + const auto& device_name_it = device_id_to_name_map_.find(device_id);
|
| + DCHECK(device_name_it != device_id_to_name_map_.end());
|
| + const auto& it = device_name_map_.find(device_name_it->second);
|
| DCHECK(it != device_name_map_.end());
|
| return it->second == 1
|
| - ? device_name
|
| + ? device_name_it->second
|
| : l10n_util::GetStringFUTF16(
|
| - IDS_DEVICE_CHOOSER_DEVICE_NAME_WITH_ID, device_name,
|
| - base::UTF8ToUTF16(device_names_and_ids_[index].second));
|
| + IDS_DEVICE_CHOOSER_DEVICE_NAME_WITH_ID,
|
| + device_name_it->second, base::UTF8ToUTF16(device_id));
|
| }
|
|
|
| void BluetoothChooserController::RefreshOptions() {
|
| @@ -83,9 +85,9 @@ void BluetoothChooserController::Select(size_t index) {
|
| BLUETOOTH_CHOOSER_EVENT_HANDLER_INVALID);
|
| return;
|
| }
|
| - DCHECK_LT(index, device_names_and_ids_.size());
|
| + DCHECK_LT(index, device_ids_.size());
|
| event_handler_.Run(content::BluetoothChooser::Event::SELECTED,
|
| - device_names_and_ids_[index].second);
|
| + device_ids_[index]);
|
| }
|
|
|
| void BluetoothChooserController::Cancel() {
|
| @@ -161,27 +163,54 @@ void BluetoothChooserController::OnDiscoveryStateChanged(
|
| }
|
| }
|
|
|
| -void BluetoothChooserController::AddDevice(const std::string& device_id,
|
| - const base::string16& device_name) {
|
| - device_names_and_ids_.push_back(std::make_pair(device_name, device_id));
|
| +void BluetoothChooserController::AddOrUpdateDevice(
|
| + const std::string& device_id,
|
| + bool should_update_name,
|
| + const base::string16& device_name,
|
| + bool is_gatt_connected,
|
| + bool is_paired,
|
| + const int8_t* rssi) {
|
| + auto result = device_id_to_name_map_.insert({device_id, device_name});
|
| + if (!result.second) {
|
| + // TODO(ortuno): Update device's information.
|
| + // https://crbug.com/634366 Update name
|
| + // http://crbug.com/543466 Update connection and paired status
|
| + // http://crbug.com/629689 Update RSSI.
|
| + return;
|
| + }
|
| +
|
| + device_ids_.push_back(device_id);
|
| ++device_name_map_[device_name];
|
| if (view())
|
| - view()->OnOptionAdded(device_names_and_ids_.size() - 1);
|
| + view()->OnOptionAdded(device_ids_.size() - 1);
|
| }
|
|
|
| void BluetoothChooserController::RemoveDevice(const std::string& device_id) {
|
| - for (auto it = device_names_and_ids_.begin();
|
| - it != device_names_and_ids_.end(); ++it) {
|
| - if (it->second == device_id) {
|
| - size_t index = it - device_names_and_ids_.begin();
|
| - DCHECK_GT(device_name_map_[it->first], 0);
|
| - if (--device_name_map_[it->first] == 0)
|
| - device_name_map_.erase(it->first);
|
| - device_names_and_ids_.erase(it);
|
| - if (view())
|
| - view()->OnOptionRemoved(index);
|
| - return;
|
| + const auto& name_it = device_id_to_name_map_.find(device_id);
|
| + if (name_it == device_id_to_name_map_.end())
|
| + return;
|
| +
|
| + size_t index = 0;
|
| + for (const auto& saved_device_id : device_ids_) {
|
| + if (saved_device_id != device_id) {
|
| + ++index;
|
| + continue;
|
| }
|
| +
|
| + device_ids_.erase(device_ids_.begin() + index);
|
| +
|
| + const auto& it = device_name_map_.find(name_it->second);
|
| + DCHECK(it != device_name_map_.end());
|
| + DCHECK_GT(it->second, 0);
|
| +
|
| + if (--(it->second) == 0)
|
| + device_name_map_.erase(it);
|
| +
|
| + device_id_to_name_map_.erase(name_it);
|
| +
|
| + if (view())
|
| + view()->OnOptionRemoved(index);
|
| + return;
|
| }
|
| }
|
|
|
| @@ -190,6 +219,7 @@ void BluetoothChooserController::ResetEventHandler() {
|
| }
|
|
|
| void BluetoothChooserController::ClearAllDevices() {
|
| - device_names_and_ids_.clear();
|
| + device_ids_.clear();
|
| + device_id_to_name_map_.clear();
|
| device_name_map_.clear();
|
| }
|
|
|