| // WARNING: This file is machine generated by fidlgen. |
| |
| #include <fidl/test/handles/cpp/natural_types.h> |
| |
| #include "lib/fidl/cpp/internal/natural_types_implementation.h" |
| |
| // |
| // Domain objects definitions (i.e. "natural types" in unified bindings) |
| // |
| namespace fidl { |
| namespace test { |
| namespace handles { |
| |
| #ifdef __Fuchsia__ |
| |
| extern "C" const fidl_type_t fidl_test_handles_HandlesTable; |
| const fidl_type_t* Handles::FidlType = &fidl_test_handles_HandlesTable; |
| |
| void Handles::Encode( |
| ::fidl::Encoder* _encoder, size_t _offset, |
| cpp17::optional<::fidl::HandleInformation> maybe_handle_info) { |
| if (::fidl::IsMemcpyCompatible<Handles>::value) { |
| memcpy(_encoder->template GetPtr<Handles>(_offset), this, sizeof(Handles)); |
| } else { |
| ::fidl::Encode(_encoder, &plain_handle, _offset + 0, |
| ::fidl::HandleInformation{ |
| .object_type = ZX_OBJ_TYPE_NONE, |
| .rights = 0x80000000, |
| }); |
| |
| ::fidl::Encode(_encoder, &bti_handle, _offset + 4, |
| ::fidl::HandleInformation{ |
| .object_type = ZX_OBJ_TYPE_BTI, |
| .rights = 0x80000000, |
| }); |
| |
| ::fidl::Encode(_encoder, &channel_handle, _offset + 8, |
| ::fidl::HandleInformation{ |
| .object_type = ZX_OBJ_TYPE_CHANNEL, |
| .rights = 0x80000000, |
| }); |
| |
| ::fidl::Encode(_encoder, &clock_handle, _offset + 12, |
| ::fidl::HandleInformation{ |
| .object_type = ZX_OBJ_TYPE_CLOCK, |
| .rights = 0x80000000, |
| }); |
| |
| ::fidl::Encode(_encoder, &debuglog_handle, _offset + 16, |
| ::fidl::HandleInformation{ |
| .object_type = ZX_OBJ_TYPE_LOG, |
| .rights = 0x80000000, |
| }); |
| |
| ::fidl::Encode(_encoder, &event_handle, _offset + 20, |
| ::fidl::HandleInformation{ |
| .object_type = ZX_OBJ_TYPE_EVENT, |
| .rights = 0x80000000, |
| }); |
| |
| ::fidl::Encode(_encoder, &eventpair_handle, _offset + 24, |
| ::fidl::HandleInformation{ |
| .object_type = ZX_OBJ_TYPE_EVENTPAIR, |
| .rights = 0x80000000, |
| }); |
| |
| ::fidl::Encode(_encoder, &exception_handle, _offset + 28, |
| ::fidl::HandleInformation{ |
| .object_type = ZX_OBJ_TYPE_EXCEPTION, |
| .rights = 0x80000000, |
| }); |
| |
| ::fidl::Encode(_encoder, &fifo_handle, _offset + 32, |
| ::fidl::HandleInformation{ |
| .object_type = ZX_OBJ_TYPE_FIFO, |
| .rights = 0x80000000, |
| }); |
| |
| ::fidl::Encode(_encoder, &guest_handle, _offset + 36, |
| ::fidl::HandleInformation{ |
| .object_type = ZX_OBJ_TYPE_GUEST, |
| .rights = 0x80000000, |
| }); |
| |
| ::fidl::Encode(_encoder, &interrupt_handle, _offset + 40, |
| ::fidl::HandleInformation{ |
| .object_type = ZX_OBJ_TYPE_INTERRUPT, |
| .rights = 0x80000000, |
| }); |
| |
| ::fidl::Encode(_encoder, &iommu_handle, _offset + 44, |
| ::fidl::HandleInformation{ |
| .object_type = ZX_OBJ_TYPE_IOMMU, |
| .rights = 0x80000000, |
| }); |
| |
| ::fidl::Encode(_encoder, &job_handle, _offset + 48, |
| ::fidl::HandleInformation{ |
| .object_type = ZX_OBJ_TYPE_JOB, |
| .rights = 0x80000000, |
| }); |
| |
| ::fidl::Encode(_encoder, &pager_handle, _offset + 52, |
| ::fidl::HandleInformation{ |
| .object_type = ZX_OBJ_TYPE_PAGER, |
| .rights = 0x80000000, |
| }); |
| |
| ::fidl::Encode(_encoder, &pcidevice_handle, _offset + 56, |
| ::fidl::HandleInformation{ |
| .object_type = ZX_OBJ_TYPE_PCI_DEVICE, |
| .rights = 0x80000000, |
| }); |
| |
| ::fidl::Encode(_encoder, &pmt_handle, _offset + 60, |
| ::fidl::HandleInformation{ |
| .object_type = ZX_OBJ_TYPE_PMT, |
| .rights = 0x80000000, |
| }); |
| |
| ::fidl::Encode(_encoder, &port_handle, _offset + 64, |
| ::fidl::HandleInformation{ |
| .object_type = ZX_OBJ_TYPE_PORT, |
| .rights = 0x80000000, |
| }); |
| |
| ::fidl::Encode(_encoder, &process_handle, _offset + 68, |
| ::fidl::HandleInformation{ |
| .object_type = ZX_OBJ_TYPE_PROCESS, |
| .rights = 0x80000000, |
| }); |
| |
| ::fidl::Encode(_encoder, &profile_handle, _offset + 72, |
| ::fidl::HandleInformation{ |
| .object_type = ZX_OBJ_TYPE_PROFILE, |
| .rights = 0x80000000, |
| }); |
| |
| ::fidl::Encode(_encoder, &resource_handle, _offset + 76, |
| ::fidl::HandleInformation{ |
| .object_type = ZX_OBJ_TYPE_RESOURCE, |
| .rights = 0x80000000, |
| }); |
| |
| ::fidl::Encode(_encoder, &socket_handle, _offset + 80, |
| ::fidl::HandleInformation{ |
| .object_type = ZX_OBJ_TYPE_SOCKET, |
| .rights = 0x80000000, |
| }); |
| |
| ::fidl::Encode(_encoder, &suspendtoken_handle, _offset + 84, |
| ::fidl::HandleInformation{ |
| .object_type = ZX_OBJ_TYPE_SUSPEND_TOKEN, |
| .rights = 0x80000000, |
| }); |
| |
| ::fidl::Encode(_encoder, &thread_handle, _offset + 88, |
| ::fidl::HandleInformation{ |
| .object_type = ZX_OBJ_TYPE_THREAD, |
| .rights = 0x80000000, |
| }); |
| |
| ::fidl::Encode(_encoder, &timer_handle, _offset + 92, |
| ::fidl::HandleInformation{ |
| .object_type = ZX_OBJ_TYPE_TIMER, |
| .rights = 0x80000000, |
| }); |
| |
| ::fidl::Encode(_encoder, &vcpu_handle, _offset + 96, |
| ::fidl::HandleInformation{ |
| .object_type = ZX_OBJ_TYPE_VCPU, |
| .rights = 0x80000000, |
| }); |
| |
| ::fidl::Encode(_encoder, &vmar_handle, _offset + 100, |
| ::fidl::HandleInformation{ |
| .object_type = ZX_OBJ_TYPE_VMAR, |
| .rights = 0x80000000, |
| }); |
| |
| ::fidl::Encode(_encoder, &vmo_handle, _offset + 104, |
| ::fidl::HandleInformation{ |
| .object_type = ZX_OBJ_TYPE_VMO, |
| .rights = 0x80000000, |
| }); |
| |
| ::fidl::Encode(_encoder, &rights_handle, _offset + 108, |
| ::fidl::HandleInformation{ |
| .object_type = ZX_OBJ_TYPE_VMO, |
| .rights = 0x5, |
| }); |
| |
| ::fidl::Encode(_encoder, &aliased_plain_handle_field, _offset + 112, |
| ::fidl::HandleInformation{ |
| .object_type = ZX_OBJ_TYPE_NONE, |
| .rights = 0x80000000, |
| }); |
| |
| ::fidl::Encode(_encoder, &aliased_subtype_handle_field, _offset + 116, |
| ::fidl::HandleInformation{ |
| .object_type = ZX_OBJ_TYPE_VMO, |
| .rights = 0x80000000, |
| }); |
| |
| ::fidl::Encode(_encoder, &aliased_rights_handle_field, _offset + 120, |
| ::fidl::HandleInformation{ |
| .object_type = ZX_OBJ_TYPE_VMO, |
| .rights = 0x1, |
| }); |
| ::fidl::Encode(_encoder, &some_protocol, _offset + 124); |
| ::fidl::Encode(_encoder, &request_some_protocol, _offset + 128); |
| } |
| } |
| |
| void Handles::Decode(::fidl::Decoder* _decoder, Handles* _value, |
| size_t _offset) { |
| if (::fidl::IsMemcpyCompatible<Handles>::value) { |
| memcpy(_value, _decoder->template GetPtr<Handles>(_offset), |
| sizeof(Handles)); |
| } else { |
| ::fidl::Decode(_decoder, &_value->plain_handle, _offset + 0); |
| ::fidl::Decode(_decoder, &_value->bti_handle, _offset + 4); |
| ::fidl::Decode(_decoder, &_value->channel_handle, _offset + 8); |
| ::fidl::Decode(_decoder, &_value->clock_handle, _offset + 12); |
| ::fidl::Decode(_decoder, &_value->debuglog_handle, _offset + 16); |
| ::fidl::Decode(_decoder, &_value->event_handle, _offset + 20); |
| ::fidl::Decode(_decoder, &_value->eventpair_handle, _offset + 24); |
| ::fidl::Decode(_decoder, &_value->exception_handle, _offset + 28); |
| ::fidl::Decode(_decoder, &_value->fifo_handle, _offset + 32); |
| ::fidl::Decode(_decoder, &_value->guest_handle, _offset + 36); |
| ::fidl::Decode(_decoder, &_value->interrupt_handle, _offset + 40); |
| ::fidl::Decode(_decoder, &_value->iommu_handle, _offset + 44); |
| ::fidl::Decode(_decoder, &_value->job_handle, _offset + 48); |
| ::fidl::Decode(_decoder, &_value->pager_handle, _offset + 52); |
| ::fidl::Decode(_decoder, &_value->pcidevice_handle, _offset + 56); |
| ::fidl::Decode(_decoder, &_value->pmt_handle, _offset + 60); |
| ::fidl::Decode(_decoder, &_value->port_handle, _offset + 64); |
| ::fidl::Decode(_decoder, &_value->process_handle, _offset + 68); |
| ::fidl::Decode(_decoder, &_value->profile_handle, _offset + 72); |
| ::fidl::Decode(_decoder, &_value->resource_handle, _offset + 76); |
| ::fidl::Decode(_decoder, &_value->socket_handle, _offset + 80); |
| ::fidl::Decode(_decoder, &_value->suspendtoken_handle, _offset + 84); |
| ::fidl::Decode(_decoder, &_value->thread_handle, _offset + 88); |
| ::fidl::Decode(_decoder, &_value->timer_handle, _offset + 92); |
| ::fidl::Decode(_decoder, &_value->vcpu_handle, _offset + 96); |
| ::fidl::Decode(_decoder, &_value->vmar_handle, _offset + 100); |
| ::fidl::Decode(_decoder, &_value->vmo_handle, _offset + 104); |
| ::fidl::Decode(_decoder, &_value->rights_handle, _offset + 108); |
| ::fidl::Decode(_decoder, &_value->aliased_plain_handle_field, |
| _offset + 112); |
| ::fidl::Decode(_decoder, &_value->aliased_subtype_handle_field, |
| _offset + 116); |
| ::fidl::Decode(_decoder, &_value->aliased_rights_handle_field, |
| _offset + 120); |
| ::fidl::Decode(_decoder, &_value->some_protocol, _offset + 124); |
| ::fidl::Decode(_decoder, &_value->request_some_protocol, _offset + 128); |
| } |
| } |
| |
| zx_status_t Handles::Clone(Handles* _result) const { |
| zx_status_t _status = ::fidl::Clone(plain_handle, &_result->plain_handle); |
| if (_status != ZX_OK) return _status; |
| _status = ::fidl::Clone(bti_handle, &_result->bti_handle); |
| if (_status != ZX_OK) return _status; |
| _status = ::fidl::Clone(channel_handle, &_result->channel_handle); |
| if (_status != ZX_OK) return _status; |
| _status = ::fidl::Clone(clock_handle, &_result->clock_handle); |
| if (_status != ZX_OK) return _status; |
| _status = ::fidl::Clone(debuglog_handle, &_result->debuglog_handle); |
| if (_status != ZX_OK) return _status; |
| _status = ::fidl::Clone(event_handle, &_result->event_handle); |
| if (_status != ZX_OK) return _status; |
| _status = ::fidl::Clone(eventpair_handle, &_result->eventpair_handle); |
| if (_status != ZX_OK) return _status; |
| _status = ::fidl::Clone(exception_handle, &_result->exception_handle); |
| if (_status != ZX_OK) return _status; |
| _status = ::fidl::Clone(fifo_handle, &_result->fifo_handle); |
| if (_status != ZX_OK) return _status; |
| _status = ::fidl::Clone(guest_handle, &_result->guest_handle); |
| if (_status != ZX_OK) return _status; |
| _status = ::fidl::Clone(interrupt_handle, &_result->interrupt_handle); |
| if (_status != ZX_OK) return _status; |
| _status = ::fidl::Clone(iommu_handle, &_result->iommu_handle); |
| if (_status != ZX_OK) return _status; |
| _status = ::fidl::Clone(job_handle, &_result->job_handle); |
| if (_status != ZX_OK) return _status; |
| _status = ::fidl::Clone(pager_handle, &_result->pager_handle); |
| if (_status != ZX_OK) return _status; |
| _status = ::fidl::Clone(pcidevice_handle, &_result->pcidevice_handle); |
| if (_status != ZX_OK) return _status; |
| _status = ::fidl::Clone(pmt_handle, &_result->pmt_handle); |
| if (_status != ZX_OK) return _status; |
| _status = ::fidl::Clone(port_handle, &_result->port_handle); |
| if (_status != ZX_OK) return _status; |
| _status = ::fidl::Clone(process_handle, &_result->process_handle); |
| if (_status != ZX_OK) return _status; |
| _status = ::fidl::Clone(profile_handle, &_result->profile_handle); |
| if (_status != ZX_OK) return _status; |
| _status = ::fidl::Clone(resource_handle, &_result->resource_handle); |
| if (_status != ZX_OK) return _status; |
| _status = ::fidl::Clone(socket_handle, &_result->socket_handle); |
| if (_status != ZX_OK) return _status; |
| _status = ::fidl::Clone(suspendtoken_handle, &_result->suspendtoken_handle); |
| if (_status != ZX_OK) return _status; |
| _status = ::fidl::Clone(thread_handle, &_result->thread_handle); |
| if (_status != ZX_OK) return _status; |
| _status = ::fidl::Clone(timer_handle, &_result->timer_handle); |
| if (_status != ZX_OK) return _status; |
| _status = ::fidl::Clone(vcpu_handle, &_result->vcpu_handle); |
| if (_status != ZX_OK) return _status; |
| _status = ::fidl::Clone(vmar_handle, &_result->vmar_handle); |
| if (_status != ZX_OK) return _status; |
| _status = ::fidl::Clone(vmo_handle, &_result->vmo_handle); |
| if (_status != ZX_OK) return _status; |
| _status = ::fidl::Clone(rights_handle, &_result->rights_handle); |
| if (_status != ZX_OK) return _status; |
| _status = ::fidl::Clone(aliased_plain_handle_field, |
| &_result->aliased_plain_handle_field); |
| if (_status != ZX_OK) return _status; |
| _status = ::fidl::Clone(aliased_subtype_handle_field, |
| &_result->aliased_subtype_handle_field); |
| if (_status != ZX_OK) return _status; |
| _status = ::fidl::Clone(aliased_rights_handle_field, |
| &_result->aliased_rights_handle_field); |
| if (_status != ZX_OK) return _status; |
| _status = ::fidl::Clone(some_protocol, &_result->some_protocol); |
| if (_status != ZX_OK) return _status; |
| _status = |
| ::fidl::Clone(request_some_protocol, &_result->request_some_protocol); |
| if (_status != ZX_OK) return _status; |
| return ZX_OK; |
| } |
| #endif // __Fuchsia__ |
| |
| } // namespace handles |
| } // namespace test |
| } // namespace fidl |