| OLD | NEW |
| 1 // Copyright 2013 The Chromium Authors. All rights reserved. | 1 // Copyright 2013 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/message_builder.h" | 5 #include "mojo/public/cpp/bindings/lib/message_builder.h" |
| 6 | 6 |
| 7 #include "mojo/public/cpp/bindings/lib/bindings_serialization.h" | 7 #include "mojo/public/cpp/bindings/lib/bindings_serialization.h" |
| 8 #include "mojo/public/cpp/bindings/message.h" | 8 #include "mojo/public/cpp/bindings/message.h" |
| 9 | 9 |
| 10 namespace mojo { | 10 namespace mojo { |
| 11 namespace internal { | 11 namespace internal { |
| 12 | 12 |
| 13 template <typename Header> | 13 template <typename Header> |
| 14 void Allocate(Buffer* buf, Header** header) { | 14 void Allocate(Buffer* buf, Header** header) { |
| 15 *header = static_cast<Header*>(buf->Allocate(sizeof(Header))); | 15 *header = static_cast<Header*>(buf->Allocate(sizeof(Header))); |
| 16 (*header)->num_bytes = sizeof(Header); | 16 (*header)->num_bytes = sizeof(Header); |
| 17 } | 17 } |
| 18 | 18 |
| 19 MessageBuilder::MessageBuilder(uint32_t name, size_t payload_size) { | 19 MessageBuilder::MessageBuilder(uint32_t name, size_t payload_size) { |
| 20 Initialize(sizeof(MessageHeader) + payload_size); | 20 InitializeMessage(sizeof(MessageHeader) + payload_size); |
| 21 | 21 |
| 22 MessageHeader* header; | 22 MessageHeader* header; |
| 23 Allocate(&buf_, &header); | 23 Allocate(message_.buffer(), &header); |
| 24 header->version = 0; | 24 header->version = 0; |
| 25 header->name = name; | 25 header->name = name; |
| 26 } | 26 } |
| 27 | 27 |
| 28 MessageBuilder::~MessageBuilder() { | 28 MessageBuilder::~MessageBuilder() { |
| 29 } | 29 } |
| 30 | 30 |
| 31 MessageBuilder::MessageBuilder() {} | 31 MessageBuilder::MessageBuilder() {} |
| 32 | 32 |
| 33 void MessageBuilder::Initialize(size_t size) { | 33 void MessageBuilder::InitializeMessage(size_t size) { |
| 34 message_.AllocData(static_cast<uint32_t>(Align(size))); | 34 message_.Initialize(static_cast<uint32_t>(Align(size)), |
| 35 buf_.Initialize(message_.mutable_data(), message_.data_num_bytes()); | 35 true /* zero_initialized */); |
| 36 } | 36 } |
| 37 | 37 |
| 38 MessageWithRequestIDBuilder::MessageWithRequestIDBuilder(uint32_t name, | 38 MessageWithRequestIDBuilder::MessageWithRequestIDBuilder(uint32_t name, |
| 39 size_t payload_size, | 39 size_t payload_size, |
| 40 uint32_t flags, | 40 uint32_t flags, |
| 41 uint64_t request_id) { | 41 uint64_t request_id) { |
| 42 Initialize(sizeof(MessageHeaderWithRequestID) + payload_size); | 42 InitializeMessage(sizeof(MessageHeaderWithRequestID) + payload_size); |
| 43 |
| 43 MessageHeaderWithRequestID* header; | 44 MessageHeaderWithRequestID* header; |
| 44 Allocate(&buf_, &header); | 45 Allocate(message_.buffer(), &header); |
| 45 header->version = 1; | 46 header->version = 1; |
| 46 header->name = name; | 47 header->name = name; |
| 47 header->flags = flags; | 48 header->flags = flags; |
| 48 header->request_id = request_id; | 49 header->request_id = request_id; |
| 49 } | 50 } |
| 50 | 51 |
| 51 } // namespace internal | 52 } // namespace internal |
| 52 } // namespace mojo | 53 } // namespace mojo |
| OLD | NEW |