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
3 // found in the LICENSE file.
5 #include "mojo/public/cpp/bindings/lib/array_internal.h"
10 ArrayDataTraits<bool>::BitRef::~BitRef() {
13 ArrayDataTraits<bool>::BitRef::BitRef(uint8_t* storage, uint8_t mask)
18 ArrayDataTraits<bool>::BitRef&
19 ArrayDataTraits<bool>::BitRef::operator=(bool value) {
28 ArrayDataTraits<bool>::BitRef&
29 ArrayDataTraits<bool>::BitRef::operator=(const BitRef& value) {
30 return (*this) = static_cast<bool>(value);
33 ArrayDataTraits<bool>::BitRef::operator bool() const {
34 return (*storage_ & mask_) != 0;
38 void ArraySerializationHelper<Handle, true>::ClearHandles(
39 const ArrayHeader* header,
40 ElementType* elements) {
41 for (uint32_t i = 0; i < header->num_elements; ++i)
42 elements[i].set_value(MOJO_HANDLE_INVALID);
46 void ArraySerializationHelper<Handle, true>::CloseHandles(
47 const ArrayHeader* header,
48 ElementType* elements) {
49 for (uint32_t i = 0; i < header->num_elements; ++i) {
50 if (elements[i].is_valid())
51 CloseRaw(elements[i]);
56 void ArraySerializationHelper<Handle, true>::EncodePointersAndHandles(
57 const ArrayHeader* header,
58 ElementType* elements,
59 std::vector<Handle>* handles) {
60 for (uint32_t i = 0; i < header->num_elements; ++i)
61 EncodeHandle(&elements[i], handles);
65 bool ArraySerializationHelper<Handle, true>::DecodePointersAndHandles(
66 const ArrayHeader* header,
67 ElementType* elements,
69 for (uint32_t i = 0; i < header->num_elements; ++i) {
70 if (!DecodeHandle(&elements[i], message->mutable_handles()))
76 } // namespace internal