blob: e3d48a81acb2f1d66acff52db8e8b85679edf24a [file] [log] [blame]
// WARNING: This file is machine generated by fidlgen.
#include <fidl/test.service/cpp/wire_messaging.h>
#include <memory>
namespace test_service {
[[maybe_unused]] constexpr uint64_t kSecondProtocol_MethodOnSecond_Ordinal =
8121179205110225988lu;
[[maybe_unused]] constexpr ::fidl::MessageDynamicFlags
kSecondProtocol_MethodOnSecond_DynamicFlags =
::fidl::MessageDynamicFlags::kStrictMethod;
#ifdef __Fuchsia__
} // namespace test_service
::fidl::WireResult<::test_service::SecondProtocol::MethodOnSecond>::WireResult(
::fidl::UnownedClientEnd<::test_service::SecondProtocol> client,
::fidl::internal::TransactionalRequest<
::test_service::SecondProtocol::MethodOnSecond>* request) {
FIDL_INTERNAL_DISABLE_AUTO_VAR_INIT
::fidl::unstable::OwnedEncodedMessage<
::fidl::internal::TransactionalRequest<
::test_service::SecondProtocol::MethodOnSecond>,
::fidl::internal::ChannelTransport>
request_message(::fidl::internal::AllowUnownedInputRef{}, request);
auto& outgoing = request_message.GetOutgoingMessage();
outgoing.Write(client.handle());
SetStatus(outgoing);
}
namespace test_service {
#endif // __Fuchsia__
#ifdef __Fuchsia__
} // namespace test_service
::fidl::WireUnownedResult<::test_service::SecondProtocol::MethodOnSecond>::
WireUnownedResult(
::fidl::UnownedClientEnd<::test_service::SecondProtocol> client_end,
::fidl::internal::AnyBufferAllocator& allocator,
::fidl::internal::TransactionalRequest<
::test_service::SecondProtocol::MethodOnSecond>* request) {
constexpr uint32_t buffer_size = ::fidl::SyncClientMethodBufferSizeInChannel<
::test_service::SecondProtocol::MethodOnSecond>();
::fitx::result<::fidl::Error, ::fidl::BufferSpan> allocation =
allocator.TryAllocate(buffer_size);
if (!allocation.is_ok()) {
::fidl::Status::operator=(allocation.error_value());
return;
}
uint8_t* buffer = allocation->data;
uint32_t request_byte_capacity = buffer_size;
uint8_t* request_bytes = buffer;
::fidl::unstable::UnownedEncodedMessage<
::fidl::internal::TransactionalRequest<
::test_service::SecondProtocol::MethodOnSecond>>
request_message(request_bytes, request_byte_capacity, request);
auto& outgoing = request_message.GetOutgoingMessage();
outgoing.Write(client_end.handle());
::fidl::Status::operator=(outgoing);
}
namespace test_service {
#endif // __Fuchsia__
} // namespace test_service
#ifdef __Fuchsia__
::fidl::Status fidl::internal::WireWeakOnewayClientImpl<
::test_service::SecondProtocol>::MethodOnSecond() {
FIDL_INTERNAL_DISABLE_AUTO_VAR_INIT
::fidl::internal::TransactionalRequest<
::test_service::SecondProtocol::MethodOnSecond>
_request_object{};
::fidl::unstable::OwnedEncodedMessage<
::fidl::internal::TransactionalRequest<
::test_service::SecondProtocol::MethodOnSecond>,
::fidl::internal::ChannelTransport>
_request_message(::fidl::internal::AllowUnownedInputRef{},
&_request_object);
return _client_base()->SendOneWay(_request_message.GetOutgoingMessage());
}
::fidl::Status fidl::internal::WireWeakOnewayBufferClientImpl<
::test_service::SecondProtocol>::MethodOnSecond() {
constexpr uint32_t _buffer_size =
::fidl::AsyncClientMethodBufferSizeInChannel<
::test_service::SecondProtocol::MethodOnSecond>();
::fitx::result<::fidl::Error, ::fidl::BufferSpan> _allocation =
_allocator().TryAllocate(_buffer_size);
if (!_allocation.is_ok()) {
return _allocation.error_value();
}
::fidl::internal::TransactionalRequest<
::test_service::SecondProtocol::MethodOnSecond>
_request{};
::fidl::unstable::UnownedEncodedMessage<
::fidl::internal::TransactionalRequest<
::test_service::SecondProtocol::MethodOnSecond>>
_request_message(_allocation->data, _buffer_size, &_request);
return _client_base()->SendOneWay(_request_message.GetOutgoingMessage());
}
#endif // __Fuchsia__
#ifdef __Fuchsia__
::fidl::Status
fidl::WireSyncEventHandler<::test_service::SecondProtocol>::HandleOneEvent(
::fidl::UnownedClientEnd<::test_service::SecondProtocol> client_end) {
zx_status_t status = client_end.channel()->wait_one(
ZX_CHANNEL_READABLE | ZX_CHANNEL_PEER_CLOSED, ::zx::time::infinite(),
nullptr);
if (status != ZX_OK) {
return ::fidl::Status::TransportError(
status, ::fidl::internal::kErrorWaitOneFailed);
}
constexpr uint32_t kHandleAllocSize = ([]() constexpr {
uint32_t x = 0;
if (x > ZX_CHANNEL_MAX_MSG_HANDLES) {
x = ZX_CHANNEL_MAX_MSG_HANDLES;
}
return x;
})();
static_assert(kHandleAllocSize <= ZX_CHANNEL_MAX_MSG_HANDLES);
::fidl::internal::InlineMessageBuffer<16> read_storage;
std::array<zx_handle_t, kHandleAllocSize> read_handles;
// TODO(fxbug.dev/85734) Remove this channel-specific allocation.
std::array<fidl_channel_handle_metadata_t, kHandleAllocSize>
read_handle_metadata;
::fidl::IncomingMessage msg = ::fidl::MessageRead(
zx::unowned_channel(client_end.handle()), read_storage.view(),
read_handles.data(), read_handle_metadata.data(), kHandleAllocSize,
ReadOptions{.discardable = true});
if (msg.status() == ZX_ERR_BUFFER_TOO_SMALL) {
// Message size is unexpectedly larger than calculated.
// This can only be due to a newer version of the protocol defining a new
// event, whose size exceeds the maximum of known events in the current
// protocol.
return ::fidl::Status::UnexpectedMessage(
ZX_ERR_BUFFER_TOO_SMALL,
::fidl::internal::kErrorSyncEventBufferTooSmall);
}
if (!msg.ok()) {
return msg;
}
fidl_message_header_t* hdr = msg.header();
switch (hdr->ordinal) {
default: {
return ::fidl::Status::UnknownOrdinal();
}
}
}
std::optional<::fidl::UnbindInfo> fidl::internal::
WireEventDispatcher<::test_service::SecondProtocol>::DispatchEvent(
::fidl::IncomingMessage& msg,
::fidl::internal::IncomingTransportContext transport_context) {
switch (msg.header()->ordinal) {
default:
break;
}
return ::fidl::UnbindInfo::UnknownOrdinal();
}
#endif // __Fuchsia__
#ifdef __Fuchsia__
constexpr ::fidl::internal::MethodEntry fidl::internal::WireServerDispatcher<
::test_service::SecondProtocol>::entries_[] = {
{
::test_service::kSecondProtocol_MethodOnSecond_Ordinal,
[](void* interface, ::fidl::IncomingMessage&& msg,
internal::IncomingTransportContext transport_context,
::fidl::Transaction* txn) {
::fidl::WireRequest<::test_service::SecondProtocol::MethodOnSecond>
empty_request;
auto* primary = &empty_request;
::fidl::internal::WireCompleter<
::test_service::SecondProtocol::MethodOnSecond>::Sync
completer(txn);
reinterpret_cast<::fidl::WireServer<::test_service::SecondProtocol>*>(
interface)
->MethodOnSecond(primary, completer);
return ZX_OK;
},
},
};
const ::fidl::internal::MethodEntry* fidl::internal::WireServerDispatcher<
::test_service::SecondProtocol>::entries_end_ = &entries_[1];
::fidl::DispatchResult fidl::internal::
WireServerDispatcher<::test_service::SecondProtocol>::TryDispatch(
::fidl::WireServer<::test_service::SecondProtocol>* impl,
::fidl::IncomingMessage& msg,
internal::IncomingTransportContext transport_context,
::fidl::Transaction* txn) {
return ::fidl::internal::TryDispatch(impl, msg, std::move(transport_context),
txn, entries_, entries_end_);
}
void fidl::internal::WireServerDispatcher<::test_service::SecondProtocol>::
Dispatch(::fidl::WireServer<::test_service::SecondProtocol>* impl,
::fidl::IncomingMessage&& msg,
internal::IncomingTransportContext transport_context,
::fidl::Transaction* txn) {
::fidl::internal::Dispatch(impl, msg, std::move(transport_context), txn,
entries_, entries_end_);
}
void fidl::WireServer<::test_service::SecondProtocol>::dispatch_message(
::fidl::IncomingMessage&& msg, ::fidl::Transaction* txn,
::fidl::internal::IncomingTransportContext transport_context) {
::fidl::internal::WireServerDispatcher<
::test_service::SecondProtocol>::Dispatch(this, std::move(msg),
std::move(transport_context),
txn);
}
#endif // __Fuchsia__
void ::fidl::internal::TransactionalRequest<
::test_service::SecondProtocol::MethodOnSecond>::_InitHeader() {
::fidl::InitTxnHeader(
&header, 0, ::test_service::kSecondProtocol_MethodOnSecond_Ordinal,
::test_service::kSecondProtocol_MethodOnSecond_DynamicFlags);
}
#ifdef __Fuchsia__
#endif // __Fuchsia__
namespace test_service {
[[maybe_unused]] constexpr uint64_t kFirstProtocol_MethodOnFirst_Ordinal =
6352548393671797041lu;
[[maybe_unused]] constexpr ::fidl::MessageDynamicFlags
kFirstProtocol_MethodOnFirst_DynamicFlags =
::fidl::MessageDynamicFlags::kStrictMethod;
#ifdef __Fuchsia__
} // namespace test_service
::fidl::WireResult<::test_service::FirstProtocol::MethodOnFirst>::WireResult(
::fidl::UnownedClientEnd<::test_service::FirstProtocol> client,
::fidl::internal::TransactionalRequest<
::test_service::FirstProtocol::MethodOnFirst>* request) {
FIDL_INTERNAL_DISABLE_AUTO_VAR_INIT
::fidl::unstable::OwnedEncodedMessage<
::fidl::internal::TransactionalRequest<
::test_service::FirstProtocol::MethodOnFirst>,
::fidl::internal::ChannelTransport>
request_message(::fidl::internal::AllowUnownedInputRef{}, request);
auto& outgoing = request_message.GetOutgoingMessage();
outgoing.Write(client.handle());
SetStatus(outgoing);
}
namespace test_service {
#endif // __Fuchsia__
#ifdef __Fuchsia__
} // namespace test_service
::fidl::WireUnownedResult<::test_service::FirstProtocol::MethodOnFirst>::
WireUnownedResult(
::fidl::UnownedClientEnd<::test_service::FirstProtocol> client_end,
::fidl::internal::AnyBufferAllocator& allocator,
::fidl::internal::TransactionalRequest<
::test_service::FirstProtocol::MethodOnFirst>* request) {
constexpr uint32_t buffer_size = ::fidl::SyncClientMethodBufferSizeInChannel<
::test_service::FirstProtocol::MethodOnFirst>();
::fitx::result<::fidl::Error, ::fidl::BufferSpan> allocation =
allocator.TryAllocate(buffer_size);
if (!allocation.is_ok()) {
::fidl::Status::operator=(allocation.error_value());
return;
}
uint8_t* buffer = allocation->data;
uint32_t request_byte_capacity = buffer_size;
uint8_t* request_bytes = buffer;
::fidl::unstable::UnownedEncodedMessage<
::fidl::internal::TransactionalRequest<
::test_service::FirstProtocol::MethodOnFirst>>
request_message(request_bytes, request_byte_capacity, request);
auto& outgoing = request_message.GetOutgoingMessage();
outgoing.Write(client_end.handle());
::fidl::Status::operator=(outgoing);
}
namespace test_service {
#endif // __Fuchsia__
} // namespace test_service
#ifdef __Fuchsia__
::fidl::Status fidl::internal::WireWeakOnewayClientImpl<
::test_service::FirstProtocol>::MethodOnFirst() {
FIDL_INTERNAL_DISABLE_AUTO_VAR_INIT
::fidl::internal::TransactionalRequest<
::test_service::FirstProtocol::MethodOnFirst>
_request_object{};
::fidl::unstable::OwnedEncodedMessage<
::fidl::internal::TransactionalRequest<
::test_service::FirstProtocol::MethodOnFirst>,
::fidl::internal::ChannelTransport>
_request_message(::fidl::internal::AllowUnownedInputRef{},
&_request_object);
return _client_base()->SendOneWay(_request_message.GetOutgoingMessage());
}
::fidl::Status fidl::internal::WireWeakOnewayBufferClientImpl<
::test_service::FirstProtocol>::MethodOnFirst() {
constexpr uint32_t _buffer_size =
::fidl::AsyncClientMethodBufferSizeInChannel<
::test_service::FirstProtocol::MethodOnFirst>();
::fitx::result<::fidl::Error, ::fidl::BufferSpan> _allocation =
_allocator().TryAllocate(_buffer_size);
if (!_allocation.is_ok()) {
return _allocation.error_value();
}
::fidl::internal::TransactionalRequest<
::test_service::FirstProtocol::MethodOnFirst>
_request{};
::fidl::unstable::UnownedEncodedMessage<
::fidl::internal::TransactionalRequest<
::test_service::FirstProtocol::MethodOnFirst>>
_request_message(_allocation->data, _buffer_size, &_request);
return _client_base()->SendOneWay(_request_message.GetOutgoingMessage());
}
#endif // __Fuchsia__
#ifdef __Fuchsia__
::fidl::Status
fidl::WireSyncEventHandler<::test_service::FirstProtocol>::HandleOneEvent(
::fidl::UnownedClientEnd<::test_service::FirstProtocol> client_end) {
zx_status_t status = client_end.channel()->wait_one(
ZX_CHANNEL_READABLE | ZX_CHANNEL_PEER_CLOSED, ::zx::time::infinite(),
nullptr);
if (status != ZX_OK) {
return ::fidl::Status::TransportError(
status, ::fidl::internal::kErrorWaitOneFailed);
}
constexpr uint32_t kHandleAllocSize = ([]() constexpr {
uint32_t x = 0;
if (x > ZX_CHANNEL_MAX_MSG_HANDLES) {
x = ZX_CHANNEL_MAX_MSG_HANDLES;
}
return x;
})();
static_assert(kHandleAllocSize <= ZX_CHANNEL_MAX_MSG_HANDLES);
::fidl::internal::InlineMessageBuffer<16> read_storage;
std::array<zx_handle_t, kHandleAllocSize> read_handles;
// TODO(fxbug.dev/85734) Remove this channel-specific allocation.
std::array<fidl_channel_handle_metadata_t, kHandleAllocSize>
read_handle_metadata;
::fidl::IncomingMessage msg = ::fidl::MessageRead(
zx::unowned_channel(client_end.handle()), read_storage.view(),
read_handles.data(), read_handle_metadata.data(), kHandleAllocSize,
ReadOptions{.discardable = true});
if (msg.status() == ZX_ERR_BUFFER_TOO_SMALL) {
// Message size is unexpectedly larger than calculated.
// This can only be due to a newer version of the protocol defining a new
// event, whose size exceeds the maximum of known events in the current
// protocol.
return ::fidl::Status::UnexpectedMessage(
ZX_ERR_BUFFER_TOO_SMALL,
::fidl::internal::kErrorSyncEventBufferTooSmall);
}
if (!msg.ok()) {
return msg;
}
fidl_message_header_t* hdr = msg.header();
switch (hdr->ordinal) {
default: {
return ::fidl::Status::UnknownOrdinal();
}
}
}
std::optional<::fidl::UnbindInfo> fidl::internal::
WireEventDispatcher<::test_service::FirstProtocol>::DispatchEvent(
::fidl::IncomingMessage& msg,
::fidl::internal::IncomingTransportContext transport_context) {
switch (msg.header()->ordinal) {
default:
break;
}
return ::fidl::UnbindInfo::UnknownOrdinal();
}
#endif // __Fuchsia__
#ifdef __Fuchsia__
constexpr ::fidl::internal::MethodEntry fidl::internal::WireServerDispatcher<
::test_service::FirstProtocol>::entries_[] = {
{
::test_service::kFirstProtocol_MethodOnFirst_Ordinal,
[](void* interface, ::fidl::IncomingMessage&& msg,
internal::IncomingTransportContext transport_context,
::fidl::Transaction* txn) {
::fidl::WireRequest<::test_service::FirstProtocol::MethodOnFirst>
empty_request;
auto* primary = &empty_request;
::fidl::internal::WireCompleter<
::test_service::FirstProtocol::MethodOnFirst>::Sync
completer(txn);
reinterpret_cast<::fidl::WireServer<::test_service::FirstProtocol>*>(
interface)
->MethodOnFirst(primary, completer);
return ZX_OK;
},
},
};
const ::fidl::internal::MethodEntry* fidl::internal::WireServerDispatcher<
::test_service::FirstProtocol>::entries_end_ = &entries_[1];
::fidl::DispatchResult fidl::internal::
WireServerDispatcher<::test_service::FirstProtocol>::TryDispatch(
::fidl::WireServer<::test_service::FirstProtocol>* impl,
::fidl::IncomingMessage& msg,
internal::IncomingTransportContext transport_context,
::fidl::Transaction* txn) {
return ::fidl::internal::TryDispatch(impl, msg, std::move(transport_context),
txn, entries_, entries_end_);
}
void fidl::internal::WireServerDispatcher<::test_service::FirstProtocol>::
Dispatch(::fidl::WireServer<::test_service::FirstProtocol>* impl,
::fidl::IncomingMessage&& msg,
internal::IncomingTransportContext transport_context,
::fidl::Transaction* txn) {
::fidl::internal::Dispatch(impl, msg, std::move(transport_context), txn,
entries_, entries_end_);
}
void fidl::WireServer<::test_service::FirstProtocol>::dispatch_message(
::fidl::IncomingMessage&& msg, ::fidl::Transaction* txn,
::fidl::internal::IncomingTransportContext transport_context) {
::fidl::internal::WireServerDispatcher<
::test_service::FirstProtocol>::Dispatch(this, std::move(msg),
std::move(transport_context),
txn);
}
#endif // __Fuchsia__
void ::fidl::internal::TransactionalRequest<
::test_service::FirstProtocol::MethodOnFirst>::_InitHeader() {
::fidl::InitTxnHeader(
&header, 0, ::test_service::kFirstProtocol_MethodOnFirst_Ordinal,
::test_service::kFirstProtocol_MethodOnFirst_DynamicFlags);
}
#ifdef __Fuchsia__
#endif // __Fuchsia__