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

Unified Diff: blimp/engine/feature/geolocation/engine_geolocation_feature.cc

Issue 2091023006: Adds EngineGeolocationFeature for Blimp Geolocation project. (Closed) Base URL: https://chromium.googlesource.com/chromium/src.git@master
Patch Set: Created 4 years, 6 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: blimp/engine/feature/geolocation/engine_geolocation_feature.cc
diff --git a/blimp/engine/feature/geolocation/engine_geolocation_feature.cc b/blimp/engine/feature/geolocation/engine_geolocation_feature.cc
new file mode 100644
index 0000000000000000000000000000000000000000..d4949f38651b3c392a0a66eab1758db4b1d73525
--- /dev/null
+++ b/blimp/engine/feature/geolocation/engine_geolocation_feature.cc
@@ -0,0 +1,130 @@
+// 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/common/create_blimp_message.h"
+#include "blimp/common/proto/blimp_message.pb.h"
+#include "blimp/common/proto/geolocation.pb.h"
+#include "blimp/engine/feature/geolocation/engine_geolocation_feature.h"
+#include "content/public/common/geoposition.h"
+
+namespace blimp {
+namespace engine {
+
+void EngineGeolocationFeature::set_geolocation_message_sender(
+ std::unique_ptr<BlimpMessageProcessor> message_processor) {
+ DCHECK(message_processor);
+ geolocation_message_sender_ = std::move(message_processor);
+}
+
+void EngineGeolocationFeature::SendUpdateListenStateMessage(
+ bool enable_high_accuracy) {
+ GeolocationMessage* geolocation_message;
+ std::unique_ptr<BlimpMessage> blimp_message =
+ CreateBlimpMessage(&geolocation_message);
+
+ UpdateListenStateMessage* details =
+ geolocation_message->mutable_update_listen_state();
+ (enable_high_accuracy)
Kevin M 2016/06/27 16:57:41 Use conventional if/else syntax.
CJ 2016/06/27 22:04:26 Done.
+ ? details->set_listen_state(UpdateListenStateMessage::ACCURACY_HIGH)
+ : details->set_listen_state(UpdateListenStateMessage::ACCURACY_LOW);
+
+ geolocation_message_sender_->ProcessMessage(std::move(blimp_message),
+ net::CompletionCallback());
+}
+
+void EngineGeolocationFeature::SendStopListenStateMessage() {
+ GeolocationMessage* geolocation_message;
+ std::unique_ptr<BlimpMessage> blimp_message =
+ CreateBlimpMessage(&geolocation_message);
+
+ UpdateListenStateMessage* details =
+ geolocation_message->mutable_update_listen_state();
+ details->set_listen_state(UpdateListenStateMessage::STOPPED);
+
+ geolocation_message_sender_->ProcessMessage(std::move(blimp_message),
+ net::CompletionCallback());
+}
+
+void EngineGeolocationFeature::SendRequestRefreshMessage() {
+ GeolocationMessage* geolocation_message;
+ std::unique_ptr<BlimpMessage> blimp_message =
+ CreateBlimpMessage(&geolocation_message);
+
+ geolocation_message->mutable_request_refresh();
+
+ geolocation_message_sender_->ProcessMessage(std::move(blimp_message),
+ net::CompletionCallback());
+}
+
+void EngineGeolocationFeature::SetDelegate(
+ GeolocationMessageDelegate* delegate) {
+ DCHECK(delegate);
Kevin M 2016/06/27 16:57:41 Also check !delegate_ ?
CJ 2016/06/27 22:04:26 Done.
+
+ delegate_ = delegate;
+}
+
+void EngineGeolocationFeature::ProcessMessage(
+ std::unique_ptr<BlimpMessage> message,
+ const net::CompletionCallback& callback) {
+ DCHECK(!callback.is_null());
+ DCHECK(message->feature_case() == BlimpMessage::kGeolocation);
Kevin M 2016/06/27 16:57:41 DCHECK_EQ(expected, actual)
CJ 2016/06/27 22:04:26 Done.
+ DCHECK(delegate_);
+
+ GeolocationMessage geolocation_message = message->geolocation();
Kevin M 2016/06/27 16:57:41 Use "const GeolocationMessage&" instead, so that y
CJ 2016/06/27 22:04:26 Done.
+ content::Geoposition geoposition;
Kevin M 2016/06/27 16:57:41 "output" ?
CJ 2016/06/27 22:04:26 Done.
+
+ switch (geolocation_message.type_case()) {
+ case GeolocationMessage::kLocation: {
+ LocationMessage location = geolocation_message.location();
+
+ geoposition.latitude = location.latitude();
Kevin M 2016/06/27 16:57:41 Put this in an anonymous namespace method. Too muc
CJ 2016/06/27 22:04:26 Done.
+ geoposition.longitude = location.longitude();
+ geoposition.altitude = location.altitude();
+ geoposition.accuracy = location.accuracy();
+ geoposition.altitude_accuracy = location.altitude_accuracy();
+ geoposition.heading = location.heading();
+ geoposition.speed = location.speed();
+ geoposition.timestamp =
+ base::Time::FromJsTime(location.timestamp_millis());
Kevin M 2016/06/27 16:57:41 DCHECK if geoposition is valid (using Geoposition:
CJ 2016/06/27 22:04:26 This already gets handled upstream by the Location
+
+ UpdateGeolocation(&geoposition);
+ break;
+ }
+ case GeolocationMessage::kError: {
+ ErrorMessage error_message = geolocation_message.error();
Kevin M 2016/06/27 16:57:41 Store this as a const reference or just refer to t
CJ 2016/06/27 22:04:26 Done.
+ switch (error_message.error_code()) {
Kevin M 2016/06/27 16:57:41 Put this in an anonymous namespace method for mapp
CJ 2016/06/27 22:04:26 Done.
+ case ErrorMessage::ERROR_CODE_NONE:
+ geoposition.error_code =
+ content::Geoposition::ErrorCode::ERROR_CODE_NONE;
+ break;
+ case ErrorMessage::ERROR_CODE_PERMISSION_DENIED:
+ geoposition.error_code =
+ content::Geoposition::ErrorCode::ERROR_CODE_PERMISSION_DENIED;
+ break;
+ case ErrorMessage::ERROR_CODE_POSITION_UNAVAILABLE:
+ geoposition.error_code =
+ content::Geoposition::ErrorCode::ERROR_CODE_POSITION_UNAVAILABLE;
+ case ErrorMessage::ERROR_CODE_TIMEOUT:
+ geoposition.error_code =
+ content::Geoposition::ErrorCode::ERROR_CODE_TIMEOUT;
+ break;
+ }
+ geoposition.error_message = error_message.error_message();
+
+ UpdateGeolocation(&geoposition);
+ break;
+ }
+ default:
Kevin M 2016/06/27 16:57:41 Handle TYPE_NOT_SET instead of using "default" so
CJ 2016/06/27 22:04:26 Done.
+ NOTREACHED();
+ }
+}
+
+void EngineGeolocationFeature::UpdateGeolocation(
Kevin M 2016/06/27 16:57:41 This is just a one-liner method whose implementati
CJ 2016/06/27 22:04:26 Done.
+ content::Geoposition* geoposition) {
Kevin M 2016/06/27 16:57:41 Take a const reference instead of a pointer here.
CJ 2016/06/27 22:04:26 Done.
+ DCHECK(delegate_);
+ delegate_->OnLocationResponse(*geoposition);
+}
+
+} // namespace engine
+} // namespace blimp

Powered by Google App Engine
This is Rietveld 408576698