blob: 0f14e79c04a0a2ea1069ceec3e0c26c1955db289 [file] [log] [blame]
// WARNING: This file is machine generated by fidlgen.
#include <fidl/test/emptystruct/llcpp/fidl.h>
#include <memory>
namespace llcpp {
namespace fidl {
namespace test {
namespace emptystruct {
namespace {
[[maybe_unused]] constexpr uint64_t kEmptyProtocol_Send_Ordinal =
2183815705502904104lu;
extern "C" const fidl_type_t
fidl_test_emptystruct_EmptyProtocolSendRequestTable;
extern "C" const fidl_type_t
fidl_test_emptystruct_EmptyProtocolSendResponseTable;
[[maybe_unused]] constexpr uint64_t kEmptyProtocol_Receive_Ordinal =
5025214662316626400lu;
extern "C" const fidl_type_t
fidl_test_emptystruct_EmptyProtocolReceiveRequestTable;
extern "C" const fidl_type_t
fidl_test_emptystruct_EmptyProtocolReceiveEventTable;
[[maybe_unused]] constexpr uint64_t kEmptyProtocol_SendAndReceive_Ordinal =
6253929606062814577lu;
extern "C" const fidl_type_t
fidl_test_emptystruct_EmptyProtocolSendAndReceiveRequestTable;
extern "C" const fidl_type_t
fidl_test_emptystruct_EmptyProtocolSendAndReceiveResponseTable;
} // namespace
#ifdef __Fuchsia__
::llcpp::fidl::test::emptystruct::EmptyProtocol::ResultOf::Send::Send(
::fidl::UnownedClientEnd<::llcpp::fidl::test::emptystruct::EmptyProtocol>
_client,
::llcpp::fidl::test::emptystruct::wire::Empty& e) {
::fidl::internal::EncodedMessageTypes<SendRequest>::OwnedByte _request(
zx_txid_t(0), e);
_request.GetOutgoingMessage().Write(_client);
status_ = _request.status();
error_ = _request.error();
}
#endif
#ifdef __Fuchsia__
::llcpp::fidl::test::emptystruct::EmptyProtocol::UnownedResultOf::Send::Send(
::fidl::UnownedClientEnd<::llcpp::fidl::test::emptystruct::EmptyProtocol>
_client,
uint8_t* _request_bytes, uint32_t _request_byte_capacity,
::llcpp::fidl::test::emptystruct::wire::Empty& e) {
::fidl::internal::EncodedMessageTypes<SendRequest>::UnownedByte _request(
_request_bytes, _request_byte_capacity, 0, e);
_request.GetOutgoingMessage().Write(_client);
status_ = _request.status();
error_ = _request.error();
}
#endif
#ifdef __Fuchsia__
::llcpp::fidl::test::emptystruct::EmptyProtocol::ResultOf::SendAndReceive::
SendAndReceive(::fidl::UnownedClientEnd<
::llcpp::fidl::test::emptystruct::EmptyProtocol>
_client,
::llcpp::fidl::test::emptystruct::wire::Empty& e) {
::fidl::internal::EncodedMessageTypes<SendAndReceiveRequest>::OwnedByte
_request(zx_txid_t(0), e);
_request.GetOutgoingMessage().Call<SendAndReceiveResponse>(
_client, bytes_,
SendAndReceiveResponse::PrimarySize +
SendAndReceiveResponse::MaxOutOfLine);
status_ = _request.status();
error_ = _request.error();
}
::llcpp::fidl::test::emptystruct::EmptyProtocol::ResultOf::SendAndReceive::
SendAndReceive(::fidl::UnownedClientEnd<
::llcpp::fidl::test::emptystruct::EmptyProtocol>
_client,
::llcpp::fidl::test::emptystruct::wire::Empty& e,
zx_time_t _deadline) {
::fidl::internal::EncodedMessageTypes<SendAndReceiveRequest>::OwnedByte
_request(zx_txid_t(0), e);
_request.GetOutgoingMessage().Call<SendAndReceiveResponse>(
_client, bytes_,
SendAndReceiveResponse::PrimarySize +
SendAndReceiveResponse::MaxOutOfLine,
_deadline);
status_ = _request.status();
error_ = _request.error();
}
#endif
#ifdef __Fuchsia__
::llcpp::fidl::test::emptystruct::EmptyProtocol::UnownedResultOf::
SendAndReceive::SendAndReceive(
::fidl::UnownedClientEnd<
::llcpp::fidl::test::emptystruct::EmptyProtocol>
_client,
uint8_t* _request_bytes, uint32_t _request_byte_capacity,
::llcpp::fidl::test::emptystruct::wire::Empty& e,
uint8_t* _response_bytes, uint32_t _response_byte_capacity)
: bytes_(_response_bytes) {
::fidl::internal::EncodedMessageTypes<SendAndReceiveRequest>::UnownedByte
_request(_request_bytes, _request_byte_capacity, 0, e);
_request.GetOutgoingMessage().Call<SendAndReceiveResponse>(
_client, _response_bytes, _response_byte_capacity);
status_ = _request.status();
error_ = _request.error();
}
#endif
#ifdef __Fuchsia__
::fidl::Result EmptyProtocol::ClientImpl::Send(
::llcpp::fidl::test::emptystruct::wire::Empty e) {
if (auto _channel = ::fidl::internal::ClientBase::GetChannel()) {
auto _res =
ResultOf::Send(::fidl::UnownedClientEnd<
::llcpp::fidl::test::emptystruct::EmptyProtocol>(
_channel->handle()),
e);
return ::fidl::Result(_res.status(), _res.error());
}
return ::fidl::Result(ZX_ERR_CANCELED, ::fidl::kErrorChannelUnbound);
}
#endif
#ifdef __Fuchsia__
::fidl::Result EmptyProtocol::ClientImpl::Send(
::fidl::BufferSpan _request_buffer,
::llcpp::fidl::test::emptystruct::wire::Empty e) {
if (auto _channel = ::fidl::internal::ClientBase::GetChannel()) {
auto _res = UnownedResultOf::Send(
::fidl::UnownedClientEnd<
::llcpp::fidl::test::emptystruct::EmptyProtocol>(
_channel->handle()),
_request_buffer.data, _request_buffer.capacity, e);
return ::fidl::Result(_res.status(), _res.error());
}
return ::fidl::Result(ZX_ERR_CANCELED, ::fidl::kErrorChannelUnbound);
}
#endif
#ifdef __Fuchsia__
::llcpp::fidl::test::emptystruct::EmptyProtocol::ResultOf::SendAndReceive
EmptyProtocol::ClientImpl::SendAndReceive_Sync(
::llcpp::fidl::test::emptystruct::wire::Empty e) {
if (auto _channel = ::fidl::internal::ClientBase::GetChannel()) {
return ResultOf::SendAndReceive(
::fidl::UnownedClientEnd<
::llcpp::fidl::test::emptystruct::EmptyProtocol>(
_channel->handle()),
e);
}
return ::llcpp::fidl::test::emptystruct::EmptyProtocol::ResultOf::
SendAndReceive(
::fidl::Result(ZX_ERR_CANCELED, ::fidl::kErrorChannelUnbound));
}
#endif
#ifdef __Fuchsia__
::llcpp::fidl::test::emptystruct::EmptyProtocol::UnownedResultOf::SendAndReceive
EmptyProtocol::ClientImpl::SendAndReceive_Sync(
::fidl::BufferSpan _request_buffer,
::llcpp::fidl::test::emptystruct::wire::Empty e,
::fidl::BufferSpan _response_buffer) {
if (auto _channel = ::fidl::internal::ClientBase::GetChannel()) {
return UnownedResultOf::SendAndReceive(
::fidl::UnownedClientEnd<
::llcpp::fidl::test::emptystruct::EmptyProtocol>(
_channel->handle()),
_request_buffer.data, _request_buffer.capacity, e,
_response_buffer.data, _response_buffer.capacity);
}
return ::llcpp::fidl::test::emptystruct::EmptyProtocol::UnownedResultOf::
SendAndReceive(
::fidl::Result(ZX_ERR_CANCELED, ::fidl::kErrorChannelUnbound));
}
#endif
#ifdef __Fuchsia__
::llcpp::fidl::test::emptystruct::EmptyProtocol::SendAndReceiveResponseContext::
SendAndReceiveResponseContext()
: ::fidl::internal::ResponseContext(SendAndReceiveResponse::Type,
kEmptyProtocol_SendAndReceive_Ordinal) {
}
void ::llcpp::fidl::test::emptystruct::EmptyProtocol::
SendAndReceiveResponseContext::OnReply(uint8_t* reply) {
OnReply(reinterpret_cast<SendAndReceiveResponse*>(reply));
}
::fidl::Result EmptyProtocol::ClientImpl::SendAndReceive(
::llcpp::fidl::test::emptystruct::wire::Empty e,
::fit::callback<void(SendAndReceiveResponse* response)> _cb) {
class ResponseContext final : public SendAndReceiveResponseContext {
public:
ResponseContext(::fit::callback<void(SendAndReceiveResponse* response)> cb)
: cb_(std::move(cb)) {}
void OnReply(SendAndReceiveResponse* response) override {
cb_(response);
delete this;
}
void OnError() override { delete this; }
private:
::fit::callback<void(SendAndReceiveResponse* response)> cb_;
};
auto* _context = new ResponseContext(std::move(_cb));
::fidl::internal::ClientBase::PrepareAsyncTxn(_context);
SendAndReceiveRequest::OwnedEncodedMessage _request(_context->Txid(), e);
return _request.GetOutgoingMessage().Write(this, _context);
}
::fidl::Result EmptyProtocol::ClientImpl::SendAndReceive(
::fidl::BufferSpan _request_buffer,
::llcpp::fidl::test::emptystruct::wire::Empty e,
SendAndReceiveResponseContext* _context) {
::fidl::internal::ClientBase::PrepareAsyncTxn(_context);
SendAndReceiveRequest::UnownedEncodedMessage _request(
_request_buffer.data, _request_buffer.capacity, _context->Txid(), e);
return _request.GetOutgoingMessage().Write(this, _context);
}
#endif
#ifdef __Fuchsia__
std::optional<::fidl::UnbindInfo> EmptyProtocol::ClientImpl::DispatchEvent(
fidl_incoming_msg_t* msg) {
if (event_handler_ != nullptr) {
fidl_message_header_t* hdr =
reinterpret_cast<fidl_message_header_t*>(msg->bytes);
switch (hdr->ordinal) {
case kEmptyProtocol_Receive_Ordinal: {
const char* error_message;
zx_status_t status =
fidl_decode_etc(ReceiveResponse::Type, msg->bytes, msg->num_bytes,
msg->handles, msg->num_handles, &error_message);
if (status != ZX_OK) {
return ::fidl::UnbindInfo{::fidl::UnbindInfo::kDecodeError, status};
}
event_handler_->Receive(reinterpret_cast<ReceiveResponse*>(msg->bytes));
return std::nullopt;
}
default:
break;
}
}
FidlHandleInfoCloseMany(msg->handles, msg->num_handles);
return ::fidl::UnbindInfo{::fidl::UnbindInfo::kUnexpectedMessage,
ZX_ERR_NOT_SUPPORTED};
}
#endif
::fidl::Result EmptyProtocol::SyncEventHandler::HandleOneEvent(
::fidl::UnownedClientEnd<::llcpp::fidl::test::emptystruct::EmptyProtocol>
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::Result(status, ::fidl::kErrorWaitOneFailed);
}
constexpr uint32_t kReadAllocSize = ([]() constexpr {
uint32_t x = 0;
if (::fidl::internal::ClampedMessageSize<
ReceiveResponse, ::fidl::MessageDirection::kReceiving>() >= x) {
x = ::fidl::internal::ClampedMessageSize<
ReceiveResponse, ::fidl::MessageDirection::kReceiving>();
}
return x;
})();
constexpr uint32_t kHandleAllocSize = ([]() constexpr {
uint32_t x = 0;
if (ReceiveResponse::MaxNumHandles >= x) {
x = ReceiveResponse::MaxNumHandles;
}
if (x > ZX_CHANNEL_MAX_MSG_HANDLES) {
x = ZX_CHANNEL_MAX_MSG_HANDLES;
}
return x;
})();
::fidl::internal::ByteStorage<kReadAllocSize> read_storage;
uint8_t* read_bytes = read_storage.data();
zx_handle_info_t read_handles[kHandleAllocSize];
uint32_t actual_bytes;
uint32_t actual_handles;
status = client_end.channel()->read_etc(
ZX_CHANNEL_READ_MAY_DISCARD, read_bytes, read_handles, kReadAllocSize,
kHandleAllocSize, &actual_bytes, &actual_handles);
if (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::Result(Unknown(), nullptr);
}
if (status != ZX_OK) {
return ::fidl::Result(status, ::fidl::kErrorReadFailed);
}
if (actual_bytes < sizeof(fidl_message_header_t)) {
FidlHandleInfoCloseMany(read_handles, actual_handles);
return ::fidl::Result(ZX_ERR_INVALID_ARGS, ::fidl::kErrorInvalidHeader);
}
fidl_message_header_t* hdr =
reinterpret_cast<fidl_message_header_t*>(read_bytes);
status = fidl_validate_txn_header(hdr);
if (status != ZX_OK) {
FidlHandleInfoCloseMany(read_handles, actual_handles);
return ::fidl::Result(status, ::fidl::kErrorInvalidHeader);
}
switch (hdr->ordinal) {
case kEmptyProtocol_Receive_Ordinal: {
const char* error_message;
zx_status_t status =
fidl_decode_etc(ReceiveResponse::Type, read_bytes, actual_bytes,
read_handles, actual_handles, &error_message);
if (status != ZX_OK) {
return ::fidl::Result(status, error_message);
}
Receive(reinterpret_cast<ReceiveResponse*>(read_bytes));
return ::fidl::Result(ZX_OK, nullptr);
}
default: {
FidlHandleInfoCloseMany(read_handles, actual_handles);
return ::fidl::Result(Unknown(), nullptr);
}
}
}
#ifdef __Fuchsia__
namespace methods {
void EmptyProtocolDispatchSend(void* interface, void* bytes,
::fidl::Transaction* txn) {
auto message = reinterpret_cast<
::llcpp::fidl::test::emptystruct::EmptyProtocol::SendRequest*>(bytes);
::llcpp::fidl::test::emptystruct::EmptyProtocol::Interface::SendCompleter::
Sync completer(txn);
reinterpret_cast<::llcpp::fidl::test::emptystruct::EmptyProtocol::Interface*>(
interface)
->Send(std::move(message->e), completer);
}
void EmptyProtocolDispatchSendAndReceive(void* interface, void* bytes,
::fidl::Transaction* txn) {
auto message = reinterpret_cast<
::llcpp::fidl::test::emptystruct::EmptyProtocol::SendAndReceiveRequest*>(
bytes);
::llcpp::fidl::test::emptystruct::EmptyProtocol::Interface::
SendAndReceiveCompleter::Sync completer(txn);
reinterpret_cast<::llcpp::fidl::test::emptystruct::EmptyProtocol::Interface*>(
interface)
->SendAndReceive(std::move(message->e), completer);
}
} // namespace methods
namespace entries {
::fidl::internal::MethodEntry EmptyProtocol[] = {
{kEmptyProtocol_Send_Ordinal,
::llcpp::fidl::test::emptystruct::EmptyProtocol::SendRequest::Type,
methods::EmptyProtocolDispatchSend},
{kEmptyProtocol_SendAndReceive_Ordinal,
::llcpp::fidl::test::emptystruct::EmptyProtocol::SendAndReceiveRequest::
Type,
methods::EmptyProtocolDispatchSendAndReceive},
};
} // namespace entries
::fidl::DispatchResult EmptyProtocol::TryDispatch(Interface* impl,
fidl_incoming_msg_t* msg,
::fidl::Transaction* txn) {
return ::fidl::internal::TryDispatch(
impl, msg, txn, entries::EmptyProtocol,
entries::EmptyProtocol + sizeof(entries::EmptyProtocol) /
sizeof(::fidl::internal::MethodEntry));
}
#endif
#ifdef __Fuchsia__
::fidl::DispatchResult EmptyProtocol::Dispatch(Interface* impl,
fidl_incoming_msg_t* msg,
::fidl::Transaction* txn) {
::fidl::DispatchResult dispatch_result = TryDispatch(impl, msg, txn);
if (dispatch_result == ::fidl::DispatchResult::kNotFound) {
FidlHandleInfoCloseMany(msg->handles, msg->num_handles);
txn->InternalError(
{::fidl::UnbindInfo::kUnexpectedMessage, ZX_ERR_NOT_SUPPORTED});
}
return dispatch_result;
}
::fidl::DispatchResult EmptyProtocol::Interface::dispatch_message(
fidl_incoming_msg_t* msg, ::fidl::Transaction* txn) {
return EmptyProtocol::Dispatch(this, msg, txn);
}
#endif
#ifdef __Fuchsia__
::fidl::Result EmptyProtocol::Interface::SendAndReceiveCompleterBase::Reply(
::llcpp::fidl::test::emptystruct::wire::Empty e) {
::fidl::internal::EncodedMessageTypes<SendAndReceiveResponse>::OwnedByte
_response{e};
return CompleterBase::SendReply(&_response.GetOutgoingMessage());
}
#endif
#ifdef __Fuchsia__
::fidl::Result EmptyProtocol::Interface::SendAndReceiveCompleterBase::Reply(
::fidl::BufferSpan _buffer,
::llcpp::fidl::test::emptystruct::wire::Empty e) {
SendAndReceiveResponse::UnownedEncodedMessage _response(_buffer.data,
_buffer.capacity, e);
return CompleterBase::SendReply(&_response.GetOutgoingMessage());
}
#endif
void ::llcpp::fidl::test::emptystruct::EmptyProtocol::SendRequest::_InitHeader(
zx_txid_t _txid) {
fidl_init_txn_header(&_hdr, _txid, kEmptyProtocol_Send_Ordinal);
}
void ::llcpp::fidl::test::emptystruct::EmptyProtocol::ReceiveResponse::
_InitHeader() {
fidl_init_txn_header(&_hdr, 0, kEmptyProtocol_Receive_Ordinal);
}
void ::llcpp::fidl::test::emptystruct::EmptyProtocol::SendAndReceiveRequest::
_InitHeader(zx_txid_t _txid) {
fidl_init_txn_header(&_hdr, _txid, kEmptyProtocol_SendAndReceive_Ordinal);
}
void ::llcpp::fidl::test::emptystruct::EmptyProtocol::SendAndReceiveResponse::
_InitHeader() {
fidl_init_txn_header(&_hdr, 0, kEmptyProtocol_SendAndReceive_Ordinal);
}
#ifdef __Fuchsia__
zx_status_t EmptyProtocol::EventSender::Receive(
::llcpp::fidl::test::emptystruct::wire::Empty e) const {
::fidl::internal::EncodedMessageTypes<ReceiveResponse>::OwnedByte _response{
e};
_response.Write(server_end_);
return _response.status();
}
zx_status_t EmptyProtocol::EventSender::Receive(
::fidl::BufferSpan _buffer,
::llcpp::fidl::test::emptystruct::wire::Empty e) const {
::fidl::internal::EncodedMessageTypes<ReceiveResponse>::UnownedByte _response(
_buffer.data, _buffer.capacity, e);
_response.Write(server_end_);
return _response.status();
}
#endif
} // namespace emptystruct
} // namespace test
} // namespace fidl
} // namespace llcpp