OLD | NEW |
1 // Copyright 2016 The Chromium Authors. All rights reserved. | 1 // Copyright 2016 The Chromium Authors. All rights reserved. |
2 // Use of this source code is governed by a BSD-style license that can be | 2 // Use of this source code is governed by a BSD-style license that can be |
3 // found in the LICENSE file. | 3 // found in the LICENSE file. |
4 | 4 |
5 #include "device/generic_sensor/sensor_provider_impl.h" | 5 #include "device/generic_sensor/sensor_provider_impl.h" |
6 | 6 |
7 #include <utility> | 7 #include <utility> |
8 | 8 |
| 9 #include "base/feature_list.h" |
9 #include "base/memory/ptr_util.h" | 10 #include "base/memory/ptr_util.h" |
10 #include "base/threading/thread_task_runner_handle.h" | 11 #include "base/threading/thread_task_runner_handle.h" |
11 #include "device/generic_sensor/platform_sensor_provider.h" | 12 #include "device/generic_sensor/platform_sensor_provider.h" |
12 #include "device/generic_sensor/sensor_impl.h" | 13 #include "device/generic_sensor/sensor_impl.h" |
13 #include "mojo/public/cpp/bindings/strong_binding.h" | 14 #include "mojo/public/cpp/bindings/strong_binding.h" |
| 15 #include "services/device/public/cpp/device_features.h" |
14 | 16 |
15 namespace device { | 17 namespace device { |
16 | 18 |
17 namespace { | 19 namespace { |
18 | 20 |
19 void RunCallback(mojom::SensorInitParamsPtr init_params, | 21 void RunCallback(mojom::SensorInitParamsPtr init_params, |
20 mojom::SensorClientRequest client, | 22 mojom::SensorClientRequest client, |
21 const SensorProviderImpl::GetSensorCallback& callback) { | 23 const SensorProviderImpl::GetSensorCallback& callback) { |
22 callback.Run(std::move(init_params), std::move(client)); | 24 callback.Run(std::move(init_params), std::move(client)); |
23 } | 25 } |
(...skipping 24 matching lines...) Expand all Loading... |
48 SensorProviderImpl::SensorProviderImpl(PlatformSensorProvider* provider) | 50 SensorProviderImpl::SensorProviderImpl(PlatformSensorProvider* provider) |
49 : provider_(provider), weak_ptr_factory_(this) { | 51 : provider_(provider), weak_ptr_factory_(this) { |
50 DCHECK(provider_); | 52 DCHECK(provider_); |
51 } | 53 } |
52 | 54 |
53 SensorProviderImpl::~SensorProviderImpl() {} | 55 SensorProviderImpl::~SensorProviderImpl() {} |
54 | 56 |
55 void SensorProviderImpl::GetSensor(mojom::SensorType type, | 57 void SensorProviderImpl::GetSensor(mojom::SensorType type, |
56 mojom::SensorRequest sensor_request, | 58 mojom::SensorRequest sensor_request, |
57 const GetSensorCallback& callback) { | 59 const GetSensorCallback& callback) { |
| 60 // For sensors that are used by DeviceMotionEvent, don't check the |
| 61 // features::kGenericSensor flag. |
| 62 if (!base::FeatureList::IsEnabled(features::kGenericSensor) && |
| 63 !(type == mojom::SensorType::ACCELEROMETER || |
| 64 type == mojom::SensorType::LINEAR_ACCELERATION || |
| 65 type == mojom::SensorType::GYROSCOPE)) { |
| 66 NotifySensorCreated(nullptr, nullptr, callback); |
| 67 return; |
| 68 } |
| 69 |
58 auto cloned_handle = provider_->CloneSharedBufferHandle(); | 70 auto cloned_handle = provider_->CloneSharedBufferHandle(); |
59 if (!cloned_handle.is_valid()) { | 71 if (!cloned_handle.is_valid()) { |
60 NotifySensorCreated(nullptr, nullptr, callback); | 72 NotifySensorCreated(nullptr, nullptr, callback); |
61 return; | 73 return; |
62 } | 74 } |
63 | 75 |
64 scoped_refptr<PlatformSensor> sensor = provider_->GetSensor(type); | 76 scoped_refptr<PlatformSensor> sensor = provider_->GetSensor(type); |
65 if (!sensor) { | 77 if (!sensor) { |
66 PlatformSensorProviderBase::CreateSensorCallback cb = base::Bind( | 78 PlatformSensorProviderBase::CreateSensorCallback cb = base::Bind( |
67 &SensorProviderImpl::SensorCreated, weak_ptr_factory_.GetWeakPtr(), | 79 &SensorProviderImpl::SensorCreated, weak_ptr_factory_.GetWeakPtr(), |
(...skipping 35 matching lines...) Expand 10 before | Expand all | Expand 10 after Loading... |
103 init_params->minimum_frequency = sensor->GetMinimumSupportedFrequency(); | 115 init_params->minimum_frequency = sensor->GetMinimumSupportedFrequency(); |
104 DCHECK_GT(init_params->minimum_frequency, 0.0); | 116 DCHECK_GT(init_params->minimum_frequency, 0.0); |
105 | 117 |
106 NotifySensorCreated(std::move(init_params), sensor_impl->GetClient(), | 118 NotifySensorCreated(std::move(init_params), sensor_impl->GetClient(), |
107 callback); | 119 callback); |
108 | 120 |
109 mojo::MakeStrongBinding(std::move(sensor_impl), std::move(sensor_request)); | 121 mojo::MakeStrongBinding(std::move(sensor_impl), std::move(sensor_request)); |
110 } | 122 } |
111 | 123 |
112 } // namespace device | 124 } // namespace device |
OLD | NEW |