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

Side by Side Diff: mojo/public/cpp/bindings/lib/control_message_handler.cc

Issue 2277853003: Use unions for interface control messages. (Closed)
Patch Set: Created 4 years, 3 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 unified diff | Download patch
OLDNEW
1 // Copyright 2015 The Chromium Authors. All rights reserved. 1 // Copyright 2015 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 "mojo/public/cpp/bindings/lib/control_message_handler.h" 5 #include "mojo/public/cpp/bindings/lib/control_message_handler.h"
6 6
7 #include <stddef.h> 7 #include <stddef.h>
8 #include <stdint.h> 8 #include <stdint.h>
9 #include <utility> 9 #include <utility>
10 10
11 #include "base/logging.h" 11 #include "base/logging.h"
12 #include "mojo/public/cpp/bindings/lib/message_builder.h" 12 #include "mojo/public/cpp/bindings/lib/message_builder.h"
13 #include "mojo/public/cpp/bindings/lib/serialization.h" 13 #include "mojo/public/cpp/bindings/lib/serialization.h"
14 #include "mojo/public/interfaces/bindings/interface_control_messages.mojom.h" 14 #include "mojo/public/interfaces/bindings/interface_control_messages.mojom.h"
15 15
16 namespace mojo { 16 namespace mojo {
17 namespace internal { 17 namespace internal {
18 18
19 // static 19 // static
20 bool ControlMessageHandler::IsControlMessage(const Message* message) { 20 bool ControlMessageHandler::IsControlMessage(const Message* message) {
21 return message->header()->name == kRunMessageId || 21 return message->header()->name == interface_control::kRunMessageId ||
22 message->header()->name == kRunOrClosePipeMessageId; 22 message->header()->name == interface_control::kRunOrClosePipeMessageId;
23 } 23 }
24 24
25 ControlMessageHandler::ControlMessageHandler(uint32_t interface_version) 25 ControlMessageHandler::ControlMessageHandler(uint32_t interface_version)
26 : interface_version_(interface_version) { 26 : interface_version_(interface_version) {
27 } 27 }
28 28
29 ControlMessageHandler::~ControlMessageHandler() { 29 ControlMessageHandler::~ControlMessageHandler() {
30 } 30 }
31 31
32 bool ControlMessageHandler::Accept(Message* message) { 32 bool ControlMessageHandler::Accept(Message* message) {
33 if (message->header()->name == kRunOrClosePipeMessageId) 33 if (message->header()->name == interface_control::kRunOrClosePipeMessageId)
34 return RunOrClosePipe(message); 34 return RunOrClosePipe(message);
35 35
36 NOTREACHED(); 36 NOTREACHED();
37 return false; 37 return false;
38 } 38 }
39 39
40 bool ControlMessageHandler::AcceptWithResponder( 40 bool ControlMessageHandler::AcceptWithResponder(
41 Message* message, 41 Message* message,
42 MessageReceiverWithStatus* responder) { 42 MessageReceiverWithStatus* responder) {
43 if (message->header()->name == kRunMessageId) 43 if (message->header()->name == interface_control::kRunMessageId)
44 return Run(message, responder); 44 return Run(message, responder);
45 45
46 NOTREACHED(); 46 NOTREACHED();
47 return false; 47 return false;
48 } 48 }
49 49
50 bool ControlMessageHandler::Run(Message* message, 50 bool ControlMessageHandler::Run(Message* message,
51 MessageReceiverWithStatus* responder) { 51 MessageReceiverWithStatus* responder) {
52 RunResponseMessageParamsPtr response_params_ptr( 52 interface_control::internal::RunMessageParams_Data* params =
53 RunResponseMessageParams::New()); 53 reinterpret_cast<interface_control::internal::RunMessageParams_Data*>(
54 response_params_ptr->reserved0 = 16u; 54 message->mutable_payload());
55 response_params_ptr->reserved1 = 0u; 55 interface_control::RunMessageParamsPtr params_ptr;
56 response_params_ptr->query_version_result = QueryVersionResult::New(); 56 Deserialize<interface_control::RunMessageParamsDataView>(params, &params_ptr,
57 response_params_ptr->query_version_result->version = interface_version_; 57 &context_);
58 auto& input = *params_ptr->input;
59 auto output = interface_control::RunOutput::New();
60 if (input.is_query_version()) {
61 output->set_query_version_result(
62 interface_control::QueryVersionResult::New());
63 output->get_query_version_result()->version = interface_version_;
64 } else {
65 output = nullptr;
dcheng 2016/08/26 17:38:32 I personally might find this slightly easier to re
Sam McNally 2016/08/26 17:47:26 Done.
66 }
58 67
59 size_t size = PrepareToSerialize<RunResponseMessageParamsDataView>( 68 auto response_params_ptr = interface_control::RunResponseMessageParams::New();
60 response_params_ptr, &context_); 69 response_params_ptr->output = std::move(output);
61 ResponseMessageBuilder builder(kRunMessageId, size, message->request_id()); 70 size_t size =
71 PrepareToSerialize<interface_control::RunResponseMessageParamsDataView>(
72 response_params_ptr, &context_);
73 ResponseMessageBuilder builder(interface_control::kRunMessageId, size,
74 message->request_id());
62 75
63 RunResponseMessageParams_Data* response_params = nullptr; 76 interface_control::internal::RunResponseMessageParams_Data* response_params =
64 Serialize<RunResponseMessageParamsDataView>( 77 nullptr;
78 Serialize<interface_control::RunResponseMessageParamsDataView>(
65 response_params_ptr, builder.buffer(), &response_params, &context_); 79 response_params_ptr, builder.buffer(), &response_params, &context_);
66 bool ok = responder->Accept(builder.message()); 80 bool ok = responder->Accept(builder.message());
67 ALLOW_UNUSED_LOCAL(ok); 81 ALLOW_UNUSED_LOCAL(ok);
68 delete responder; 82 delete responder;
69 83
70 return true; 84 return true;
71 } 85 }
72 86
73 bool ControlMessageHandler::RunOrClosePipe(Message* message) { 87 bool ControlMessageHandler::RunOrClosePipe(Message* message) {
74 RunOrClosePipeMessageParams_Data* params = 88 interface_control::internal::RunOrClosePipeMessageParams_Data* params =
75 reinterpret_cast<RunOrClosePipeMessageParams_Data*>( 89 reinterpret_cast<
90 interface_control::internal::RunOrClosePipeMessageParams_Data*>(
76 message->mutable_payload()); 91 message->mutable_payload());
77 RunOrClosePipeMessageParamsPtr params_ptr; 92 interface_control::RunOrClosePipeMessageParamsPtr params_ptr;
78 Deserialize<RunOrClosePipeMessageParamsDataView>(params, &params_ptr, 93 Deserialize<interface_control::RunOrClosePipeMessageParamsDataView>(
79 &context_); 94 params, &params_ptr, &context_);
95 auto& input = *params_ptr->input;
96 if (input.is_require_version())
97 return interface_version_ >= input.get_require_version()->version;
80 98
81 return interface_version_ >= params_ptr->require_version->version; 99 return false;
82 } 100 }
83 101
84 } // namespace internal 102 } // namespace internal
85 } // namespace mojo 103 } // namespace mojo
OLDNEW

Powered by Google App Engine
This is Rietveld 408576698