Chromium Code Reviews
chromiumcodereview-hr@appspot.gserviceaccount.com (chromiumcodereview-hr) | Please choose your nickname with Settings | Help | Chromium Project | Gerrit Changes | Sign out
(8114)

Unified Diff: chrome/browser/ui/bluetooth/bluetooth_chooser_controller.cc

Issue 2210873003: bluetooth: Allow updates on chooser items. (Closed) Base URL: https://chromium.googlesource.com/chromium/src.git@bluetooth-fix-advertised-services
Patch Set: Make const Created 4 years, 4 months ago
Use n/p to move between diff chunks; N/P to move between comments. Draft comments are only viewable by you.
Jump to:
View side-by-side diff with in-line comments
Download patch
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();
}
« no previous file with comments | « chrome/browser/ui/bluetooth/bluetooth_chooser_controller.h ('k') | chrome/browser/ui/bluetooth/bluetooth_chooser_desktop.h » ('j') | no next file with comments »

Powered by Google App Engine
This is Rietveld 408576698