Index: blimp/client/core/geolocation/blimp_location_provider.cc |
diff --git a/blimp/client/core/geolocation/blimp_location_provider.cc b/blimp/client/core/geolocation/blimp_location_provider.cc |
new file mode 100644 |
index 0000000000000000000000000000000000000000..b1fe83f349fe526450b14f90ab65f0779b899cd1 |
--- /dev/null |
+++ b/blimp/client/core/geolocation/blimp_location_provider.cc |
@@ -0,0 +1,59 @@ |
+// Copyright 2016 The Chromium Authors. All rights reserved. |
+// Use of this source code is governed by a BSD-style license that can be |
+// found in the LICENSE file. |
+ |
+#include "blimp/client/core/geolocation/blimp_location_provider.h" |
+ |
+#include "device/geolocation/geoposition.h" |
+#include "device/geolocation/location_arbitrator_impl.h" |
+ |
+namespace blimp { |
+namespace client { |
+namespace { |
+class BlimpGeolocationDelegate : public device::GeolocationDelegate { |
+ public: |
+ BlimpGeolocationDelegate() = default; |
+ |
+ private: |
+ DISALLOW_COPY_AND_ASSIGN(BlimpGeolocationDelegate); |
+}; |
+ |
+} // namespace |
+ |
+BlimpLocationProvider::BlimpLocationProvider() |
+ : location_provider_(new device::LocationArbitratorImpl( |
+ base::Bind(&BlimpLocationProvider::OnLocationUpdate, |
+ base::Unretained(this)), |
+ new BlimpGeolocationDelegate())) {} |
Wez
2016/08/19 23:12:10
Why not pass in a default GeolocationDelegate here
CJ
2016/08/22 20:28:08
I thought there would be some issue with there not
|
+ |
+BlimpLocationProvider::~BlimpLocationProvider() {} |
+ |
+void BlimpLocationProvider::SetUpdateCallback( |
+ const LocationProviderUpdateCallback& callback) { |
+ DCHECK(!callback.is_null()); |
+ feature_update_callback_ = callback; |
+} |
+ |
+bool BlimpLocationProvider::StartProvider(bool enable_high_accuracy) { |
+ return location_provider_->StartProvider(enable_high_accuracy); |
+} |
+ |
+void BlimpLocationProvider::StopProvider() { |
+ location_provider_->StopProvider(); |
+} |
+ |
+const device::Geoposition& BlimpLocationProvider::GetPosition() { |
+ return location_provider_->GetPosition(); |
+} |
+ |
+void BlimpLocationProvider::OnPermissionGranted() { |
+ location_provider_->OnPermissionGranted(); |
+} |
+ |
+void BlimpLocationProvider::OnLocationUpdate( |
+ const device::Geoposition& new_position) { |
+ feature_update_callback_.Run(this, new_position); |
+} |
+ |
+} // namespace client |
+} // namespace blimp |