Chromium Code Reviews| 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 "blimp/client/core/settings/settings_feature.h" | 5 #include "blimp/client/core/settings/settings_feature.h" |
| 6 | 6 |
| 7 #include "blimp/client/core/settings/settings.h" | |
| 7 #include "blimp/common/create_blimp_message.h" | 8 #include "blimp/common/create_blimp_message.h" |
| 8 #include "blimp/common/proto/blimp_message.pb.h" | 9 #include "blimp/common/proto/blimp_message.pb.h" |
| 9 #include "blimp/common/proto/settings.pb.h" | 10 #include "blimp/common/proto/settings.pb.h" |
| 10 #include "net/base/net_errors.h" | 11 #include "net/base/net_errors.h" |
| 11 | 12 |
| 12 namespace blimp { | 13 namespace blimp { |
| 13 namespace client { | 14 namespace client { |
| 14 | 15 |
| 15 SettingsFeature::SettingsFeature() : record_whole_document_(false) {} | 16 SettingsFeature::SettingsFeature(Settings* settings) |
| 17 : SettingsObserver(settings) {} | |
| 16 | 18 |
| 17 SettingsFeature::~SettingsFeature() {} | 19 SettingsFeature::~SettingsFeature() = default; |
| 18 | 20 |
| 19 void SettingsFeature::set_outgoing_message_processor( | 21 void SettingsFeature::set_outgoing_message_processor( |
| 20 std::unique_ptr<BlimpMessageProcessor> processor) { | 22 std::unique_ptr<BlimpMessageProcessor> processor) { |
| 21 outgoing_message_processor_ = std::move(processor); | 23 outgoing_message_processor_ = std::move(processor); |
| 22 } | 24 } |
| 23 | 25 |
| 24 void SettingsFeature::SetRecordWholeDocument(bool record_whole_document) { | 26 void SettingsFeature::OnRecordWholeDocumentChanged(bool enable) { |
| 25 if (record_whole_document_ == record_whole_document) | |
| 26 return; | |
| 27 | |
| 28 record_whole_document_ = record_whole_document; | |
| 29 | |
| 30 EngineSettingsMessage* engine_settings; | 27 EngineSettingsMessage* engine_settings; |
| 31 std::unique_ptr<BlimpMessage> message = CreateBlimpMessage(&engine_settings); | 28 std::unique_ptr<BlimpMessage> message = CreateBlimpMessage(&engine_settings); |
| 32 engine_settings->set_record_whole_document(record_whole_document_); | 29 engine_settings->set_record_whole_document(enable); |
| 33 outgoing_message_processor_->ProcessMessage(std::move(message), | 30 outgoing_message_processor_->ProcessMessage(std::move(message), |
| 34 net::CompletionCallback()); | 31 net::CompletionCallback()); |
| 35 } | 32 } |
| 36 | 33 |
| 37 void SettingsFeature::SendUserAgentOSVersionInfo(const std::string& osVersion) { | 34 void SettingsFeature::SendUserAgentOSVersionInfo(const std::string& osVersion) { |
|
David Trainor- moved to gerrit
2016/10/01 03:26:34
Oops we never call this! See crbug.com/652032 tha
| |
| 38 EngineSettingsMessage* engine_settings; | 35 EngineSettingsMessage* engine_settings; |
| 39 std::unique_ptr<BlimpMessage> message = CreateBlimpMessage(&engine_settings); | 36 std::unique_ptr<BlimpMessage> message = CreateBlimpMessage(&engine_settings); |
| 40 engine_settings->set_client_os_info(osVersion); | 37 engine_settings->set_client_os_info(osVersion); |
| 41 outgoing_message_processor_->ProcessMessage(std::move(message), | 38 outgoing_message_processor_->ProcessMessage(std::move(message), |
| 42 net::CompletionCallback()); | 39 net::CompletionCallback()); |
| 43 } | 40 } |
| 44 | 41 |
| 45 void SettingsFeature::ProcessMessage(std::unique_ptr<BlimpMessage> message, | 42 void SettingsFeature::ProcessMessage(std::unique_ptr<BlimpMessage> message, |
| 46 const net::CompletionCallback& callback) { | 43 const net::CompletionCallback& callback) { |
| 47 // We don't receive any messages from the engine yet. | 44 // We don't receive any messages from the engine yet. |
| 48 NOTREACHED() << "Invalid settings message received from the engine."; | 45 NOTREACHED() << "Invalid settings message received from the engine."; |
| 49 callback.Run(net::OK); | 46 callback.Run(net::OK); |
| 50 } | 47 } |
| 51 | 48 |
| 49 void SettingsFeature::PushSettings() { | |
| 50 OnRecordWholeDocumentChanged(settings()->record_whole_document()); | |
|
David Trainor- moved to gerrit
2016/10/01 03:26:35
Can we just build one big EngineSettingsMessage an
Menglin
2016/10/03 23:08:27
Done.
| |
| 51 } | |
| 52 | |
| 52 } // namespace client | 53 } // namespace client |
| 53 } // namespace blimp | 54 } // namespace blimp |
| OLD | NEW |