| Index: device/bluetooth/bluetooth_remote_gatt_characteristic_mac.mm
|
| diff --git a/device/bluetooth/bluetooth_remote_gatt_characteristic_mac.mm b/device/bluetooth/bluetooth_remote_gatt_characteristic_mac.mm
|
| index c04df6af94cbf836232feccfe1a9b6dd85743118..67c4c46a0808cccf6c6d1390c259795d762c0e98 100644
|
| --- a/device/bluetooth/bluetooth_remote_gatt_characteristic_mac.mm
|
| +++ b/device/bluetooth/bluetooth_remote_gatt_characteristic_mac.mm
|
| @@ -71,9 +71,7 @@ BluetoothRemoteGattCharacteristicMac::BluetoothRemoteGattCharacteristicMac(
|
| CBCharacteristic* cb_characteristic)
|
| : gatt_service_(gatt_service),
|
| cb_characteristic_(cb_characteristic, base::scoped_policy::RETAIN),
|
| - characteristic_value_read_or_write_in_progress_(false),
|
| - start_notifications_in_progress_(false),
|
| - weak_ptr_factory_(this) {
|
| + characteristic_value_read_or_write_in_progress_(false) {
|
| uuid_ = BluetoothAdapterMac::BluetoothUUIDWithCBUUID(
|
| [cb_characteristic_.get() UUID]);
|
| identifier_ = base::SysNSStringToUTF8(
|
| @@ -150,50 +148,6 @@ BluetoothRemoteGattCharacteristicMac::GetDescriptor(
|
| searched_pair->second.get());
|
| }
|
|
|
| -void BluetoothRemoteGattCharacteristicMac::StartNotifySession(
|
| - const NotifySessionCallback& callback,
|
| - const ErrorCallback& error_callback) {
|
| - if (IsNotifying()) {
|
| - VLOG(2) << "Already notifying. Creating notify session.";
|
| - std::unique_ptr<BluetoothGattNotifySession> notify_session(
|
| - new BluetoothGattNotifySession(weak_ptr_factory_.GetWeakPtr()));
|
| - base::ThreadTaskRunnerHandle::Get()->PostTask(
|
| - FROM_HERE,
|
| - base::Bind(callback, base::Passed(std::move(notify_session))));
|
| - return;
|
| - }
|
| -
|
| - if (!SupportsNotificationsOrIndications()) {
|
| - base::ThreadTaskRunnerHandle::Get()->PostTask(
|
| - FROM_HERE,
|
| - base::Bind(error_callback,
|
| - BluetoothRemoteGattService::GATT_ERROR_NOT_SUPPORTED));
|
| - return;
|
| - }
|
| -
|
| - start_notify_session_callbacks_.push_back(
|
| - std::make_pair(callback, error_callback));
|
| -
|
| - if (start_notifications_in_progress_) {
|
| - VLOG(2) << "Start Notifications already in progress. "
|
| - << "Request has been queued.";
|
| - return;
|
| - }
|
| -
|
| - [GetCBPeripheral() setNotifyValue:YES
|
| - forCharacteristic:cb_characteristic_.get()];
|
| - start_notifications_in_progress_ = true;
|
| -}
|
| -
|
| -void BluetoothRemoteGattCharacteristicMac::StopNotifySession(
|
| - BluetoothGattNotifySession* session,
|
| - const base::Closure& callback) {
|
| - // TODO(http://crbug.com/633191): Remove this method and use the base version.
|
| - // Instead, we should implement SubscribeToNotifications and
|
| - // UnsubscribeFromNotifications.
|
| - base::ThreadTaskRunnerHandle::Get()->PostTask(FROM_HERE, callback);
|
| -}
|
| -
|
| void BluetoothRemoteGattCharacteristicMac::ReadRemoteCharacteristic(
|
| const ValueCallback& callback,
|
| const ErrorCallback& error_callback) {
|
| @@ -256,8 +210,12 @@ void BluetoothRemoteGattCharacteristicMac::SubscribeToNotifications(
|
| BluetoothRemoteGattDescriptor* ccc_descriptor,
|
| const base::Closure& callback,
|
| const ErrorCallback& error_callback) {
|
| - // TODO(http://crbug.com/633191): Implement this method
|
| - NOTIMPLEMENTED();
|
| + DCHECK(subscribe_to_notification_callback_.first.is_null());
|
| + DCHECK(subscribe_to_notification_callback_.second.is_null());
|
| + subscribe_to_notification_callback_ =
|
| + std::make_pair(callback, error_callback);
|
| + [GetCBPeripheral() setNotifyValue:YES
|
| + forCharacteristic:cb_characteristic_.get()];
|
| }
|
|
|
| void BluetoothRemoteGattCharacteristicMac::UnsubscribeFromNotifications(
|
| @@ -336,10 +294,8 @@ void BluetoothRemoteGattCharacteristicMac::DidWriteValue(NSError* error) {
|
|
|
| void BluetoothRemoteGattCharacteristicMac::DidUpdateNotificationState(
|
| NSError* error) {
|
| - std::vector<std::pair<NotifySessionCallback, ErrorCallback>>
|
| - reentrant_safe_callbacks;
|
| - reentrant_safe_callbacks.swap(start_notify_session_callbacks_);
|
| - start_notifications_in_progress_ = false;
|
| + PendingNotifyCallback reentrant_safe_callbacks;
|
| + reentrant_safe_callbacks.swap(subscribe_to_notification_callback_);
|
| if (error) {
|
| VLOG(1) << "Bluetooth error while modifying notification state for "
|
| "characteristic, domain: "
|
| @@ -348,14 +304,13 @@ void BluetoothRemoteGattCharacteristicMac::DidUpdateNotificationState(
|
| << base::SysNSStringToUTF8(error.localizedDescription);
|
| BluetoothGattService::GattErrorCode error_code =
|
| BluetoothDeviceMac::GetGattErrorCodeFromNSError(error);
|
| - for (const auto& callback : reentrant_safe_callbacks) {
|
| - callback.second.Run(error_code);
|
| + if (!reentrant_safe_callbacks.second.is_null()) {
|
| + reentrant_safe_callbacks.second.Run(error_code);
|
| }
|
| return;
|
| }
|
| - for (const auto& callback : reentrant_safe_callbacks) {
|
| - callback.first.Run(base::MakeUnique<BluetoothGattNotifySession>(
|
| - weak_ptr_factory_.GetWeakPtr()));
|
| + if (!reentrant_safe_callbacks.first.is_null()) {
|
| + reentrant_safe_callbacks.first.Run();
|
| }
|
| }
|
|
|
|
|