blob: 72ad80b3183b1c52e16664d54e17d8834322db3b [file] [log] [blame]
// WARNING: This file is machine generated by fidlgen.
#pragma once
#include <lib/fidl/internal.h>
#include <lib/fidl/llcpp/array.h>
#include <lib/fidl/llcpp/buffer_allocator.h>
#include <lib/fidl/llcpp/buffer_then_heap_allocator.h>
#include <lib/fidl/llcpp/coding.h>
#include <lib/fidl/llcpp/envelope.h>
#include <lib/fidl/llcpp/errors.h>
#include <lib/fidl/llcpp/memory.h>
#include <lib/fidl/llcpp/message.h>
#include <lib/fidl/llcpp/message_storage.h>
#include <lib/fidl/llcpp/string_view.h>
#include <lib/fidl/llcpp/tracking_ptr.h>
#include <lib/fidl/llcpp/traits.h>
#include <lib/fidl/llcpp/vector_view.h>
#include <lib/fit/function.h>
#include <lib/fit/optional.h>
#include <variant>
#ifdef __Fuchsia__
#include <lib/fidl/llcpp/client.h>
#include <lib/fidl/llcpp/connect_service.h>
#include <lib/fidl/llcpp/result.h>
#include <lib/fidl/llcpp/server.h>
#include <lib/fidl/llcpp/service_handler_interface.h>
#include <lib/fidl/llcpp/sync_call.h>
#include <lib/fidl/llcpp/transaction.h>
#include <lib/fidl/txn_header.h>
#include <lib/zx/channel.h>
#include <lib/zx/handle.h>
#include <lib/zx/socket.h>
#endif // __Fuchsia__
#include <zircon/fidl.h>
namespace llcpp {
namespace fidl {
namespace test {
namespace protocols {
enum class obj_type : uint32_t {
NONE = 0u,
SOCKET = 14u,
};
struct WithErrorSyntax_ResponseAsStruct_Response;
class WithErrorSyntax_ResponseAsStruct_Result;
struct WithErrorSyntax_ErrorAsPrimitive_Response;
class WithErrorSyntax_ErrorAsPrimitive_Result;
struct WithErrorSyntax_ErrorAsEnum_Response;
class Transitional;
class ChannelProtocol;
class WithAndWithoutRequestResponse;
enum class ErrorEnun : uint32_t {
ERR_FOO = 1u,
ERR_BAR = 2u,
};
class WithErrorSyntax_ErrorAsEnum_Result;
class WithErrorSyntax;
extern "C" const fidl_type_t
fidl_test_protocols_WithErrorSyntax_ResponseAsStruct_ResultTable;
class WithErrorSyntax_ResponseAsStruct_Result {
public:
WithErrorSyntax_ResponseAsStruct_Result()
: ordinal_(Ordinal::Invalid), envelope_{} {}
WithErrorSyntax_ResponseAsStruct_Result(
WithErrorSyntax_ResponseAsStruct_Result&&) = default;
WithErrorSyntax_ResponseAsStruct_Result& operator=(
WithErrorSyntax_ResponseAsStruct_Result&&) = default;
~WithErrorSyntax_ResponseAsStruct_Result() { reset_ptr(nullptr); }
enum class Tag : fidl_xunion_tag_t {
kResponse = 1, // 0x1
kErr = 2, // 0x2
};
bool has_invalid_tag() const { return ordinal_ == Ordinal::Invalid; }
bool is_response() const { return ordinal_ == Ordinal::kResponse; }
static WithErrorSyntax_ResponseAsStruct_Result WithResponse(
::fidl::tracking_ptr<::llcpp::fidl::test::protocols::
WithErrorSyntax_ResponseAsStruct_Response>&&
val) {
WithErrorSyntax_ResponseAsStruct_Result result;
result.set_response(std::move(val));
return result;
}
void set_response(::fidl::tracking_ptr<
::llcpp::fidl::test::protocols::
WithErrorSyntax_ResponseAsStruct_Response>&& elem) {
ordinal_ = Ordinal::kResponse;
reset_ptr(static_cast<::fidl::tracking_ptr<void>>(std::move(elem)));
}
::llcpp::fidl::test::protocols::WithErrorSyntax_ResponseAsStruct_Response&
mutable_response() {
ZX_ASSERT(ordinal_ == Ordinal::kResponse);
return *static_cast<::llcpp::fidl::test::protocols::
WithErrorSyntax_ResponseAsStruct_Response*>(
envelope_.data.get());
}
const ::llcpp::fidl::test::protocols::
WithErrorSyntax_ResponseAsStruct_Response&
response() const {
ZX_ASSERT(ordinal_ == Ordinal::kResponse);
return *static_cast<::llcpp::fidl::test::protocols::
WithErrorSyntax_ResponseAsStruct_Response*>(
envelope_.data.get());
}
bool is_err() const { return ordinal_ == Ordinal::kErr; }
static WithErrorSyntax_ResponseAsStruct_Result WithErr(
::fidl::tracking_ptr<uint32_t>&& val) {
WithErrorSyntax_ResponseAsStruct_Result result;
result.set_err(std::move(val));
return result;
}
void set_err(::fidl::tracking_ptr<uint32_t>&& elem) {
ordinal_ = Ordinal::kErr;
reset_ptr(static_cast<::fidl::tracking_ptr<void>>(std::move(elem)));
}
uint32_t& mutable_err() {
ZX_ASSERT(ordinal_ == Ordinal::kErr);
return *static_cast<uint32_t*>(envelope_.data.get());
}
const uint32_t& err() const {
ZX_ASSERT(ordinal_ == Ordinal::kErr);
return *static_cast<uint32_t*>(envelope_.data.get());
}
Tag which() const {
ZX_ASSERT(!has_invalid_tag());
return static_cast<Tag>(ordinal_);
}
static constexpr const fidl_type_t* Type =
&fidl_test_protocols_WithErrorSyntax_ResponseAsStruct_ResultTable;
static constexpr uint32_t MaxNumHandles = 0;
static constexpr uint32_t PrimarySize = 24;
[[maybe_unused]] static constexpr uint32_t MaxOutOfLine = 24;
static constexpr bool HasPointer = true;
static constexpr bool IsResource = false;
void _CloseHandles();
private:
enum class Ordinal : fidl_xunion_tag_t {
Invalid = 0,
kResponse = 1, // 0x1
kErr = 2, // 0x2
};
void reset_ptr(::fidl::tracking_ptr<void>&& new_ptr) {
// To clear the existing value, std::move it and let it go out of scope.
switch (static_cast<fidl_xunion_tag_t>(ordinal_)) {
case 1: {
::fidl::tracking_ptr<::llcpp::fidl::test::protocols::
WithErrorSyntax_ResponseAsStruct_Response>
to_destroy = static_cast<::fidl::tracking_ptr<
::llcpp::fidl::test::protocols::
WithErrorSyntax_ResponseAsStruct_Response>>(
std::move(envelope_.data));
break;
}
case 2: {
::fidl::tracking_ptr<uint32_t> to_destroy =
static_cast<::fidl::tracking_ptr<uint32_t>>(
std::move(envelope_.data));
break;
}
}
envelope_.data = std::move(new_ptr);
}
static void SizeAndOffsetAssertionHelper();
Ordinal ordinal_;
FIDL_ALIGNDECL
::fidl::Envelope<void> envelope_;
};
extern "C" const fidl_type_t
fidl_test_protocols_WithErrorSyntax_ErrorAsPrimitive_ResultTable;
class WithErrorSyntax_ErrorAsPrimitive_Result {
public:
WithErrorSyntax_ErrorAsPrimitive_Result()
: ordinal_(Ordinal::Invalid), envelope_{} {}
WithErrorSyntax_ErrorAsPrimitive_Result(
WithErrorSyntax_ErrorAsPrimitive_Result&&) = default;
WithErrorSyntax_ErrorAsPrimitive_Result& operator=(
WithErrorSyntax_ErrorAsPrimitive_Result&&) = default;
~WithErrorSyntax_ErrorAsPrimitive_Result() { reset_ptr(nullptr); }
enum class Tag : fidl_xunion_tag_t {
kResponse = 1, // 0x1
kErr = 2, // 0x2
};
bool has_invalid_tag() const { return ordinal_ == Ordinal::Invalid; }
bool is_response() const { return ordinal_ == Ordinal::kResponse; }
static WithErrorSyntax_ErrorAsPrimitive_Result WithResponse(
::fidl::tracking_ptr<::llcpp::fidl::test::protocols::
WithErrorSyntax_ErrorAsPrimitive_Response>&&
val) {
WithErrorSyntax_ErrorAsPrimitive_Result result;
result.set_response(std::move(val));
return result;
}
void set_response(::fidl::tracking_ptr<
::llcpp::fidl::test::protocols::
WithErrorSyntax_ErrorAsPrimitive_Response>&& elem) {
ordinal_ = Ordinal::kResponse;
reset_ptr(static_cast<::fidl::tracking_ptr<void>>(std::move(elem)));
}
::llcpp::fidl::test::protocols::WithErrorSyntax_ErrorAsPrimitive_Response&
mutable_response() {
ZX_ASSERT(ordinal_ == Ordinal::kResponse);
return *static_cast<::llcpp::fidl::test::protocols::
WithErrorSyntax_ErrorAsPrimitive_Response*>(
envelope_.data.get());
}
const ::llcpp::fidl::test::protocols::
WithErrorSyntax_ErrorAsPrimitive_Response&
response() const {
ZX_ASSERT(ordinal_ == Ordinal::kResponse);
return *static_cast<::llcpp::fidl::test::protocols::
WithErrorSyntax_ErrorAsPrimitive_Response*>(
envelope_.data.get());
}
bool is_err() const { return ordinal_ == Ordinal::kErr; }
static WithErrorSyntax_ErrorAsPrimitive_Result WithErr(
::fidl::tracking_ptr<uint32_t>&& val) {
WithErrorSyntax_ErrorAsPrimitive_Result result;
result.set_err(std::move(val));
return result;
}
void set_err(::fidl::tracking_ptr<uint32_t>&& elem) {
ordinal_ = Ordinal::kErr;
reset_ptr(static_cast<::fidl::tracking_ptr<void>>(std::move(elem)));
}
uint32_t& mutable_err() {
ZX_ASSERT(ordinal_ == Ordinal::kErr);
return *static_cast<uint32_t*>(envelope_.data.get());
}
const uint32_t& err() const {
ZX_ASSERT(ordinal_ == Ordinal::kErr);
return *static_cast<uint32_t*>(envelope_.data.get());
}
Tag which() const {
ZX_ASSERT(!has_invalid_tag());
return static_cast<Tag>(ordinal_);
}
static constexpr const fidl_type_t* Type =
&fidl_test_protocols_WithErrorSyntax_ErrorAsPrimitive_ResultTable;
static constexpr uint32_t MaxNumHandles = 0;
static constexpr uint32_t PrimarySize = 24;
[[maybe_unused]] static constexpr uint32_t MaxOutOfLine = 8;
static constexpr bool HasPointer = true;
static constexpr bool IsResource = false;
void _CloseHandles();
private:
enum class Ordinal : fidl_xunion_tag_t {
Invalid = 0,
kResponse = 1, // 0x1
kErr = 2, // 0x2
};
void reset_ptr(::fidl::tracking_ptr<void>&& new_ptr) {
// To clear the existing value, std::move it and let it go out of scope.
switch (static_cast<fidl_xunion_tag_t>(ordinal_)) {
case 1: {
::fidl::tracking_ptr<::llcpp::fidl::test::protocols::
WithErrorSyntax_ErrorAsPrimitive_Response>
to_destroy = static_cast<::fidl::tracking_ptr<
::llcpp::fidl::test::protocols::
WithErrorSyntax_ErrorAsPrimitive_Response>>(
std::move(envelope_.data));
break;
}
case 2: {
::fidl::tracking_ptr<uint32_t> to_destroy =
static_cast<::fidl::tracking_ptr<uint32_t>>(
std::move(envelope_.data));
break;
}
}
envelope_.data = std::move(new_ptr);
}
static void SizeAndOffsetAssertionHelper();
Ordinal ordinal_;
FIDL_ALIGNDECL
::fidl::Envelope<void> envelope_;
};
extern "C" const fidl_type_t
fidl_test_protocols_WithErrorSyntax_ErrorAsEnum_ResultTable;
class WithErrorSyntax_ErrorAsEnum_Result {
public:
WithErrorSyntax_ErrorAsEnum_Result()
: ordinal_(Ordinal::Invalid), envelope_{} {}
WithErrorSyntax_ErrorAsEnum_Result(WithErrorSyntax_ErrorAsEnum_Result&&) =
default;
WithErrorSyntax_ErrorAsEnum_Result& operator=(
WithErrorSyntax_ErrorAsEnum_Result&&) = default;
~WithErrorSyntax_ErrorAsEnum_Result() { reset_ptr(nullptr); }
enum class Tag : fidl_xunion_tag_t {
kResponse = 1, // 0x1
kErr = 2, // 0x2
};
bool has_invalid_tag() const { return ordinal_ == Ordinal::Invalid; }
bool is_response() const { return ordinal_ == Ordinal::kResponse; }
static WithErrorSyntax_ErrorAsEnum_Result WithResponse(
::fidl::tracking_ptr<::llcpp::fidl::test::protocols::
WithErrorSyntax_ErrorAsEnum_Response>&& val) {
WithErrorSyntax_ErrorAsEnum_Result result;
result.set_response(std::move(val));
return result;
}
void set_response(
::fidl::tracking_ptr<::llcpp::fidl::test::protocols::
WithErrorSyntax_ErrorAsEnum_Response>&& elem) {
ordinal_ = Ordinal::kResponse;
reset_ptr(static_cast<::fidl::tracking_ptr<void>>(std::move(elem)));
}
::llcpp::fidl::test::protocols::WithErrorSyntax_ErrorAsEnum_Response&
mutable_response() {
ZX_ASSERT(ordinal_ == Ordinal::kResponse);
return *static_cast<
::llcpp::fidl::test::protocols::WithErrorSyntax_ErrorAsEnum_Response*>(
envelope_.data.get());
}
const ::llcpp::fidl::test::protocols::WithErrorSyntax_ErrorAsEnum_Response&
response() const {
ZX_ASSERT(ordinal_ == Ordinal::kResponse);
return *static_cast<
::llcpp::fidl::test::protocols::WithErrorSyntax_ErrorAsEnum_Response*>(
envelope_.data.get());
}
bool is_err() const { return ordinal_ == Ordinal::kErr; }
static WithErrorSyntax_ErrorAsEnum_Result WithErr(
::fidl::tracking_ptr<::llcpp::fidl::test::protocols::ErrorEnun>&& val) {
WithErrorSyntax_ErrorAsEnum_Result result;
result.set_err(std::move(val));
return result;
}
void set_err(
::fidl::tracking_ptr<::llcpp::fidl::test::protocols::ErrorEnun>&& elem) {
ordinal_ = Ordinal::kErr;
reset_ptr(static_cast<::fidl::tracking_ptr<void>>(std::move(elem)));
}
::llcpp::fidl::test::protocols::ErrorEnun& mutable_err() {
ZX_ASSERT(ordinal_ == Ordinal::kErr);
return *static_cast<::llcpp::fidl::test::protocols::ErrorEnun*>(
envelope_.data.get());
}
const ::llcpp::fidl::test::protocols::ErrorEnun& err() const {
ZX_ASSERT(ordinal_ == Ordinal::kErr);
return *static_cast<::llcpp::fidl::test::protocols::ErrorEnun*>(
envelope_.data.get());
}
Tag which() const {
ZX_ASSERT(!has_invalid_tag());
return static_cast<Tag>(ordinal_);
}
static constexpr const fidl_type_t* Type =
&fidl_test_protocols_WithErrorSyntax_ErrorAsEnum_ResultTable;
static constexpr uint32_t MaxNumHandles = 0;
static constexpr uint32_t PrimarySize = 24;
[[maybe_unused]] static constexpr uint32_t MaxOutOfLine = 8;
static constexpr bool HasPointer = true;
static constexpr bool IsResource = false;
void _CloseHandles();
private:
enum class Ordinal : fidl_xunion_tag_t {
Invalid = 0,
kResponse = 1, // 0x1
kErr = 2, // 0x2
};
void reset_ptr(::fidl::tracking_ptr<void>&& new_ptr) {
// To clear the existing value, std::move it and let it go out of scope.
switch (static_cast<fidl_xunion_tag_t>(ordinal_)) {
case 1: {
::fidl::tracking_ptr<::llcpp::fidl::test::protocols::
WithErrorSyntax_ErrorAsEnum_Response>
to_destroy = static_cast<
::fidl::tracking_ptr<::llcpp::fidl::test::protocols::
WithErrorSyntax_ErrorAsEnum_Response>>(
std::move(envelope_.data));
break;
}
case 2: {
::fidl::tracking_ptr<::llcpp::fidl::test::protocols::ErrorEnun>
to_destroy = static_cast<::fidl::tracking_ptr<
::llcpp::fidl::test::protocols::ErrorEnun>>(
std::move(envelope_.data));
break;
}
}
envelope_.data = std::move(new_ptr);
}
static void SizeAndOffsetAssertionHelper();
Ordinal ordinal_;
FIDL_ALIGNDECL
::fidl::Envelope<void> envelope_;
};
extern "C" const fidl_type_t
fidl_test_protocols_WithErrorSyntax_ResponseAsStruct_ResponseTable;
struct WithErrorSyntax_ResponseAsStruct_Response {
static constexpr const fidl_type_t* Type =
&fidl_test_protocols_WithErrorSyntax_ResponseAsStruct_ResponseTable;
static constexpr uint32_t MaxNumHandles = 0;
static constexpr uint32_t PrimarySize = 24;
[[maybe_unused]] static constexpr uint32_t MaxOutOfLine = 0;
static constexpr bool HasPointer = false;
static constexpr bool IsResource = false;
int64_t a = {};
int64_t b = {};
int64_t c = {};
void _CloseHandles();
class UnownedEncodedMessage final {
public:
UnownedEncodedMessage(uint8_t* bytes, uint32_t byte_size,
WithErrorSyntax_ResponseAsStruct_Response* value)
: message_(bytes, byte_size,
sizeof(WithErrorSyntax_ResponseAsStruct_Response), nullptr,
0, 0) {
message_.LinearizeAndEncode<WithErrorSyntax_ResponseAsStruct_Response>(
value);
}
UnownedEncodedMessage(const UnownedEncodedMessage&) = delete;
UnownedEncodedMessage(UnownedEncodedMessage&&) = delete;
UnownedEncodedMessage* operator=(const UnownedEncodedMessage&) = delete;
UnownedEncodedMessage* operator=(UnownedEncodedMessage&&) = delete;
zx_status_t status() const { return message_.status(); }
#ifdef __Fuchsia__
const char* status_string() const { return message_.status_string(); }
#endif
bool ok() const { return message_.status() == ZX_OK; }
const char* error() const { return message_.error(); }
::fidl::OutgoingMessage& GetOutgoingMessage() { return message_; }
private:
::fidl::OutgoingMessage message_;
};
class OwnedEncodedMessage final {
public:
explicit OwnedEncodedMessage(
WithErrorSyntax_ResponseAsStruct_Response* value)
: message_(bytes_, sizeof(bytes_), value) {}
OwnedEncodedMessage(const OwnedEncodedMessage&) = delete;
OwnedEncodedMessage(OwnedEncodedMessage&&) = delete;
OwnedEncodedMessage* operator=(const OwnedEncodedMessage&) = delete;
OwnedEncodedMessage* operator=(OwnedEncodedMessage&&) = delete;
zx_status_t status() const { return message_.status(); }
#ifdef __Fuchsia__
const char* status_string() const { return message_.status_string(); }
#endif
bool ok() const { return message_.ok(); }
const char* error() const { return message_.error(); }
::fidl::OutgoingMessage& GetOutgoingMessage() {
return message_.GetOutgoingMessage();
}
private:
FIDL_ALIGNDECL
uint8_t bytes_[FIDL_ALIGN(PrimarySize + MaxOutOfLine)];
UnownedEncodedMessage message_;
};
class DecodedMessage final : public ::fidl::internal::IncomingMessage {
public:
DecodedMessage(uint8_t* bytes, uint32_t byte_actual,
zx_handle_info_t* handles = nullptr,
uint32_t handle_actual = 0)
: ::fidl::internal::IncomingMessage(bytes, byte_actual, handles,
handle_actual) {
Decode<struct WithErrorSyntax_ResponseAsStruct_Response>();
}
DecodedMessage(fidl_incoming_msg_t* msg)
: ::fidl::internal::IncomingMessage(msg) {
Decode<struct WithErrorSyntax_ResponseAsStruct_Response>();
}
DecodedMessage(const DecodedMessage&) = delete;
DecodedMessage(DecodedMessage&&) = delete;
DecodedMessage* operator=(const DecodedMessage&) = delete;
DecodedMessage* operator=(DecodedMessage&&) = delete;
struct WithErrorSyntax_ResponseAsStruct_Response* PrimaryObject() {
ZX_DEBUG_ASSERT(ok());
return reinterpret_cast<
struct WithErrorSyntax_ResponseAsStruct_Response*>(bytes());
}
// Release the ownership of the decoded message. That means that the handles
// won't be closed When the object is destroyed. After calling this method,
// the DecodedMessage object should not be used anymore.
void ReleasePrimaryObject() { ResetBytes(); }
// These methods should only be used for testing purpose.
// They create an DecodedMessage using the bytes of an outgoing message and
// copying the handles.
static DecodedMessage FromOutgoingWithRawHandleCopy(
UnownedEncodedMessage* encoded_message) {
return DecodedMessage(encoded_message->GetOutgoingMessage());
}
static DecodedMessage FromOutgoingWithRawHandleCopy(
OwnedEncodedMessage* encoded_message) {
return DecodedMessage(encoded_message->GetOutgoingMessage());
}
private:
DecodedMessage(::fidl::OutgoingMessage& outgoing_message) {
Init(outgoing_message, nullptr, 0);
if (ok()) {
Decode<struct WithErrorSyntax_ResponseAsStruct_Response>();
}
}
};
};
extern "C" const fidl_type_t
fidl_test_protocols_WithErrorSyntax_ErrorAsPrimitive_ResponseTable;
struct WithErrorSyntax_ErrorAsPrimitive_Response {
static constexpr const fidl_type_t* Type =
&fidl_test_protocols_WithErrorSyntax_ErrorAsPrimitive_ResponseTable;
static constexpr uint32_t MaxNumHandles = 0;
static constexpr uint32_t PrimarySize = 1;
[[maybe_unused]] static constexpr uint32_t MaxOutOfLine = 0;
static constexpr bool HasPointer = false;
static constexpr bool IsResource = false;
uint8_t __reserved = {};
void _CloseHandles();
class UnownedEncodedMessage final {
public:
UnownedEncodedMessage(uint8_t* bytes, uint32_t byte_size,
WithErrorSyntax_ErrorAsPrimitive_Response* value)
: message_(bytes, byte_size,
sizeof(WithErrorSyntax_ErrorAsPrimitive_Response), nullptr,
0, 0) {
message_.LinearizeAndEncode<WithErrorSyntax_ErrorAsPrimitive_Response>(
value);
}
UnownedEncodedMessage(const UnownedEncodedMessage&) = delete;
UnownedEncodedMessage(UnownedEncodedMessage&&) = delete;
UnownedEncodedMessage* operator=(const UnownedEncodedMessage&) = delete;
UnownedEncodedMessage* operator=(UnownedEncodedMessage&&) = delete;
zx_status_t status() const { return message_.status(); }
#ifdef __Fuchsia__
const char* status_string() const { return message_.status_string(); }
#endif
bool ok() const { return message_.status() == ZX_OK; }
const char* error() const { return message_.error(); }
::fidl::OutgoingMessage& GetOutgoingMessage() { return message_; }
private:
::fidl::OutgoingMessage message_;
};
class OwnedEncodedMessage final {
public:
explicit OwnedEncodedMessage(
WithErrorSyntax_ErrorAsPrimitive_Response* value)
: message_(bytes_, sizeof(bytes_), value) {}
OwnedEncodedMessage(const OwnedEncodedMessage&) = delete;
OwnedEncodedMessage(OwnedEncodedMessage&&) = delete;
OwnedEncodedMessage* operator=(const OwnedEncodedMessage&) = delete;
OwnedEncodedMessage* operator=(OwnedEncodedMessage&&) = delete;
zx_status_t status() const { return message_.status(); }
#ifdef __Fuchsia__
const char* status_string() const { return message_.status_string(); }
#endif
bool ok() const { return message_.ok(); }
const char* error() const { return message_.error(); }
::fidl::OutgoingMessage& GetOutgoingMessage() {
return message_.GetOutgoingMessage();
}
private:
FIDL_ALIGNDECL
uint8_t bytes_[FIDL_ALIGN(PrimarySize + MaxOutOfLine)];
UnownedEncodedMessage message_;
};
class DecodedMessage final : public ::fidl::internal::IncomingMessage {
public:
DecodedMessage(uint8_t* bytes, uint32_t byte_actual,
zx_handle_info_t* handles = nullptr,
uint32_t handle_actual = 0)
: ::fidl::internal::IncomingMessage(bytes, byte_actual, handles,
handle_actual) {
Decode<struct WithErrorSyntax_ErrorAsPrimitive_Response>();
}
DecodedMessage(fidl_incoming_msg_t* msg)
: ::fidl::internal::IncomingMessage(msg) {
Decode<struct WithErrorSyntax_ErrorAsPrimitive_Response>();
}
DecodedMessage(const DecodedMessage&) = delete;
DecodedMessage(DecodedMessage&&) = delete;
DecodedMessage* operator=(const DecodedMessage&) = delete;
DecodedMessage* operator=(DecodedMessage&&) = delete;
struct WithErrorSyntax_ErrorAsPrimitive_Response* PrimaryObject() {
ZX_DEBUG_ASSERT(ok());
return reinterpret_cast<
struct WithErrorSyntax_ErrorAsPrimitive_Response*>(bytes());
}
// Release the ownership of the decoded message. That means that the handles
// won't be closed When the object is destroyed. After calling this method,
// the DecodedMessage object should not be used anymore.
void ReleasePrimaryObject() { ResetBytes(); }
// These methods should only be used for testing purpose.
// They create an DecodedMessage using the bytes of an outgoing message and
// copying the handles.
static DecodedMessage FromOutgoingWithRawHandleCopy(
UnownedEncodedMessage* encoded_message) {
return DecodedMessage(encoded_message->GetOutgoingMessage());
}
static DecodedMessage FromOutgoingWithRawHandleCopy(
OwnedEncodedMessage* encoded_message) {
return DecodedMessage(encoded_message->GetOutgoingMessage());
}
private:
DecodedMessage(::fidl::OutgoingMessage& outgoing_message) {
Init(outgoing_message, nullptr, 0);
if (ok()) {
Decode<struct WithErrorSyntax_ErrorAsPrimitive_Response>();
}
}
};
};
extern "C" const fidl_type_t
fidl_test_protocols_WithErrorSyntax_ErrorAsEnum_ResponseTable;
struct WithErrorSyntax_ErrorAsEnum_Response {
static constexpr const fidl_type_t* Type =
&fidl_test_protocols_WithErrorSyntax_ErrorAsEnum_ResponseTable;
static constexpr uint32_t MaxNumHandles = 0;
static constexpr uint32_t PrimarySize = 1;
[[maybe_unused]] static constexpr uint32_t MaxOutOfLine = 0;
static constexpr bool HasPointer = false;
static constexpr bool IsResource = false;
uint8_t __reserved = {};
void _CloseHandles();
class UnownedEncodedMessage final {
public:
UnownedEncodedMessage(uint8_t* bytes, uint32_t byte_size,
WithErrorSyntax_ErrorAsEnum_Response* value)
: message_(bytes, byte_size,
sizeof(WithErrorSyntax_ErrorAsEnum_Response), nullptr, 0,
0) {
message_.LinearizeAndEncode<WithErrorSyntax_ErrorAsEnum_Response>(value);
}
UnownedEncodedMessage(const UnownedEncodedMessage&) = delete;
UnownedEncodedMessage(UnownedEncodedMessage&&) = delete;
UnownedEncodedMessage* operator=(const UnownedEncodedMessage&) = delete;
UnownedEncodedMessage* operator=(UnownedEncodedMessage&&) = delete;
zx_status_t status() const { return message_.status(); }
#ifdef __Fuchsia__
const char* status_string() const { return message_.status_string(); }
#endif
bool ok() const { return message_.status() == ZX_OK; }
const char* error() const { return message_.error(); }
::fidl::OutgoingMessage& GetOutgoingMessage() { return message_; }
private:
::fidl::OutgoingMessage message_;
};
class OwnedEncodedMessage final {
public:
explicit OwnedEncodedMessage(WithErrorSyntax_ErrorAsEnum_Response* value)
: message_(bytes_, sizeof(bytes_), value) {}
OwnedEncodedMessage(const OwnedEncodedMessage&) = delete;
OwnedEncodedMessage(OwnedEncodedMessage&&) = delete;
OwnedEncodedMessage* operator=(const OwnedEncodedMessage&) = delete;
OwnedEncodedMessage* operator=(OwnedEncodedMessage&&) = delete;
zx_status_t status() const { return message_.status(); }
#ifdef __Fuchsia__
const char* status_string() const { return message_.status_string(); }
#endif
bool ok() const { return message_.ok(); }
const char* error() const { return message_.error(); }
::fidl::OutgoingMessage& GetOutgoingMessage() {
return message_.GetOutgoingMessage();
}
private:
FIDL_ALIGNDECL
uint8_t bytes_[FIDL_ALIGN(PrimarySize + MaxOutOfLine)];
UnownedEncodedMessage message_;
};
class DecodedMessage final : public ::fidl::internal::IncomingMessage {
public:
DecodedMessage(uint8_t* bytes, uint32_t byte_actual,
zx_handle_info_t* handles = nullptr,
uint32_t handle_actual = 0)
: ::fidl::internal::IncomingMessage(bytes, byte_actual, handles,
handle_actual) {
Decode<struct WithErrorSyntax_ErrorAsEnum_Response>();
}
DecodedMessage(fidl_incoming_msg_t* msg)
: ::fidl::internal::IncomingMessage(msg) {
Decode<struct WithErrorSyntax_ErrorAsEnum_Response>();
}
DecodedMessage(const DecodedMessage&) = delete;
DecodedMessage(DecodedMessage&&) = delete;
DecodedMessage* operator=(const DecodedMessage&) = delete;
DecodedMessage* operator=(DecodedMessage&&) = delete;
struct WithErrorSyntax_ErrorAsEnum_Response* PrimaryObject() {
ZX_DEBUG_ASSERT(ok());
return reinterpret_cast<struct WithErrorSyntax_ErrorAsEnum_Response*>(
bytes());
}
// Release the ownership of the decoded message. That means that the handles
// won't be closed When the object is destroyed. After calling this method,
// the DecodedMessage object should not be used anymore.
void ReleasePrimaryObject() { ResetBytes(); }
// These methods should only be used for testing purpose.
// They create an DecodedMessage using the bytes of an outgoing message and
// copying the handles.
static DecodedMessage FromOutgoingWithRawHandleCopy(
UnownedEncodedMessage* encoded_message) {
return DecodedMessage(encoded_message->GetOutgoingMessage());
}
static DecodedMessage FromOutgoingWithRawHandleCopy(
OwnedEncodedMessage* encoded_message) {
return DecodedMessage(encoded_message->GetOutgoingMessage());
}
private:
DecodedMessage(::fidl::OutgoingMessage& outgoing_message) {
Init(outgoing_message, nullptr, 0);
if (ok()) {
Decode<struct WithErrorSyntax_ErrorAsEnum_Response>();
}
}
};
};
extern "C" const fidl_type_t
fidl_test_protocols_TransitionalRequestRequestTable;
extern "C" const fidl_type_t
fidl_test_protocols_TransitionalRequestResponseTable;
extern "C" const fidl_type_t fidl_test_protocols_TransitionalOneWayRequestTable;
extern "C" const fidl_type_t
fidl_test_protocols_TransitionalOneWayResponseTable;
extern "C" const fidl_type_t fidl_test_protocols_TransitionalEventRequestTable;
extern "C" const fidl_type_t fidl_test_protocols_TransitionalEventEventTable;
class Transitional final {
Transitional() = delete;
public:
struct RequestResponse final {
FIDL_ALIGNDECL
fidl_message_header_t _hdr;
int64_t y;
explicit RequestResponse(int64_t y) : y(y) { _InitHeader(); }
RequestResponse() { _InitHeader(); }
static constexpr const fidl_type_t* Type =
&fidl_test_protocols_TransitionalRequestResponseTable;
static constexpr uint32_t MaxNumHandles = 0;
static constexpr uint32_t PrimarySize = 24;
static constexpr uint32_t MaxOutOfLine = 0;
static constexpr bool HasFlexibleEnvelope = false;
static constexpr bool HasPointer = false;
static constexpr bool IsResource = false;
static constexpr ::fidl::internal::TransactionalMessageKind MessageKind =
::fidl::internal::TransactionalMessageKind::kResponse;
class UnownedEncodedMessage final {
public:
UnownedEncodedMessage(uint8_t* _bytes, uint32_t _byte_size, int64_t y)
: message_(_bytes, _byte_size, sizeof(RequestResponse), nullptr, 0,
0) {
FIDL_ALIGNDECL RequestResponse _response{y};
message_.LinearizeAndEncode<RequestResponse>(&_response);
}
UnownedEncodedMessage(uint8_t* bytes, uint32_t byte_size,
RequestResponse* response)
: message_(bytes, byte_size, sizeof(RequestResponse), nullptr, 0, 0) {
message_.LinearizeAndEncode<RequestResponse>(response);
}
UnownedEncodedMessage(const UnownedEncodedMessage&) = delete;
UnownedEncodedMessage(UnownedEncodedMessage&&) = delete;
UnownedEncodedMessage* operator=(const UnownedEncodedMessage&) = delete;
UnownedEncodedMessage* operator=(UnownedEncodedMessage&&) = delete;
zx_status_t status() const { return message_.status(); }
#ifdef __Fuchsia__
const char* status_string() const { return message_.status_string(); }
#endif
bool ok() const { return message_.status() == ZX_OK; }
const char* error() const { return message_.error(); }
::fidl::OutgoingMessage& GetOutgoingMessage() { return message_; }
void Write(zx_handle_t client) { message_.Write(client); }
private:
RequestResponse& Message() {
return *reinterpret_cast<RequestResponse*>(message_.bytes());
}
::fidl::OutgoingMessage message_;
};
class OwnedEncodedMessage final {
public:
explicit OwnedEncodedMessage(int64_t y)
: message_(bytes_, sizeof(bytes_), y) {}
explicit OwnedEncodedMessage(RequestResponse* response)
: message_(bytes_, sizeof(bytes_), response) {}
OwnedEncodedMessage(const OwnedEncodedMessage&) = delete;
OwnedEncodedMessage(OwnedEncodedMessage&&) = delete;
OwnedEncodedMessage* operator=(const OwnedEncodedMessage&) = delete;
OwnedEncodedMessage* operator=(OwnedEncodedMessage&&) = delete;
zx_status_t status() const { return message_.status(); }
#ifdef __Fuchsia__
const char* status_string() const { return message_.status_string(); }
#endif
bool ok() const { return message_.ok(); }
const char* error() const { return message_.error(); }
::fidl::OutgoingMessage& GetOutgoingMessage() {
return message_.GetOutgoingMessage();
}
void Write(zx_handle_t client) { message_.Write(client); }
private:
FIDL_ALIGNDECL
uint8_t bytes_[PrimarySize + MaxOutOfLine];
UnownedEncodedMessage message_;
};
class DecodedMessage final : public ::fidl::internal::IncomingMessage {
public:
DecodedMessage(uint8_t* bytes, uint32_t byte_actual,
zx_handle_info_t* handles = nullptr,
uint32_t handle_actual = 0)
: ::fidl::internal::IncomingMessage(bytes, byte_actual, handles,
handle_actual) {
Decode<RequestResponse>();
}
DecodedMessage(fidl_incoming_msg_t* msg)
: ::fidl::internal::IncomingMessage(msg) {
Decode<RequestResponse>();
}
DecodedMessage(const DecodedMessage&) = delete;
DecodedMessage(DecodedMessage&&) = delete;
DecodedMessage* operator=(const DecodedMessage&) = delete;
DecodedMessage* operator=(DecodedMessage&&) = delete;
RequestResponse* PrimaryObject() {
ZX_DEBUG_ASSERT(ok());
return reinterpret_cast<RequestResponse*>(bytes());
}
// Release the ownership of the decoded message. That means that the
// handles won't be closed When the object is destroyed. After calling
// this method, the DecodedMessage object should not be used anymore.
void ReleasePrimaryObject() { ResetBytes(); }
// These methods should only be used for testing purpose.
// They create an DecodedMessage using the bytes of an outgoing message
// and copying the handles.
static DecodedMessage FromOutgoingWithRawHandleCopy(
UnownedEncodedMessage* outgoing_message) {
return DecodedMessage(outgoing_message->GetOutgoingMessage());
}
static DecodedMessage FromOutgoingWithRawHandleCopy(
OwnedEncodedMessage* outgoing_message) {
return DecodedMessage(outgoing_message->GetOutgoingMessage());
}
private:
DecodedMessage(::fidl::OutgoingMessage& outgoing_message) {
Init(outgoing_message, nullptr, 0);
if (ok()) {
Decode<RequestResponse>();
}
}
};
private:
void _InitHeader();
};
struct RequestRequest final {
FIDL_ALIGNDECL
fidl_message_header_t _hdr;
int64_t x;
explicit RequestRequest(zx_txid_t _txid, int64_t x) : x(x) {
_InitHeader(_txid);
}
explicit RequestRequest(zx_txid_t _txid) { _InitHeader(_txid); }
static constexpr const fidl_type_t* Type =
&fidl_test_protocols_TransitionalRequestRequestTable;
static constexpr uint32_t MaxNumHandles = 0;
static constexpr uint32_t PrimarySize = 24;
static constexpr uint32_t MaxOutOfLine = 0;
static constexpr uint32_t AltPrimarySize = 24;
static constexpr uint32_t AltMaxOutOfLine = 0;
static constexpr bool HasFlexibleEnvelope = false;
static constexpr bool HasPointer = false;
static constexpr bool IsResource = false;
static constexpr ::fidl::internal::TransactionalMessageKind MessageKind =
::fidl::internal::TransactionalMessageKind::kRequest;
using ResponseType = RequestResponse;
class UnownedEncodedMessage final {
public:
UnownedEncodedMessage(uint8_t* _bytes, uint32_t _byte_size,
zx_txid_t _txid, int64_t x)
: message_(_bytes, _byte_size, sizeof(RequestRequest), nullptr, 0,
0) {
FIDL_ALIGNDECL RequestRequest _request(_txid, x);
message_.LinearizeAndEncode<RequestRequest>(&_request);
}
UnownedEncodedMessage(uint8_t* bytes, uint32_t byte_size,
RequestRequest* request)
: message_(bytes, byte_size, sizeof(RequestRequest), nullptr, 0, 0) {
message_.LinearizeAndEncode<RequestRequest>(request);
}
UnownedEncodedMessage(const UnownedEncodedMessage&) = delete;
UnownedEncodedMessage(UnownedEncodedMessage&&) = delete;
UnownedEncodedMessage* operator=(const UnownedEncodedMessage&) = delete;
UnownedEncodedMessage* operator=(UnownedEncodedMessage&&) = delete;
zx_status_t status() const { return message_.status(); }
#ifdef __Fuchsia__
const char* status_string() const { return message_.status_string(); }
#endif
bool ok() const { return message_.status() == ZX_OK; }
const char* error() const { return message_.error(); }
::fidl::OutgoingMessage& GetOutgoingMessage() { return message_; }
void Write(zx_handle_t client) { message_.Write(client); }
private:
RequestRequest& Message() {
return *reinterpret_cast<RequestRequest*>(message_.bytes());
}
::fidl::OutgoingMessage message_;
};
class OwnedEncodedMessage final {
public:
explicit OwnedEncodedMessage(zx_txid_t _txid, int64_t x)
: message_(bytes_, sizeof(bytes_), _txid, x) {}
explicit OwnedEncodedMessage(RequestRequest* request)
: message_(bytes_, sizeof(bytes_), request) {}
OwnedEncodedMessage(const OwnedEncodedMessage&) = delete;
OwnedEncodedMessage(OwnedEncodedMessage&&) = delete;
OwnedEncodedMessage* operator=(const OwnedEncodedMessage&) = delete;
OwnedEncodedMessage* operator=(OwnedEncodedMessage&&) = delete;
zx_status_t status() const { return message_.status(); }
#ifdef __Fuchsia__
const char* status_string() const { return message_.status_string(); }
#endif
bool ok() const { return message_.ok(); }
const char* error() const { return message_.error(); }
::fidl::OutgoingMessage& GetOutgoingMessage() {
return message_.GetOutgoingMessage();
}
void Write(zx_handle_t client) { message_.Write(client); }
private:
FIDL_ALIGNDECL
uint8_t bytes_[PrimarySize + MaxOutOfLine];
UnownedEncodedMessage message_;
};
class DecodedMessage final : public ::fidl::internal::IncomingMessage {
public:
DecodedMessage(uint8_t* bytes, uint32_t byte_actual,
zx_handle_info_t* handles = nullptr,
uint32_t handle_actual = 0)
: ::fidl::internal::IncomingMessage(bytes, byte_actual, handles,
handle_actual) {
Decode<RequestRequest>();
}
DecodedMessage(fidl_incoming_msg_t* msg)
: ::fidl::internal::IncomingMessage(msg) {
Decode<RequestRequest>();
}
DecodedMessage(const DecodedMessage&) = delete;
DecodedMessage(DecodedMessage&&) = delete;
DecodedMessage* operator=(const DecodedMessage&) = delete;
DecodedMessage* operator=(DecodedMessage&&) = delete;
RequestRequest* PrimaryObject() {
ZX_DEBUG_ASSERT(ok());
return reinterpret_cast<RequestRequest*>(bytes());
}
// Release the ownership of the decoded message. That means that the
// handles won't be closed When the object is destroyed. After calling
// this method, the DecodedMessage object should not be used anymore.
void ReleasePrimaryObject() { ResetBytes(); }
// These methods should only be used for testing purpose.
// They create an DecodedMessage using the bytes of an outgoing message
// and copying the handles.
static DecodedMessage FromOutgoingWithRawHandleCopy(
UnownedEncodedMessage* encoded_message) {
return DecodedMessage(encoded_message->GetOutgoingMessage());
}
static DecodedMessage FromOutgoingWithRawHandleCopy(
OwnedEncodedMessage* encoded_message) {
return DecodedMessage(encoded_message->GetOutgoingMessage());
}
private:
DecodedMessage(::fidl::OutgoingMessage& outgoing_message) {
Init(outgoing_message, nullptr, 0);
if (ok()) {
Decode<RequestRequest>();
}
}
};
private:
void _InitHeader(zx_txid_t _txid);
};
struct OneWayRequest final {
FIDL_ALIGNDECL
fidl_message_header_t _hdr;
int64_t x;
explicit OneWayRequest(zx_txid_t _txid, int64_t x) : x(x) {
_InitHeader(_txid);
}
explicit OneWayRequest(zx_txid_t _txid) { _InitHeader(_txid); }
static constexpr const fidl_type_t* Type =
&fidl_test_protocols_TransitionalOneWayRequestTable;
static constexpr uint32_t MaxNumHandles = 0;
static constexpr uint32_t PrimarySize = 24;
static constexpr uint32_t MaxOutOfLine = 0;
static constexpr uint32_t AltPrimarySize = 24;
static constexpr uint32_t AltMaxOutOfLine = 0;
static constexpr bool HasFlexibleEnvelope = false;
static constexpr bool HasPointer = false;
static constexpr bool IsResource = false;
static constexpr ::fidl::internal::TransactionalMessageKind MessageKind =
::fidl::internal::TransactionalMessageKind::kRequest;
class UnownedEncodedMessage final {
public:
UnownedEncodedMessage(uint8_t* _bytes, uint32_t _byte_size,
zx_txid_t _txid, int64_t x)
: message_(_bytes, _byte_size, sizeof(OneWayRequest), nullptr, 0, 0) {
FIDL_ALIGNDECL OneWayRequest _request(_txid, x);
message_.LinearizeAndEncode<OneWayRequest>(&_request);
}
UnownedEncodedMessage(uint8_t* bytes, uint32_t byte_size,
OneWayRequest* request)
: message_(bytes, byte_size, sizeof(OneWayRequest), nullptr, 0, 0) {
message_.LinearizeAndEncode<OneWayRequest>(request);
}
UnownedEncodedMessage(const UnownedEncodedMessage&) = delete;
UnownedEncodedMessage(UnownedEncodedMessage&&) = delete;
UnownedEncodedMessage* operator=(const UnownedEncodedMessage&) = delete;
UnownedEncodedMessage* operator=(UnownedEncodedMessage&&) = delete;
zx_status_t status() const { return message_.status(); }
#ifdef __Fuchsia__
const char* status_string() const { return message_.status_string(); }
#endif
bool ok() const { return message_.status() == ZX_OK; }
const char* error() const { return message_.error(); }
::fidl::OutgoingMessage& GetOutgoingMessage() { return message_; }
void Write(zx_handle_t client) { message_.Write(client); }
private:
OneWayRequest& Message() {
return *reinterpret_cast<OneWayRequest*>(message_.bytes());
}
::fidl::OutgoingMessage message_;
};
class OwnedEncodedMessage final {
public:
explicit OwnedEncodedMessage(zx_txid_t _txid, int64_t x)
: message_(bytes_, sizeof(bytes_), _txid, x) {}
explicit OwnedEncodedMessage(OneWayRequest* request)
: message_(bytes_, sizeof(bytes_), request) {}
OwnedEncodedMessage(const OwnedEncodedMessage&) = delete;
OwnedEncodedMessage(OwnedEncodedMessage&&) = delete;
OwnedEncodedMessage* operator=(const OwnedEncodedMessage&) = delete;
OwnedEncodedMessage* operator=(OwnedEncodedMessage&&) = delete;
zx_status_t status() const { return message_.status(); }
#ifdef __Fuchsia__
const char* status_string() const { return message_.status_string(); }
#endif
bool ok() const { return message_.ok(); }
const char* error() const { return message_.error(); }
::fidl::OutgoingMessage& GetOutgoingMessage() {
return message_.GetOutgoingMessage();
}
void Write(zx_handle_t client) { message_.Write(client); }
private:
FIDL_ALIGNDECL
uint8_t bytes_[PrimarySize + MaxOutOfLine];
UnownedEncodedMessage message_;
};
class DecodedMessage final : public ::fidl::internal::IncomingMessage {
public:
DecodedMessage(uint8_t* bytes, uint32_t byte_actual,
zx_handle_info_t* handles = nullptr,
uint32_t handle_actual = 0)
: ::fidl::internal::IncomingMessage(bytes, byte_actual, handles,
handle_actual) {
Decode<OneWayRequest>();
}
DecodedMessage(fidl_incoming_msg_t* msg)
: ::fidl::internal::IncomingMessage(msg) {
Decode<OneWayRequest>();
}
DecodedMessage(const DecodedMessage&) = delete;
DecodedMessage(DecodedMessage&&) = delete;
DecodedMessage* operator=(const DecodedMessage&) = delete;
DecodedMessage* operator=(DecodedMessage&&) = delete;
OneWayRequest* PrimaryObject() {
ZX_DEBUG_ASSERT(ok());
return reinterpret_cast<OneWayRequest*>(bytes());
}
// Release the ownership of the decoded message. That means that the
// handles won't be closed When the object is destroyed. After calling
// this method, the DecodedMessage object should not be used anymore.
void ReleasePrimaryObject() { ResetBytes(); }
// These methods should only be used for testing purpose.
// They create an DecodedMessage using the bytes of an outgoing message
// and copying the handles.
static DecodedMessage FromOutgoingWithRawHandleCopy(
UnownedEncodedMessage* encoded_message) {
return DecodedMessage(encoded_message->GetOutgoingMessage());
}
static DecodedMessage FromOutgoingWithRawHandleCopy(
OwnedEncodedMessage* encoded_message) {
return DecodedMessage(encoded_message->GetOutgoingMessage());
}
private:
DecodedMessage(::fidl::OutgoingMessage& outgoing_message) {
Init(outgoing_message, nullptr, 0);
if (ok()) {
Decode<OneWayRequest>();
}
}
};
private:
void _InitHeader(zx_txid_t _txid);
};
struct EventResponse final {
FIDL_ALIGNDECL
fidl_message_header_t _hdr;
int64_t x;
explicit EventResponse(int64_t x) : x(x) { _InitHeader(); }
EventResponse() { _InitHeader(); }
static constexpr const fidl_type_t* Type =
&fidl_test_protocols_TransitionalEventEventTable;
static constexpr uint32_t MaxNumHandles = 0;
static constexpr uint32_t PrimarySize = 24;
static constexpr uint32_t MaxOutOfLine = 0;
static constexpr bool HasFlexibleEnvelope = false;
static constexpr bool HasPointer = false;
static constexpr bool IsResource = false;
static constexpr ::fidl::internal::TransactionalMessageKind MessageKind =
::fidl::internal::TransactionalMessageKind::kResponse;
class UnownedEncodedMessage final {
public:
UnownedEncodedMessage(uint8_t* _bytes, uint32_t _byte_size, int64_t x)
: message_(_bytes, _byte_size, sizeof(EventResponse), nullptr, 0, 0) {
FIDL_ALIGNDECL EventResponse _response{x};
message_.LinearizeAndEncode<EventResponse>(&_response);
}
UnownedEncodedMessage(uint8_t* bytes, uint32_t byte_size,
EventResponse* response)
: message_(bytes, byte_size, sizeof(EventResponse), nullptr, 0, 0) {
message_.LinearizeAndEncode<EventResponse>(response);
}
UnownedEncodedMessage(const UnownedEncodedMessage&) = delete;
UnownedEncodedMessage(UnownedEncodedMessage&&) = delete;
UnownedEncodedMessage* operator=(const UnownedEncodedMessage&) = delete;
UnownedEncodedMessage* operator=(UnownedEncodedMessage&&) = delete;
zx_status_t status() const { return message_.status(); }
#ifdef __Fuchsia__
const char* status_string() const { return message_.status_string(); }
#endif
bool ok() const { return message_.status() == ZX_OK; }
const char* error() const { return message_.error(); }
::fidl::OutgoingMessage& GetOutgoingMessage() { return message_; }
void Write(zx_handle_t client) { message_.Write(client); }
private:
EventResponse& Message() {
return *reinterpret_cast<EventResponse*>(message_.bytes());
}
::fidl::OutgoingMessage message_;
};
class OwnedEncodedMessage final {
public:
explicit OwnedEncodedMessage(int64_t x)
: message_(bytes_, sizeof(bytes_), x) {}
explicit OwnedEncodedMessage(EventResponse* response)
: message_(bytes_, sizeof(bytes_), response) {}
OwnedEncodedMessage(const OwnedEncodedMessage&) = delete;
OwnedEncodedMessage(OwnedEncodedMessage&&) = delete;
OwnedEncodedMessage* operator=(const OwnedEncodedMessage&) = delete;
OwnedEncodedMessage* operator=(OwnedEncodedMessage&&) = delete;
zx_status_t status() const { return message_.status(); }
#ifdef __Fuchsia__
const char* status_string() const { return message_.status_string(); }
#endif
bool ok() const { return message_.ok(); }
const char* error() const { return message_.error(); }
::fidl::OutgoingMessage& GetOutgoingMessage() {
return message_.GetOutgoingMessage();
}
void Write(zx_handle_t client) { message_.Write(client); }
private:
FIDL_ALIGNDECL
uint8_t bytes_[PrimarySize + MaxOutOfLine];
UnownedEncodedMessage message_;
};
class DecodedMessage final : public ::fidl::internal::IncomingMessage {
public:
DecodedMessage(uint8_t* bytes, uint32_t byte_actual,
zx_handle_info_t* handles = nullptr,
uint32_t handle_actual = 0)
: ::fidl::internal::IncomingMessage(bytes, byte_actual, handles,
handle_actual) {
Decode<EventResponse>();
}
DecodedMessage(fidl_incoming_msg_t* msg)
: ::fidl::internal::IncomingMessage(msg) {
Decode<EventResponse>();
}
DecodedMessage(const DecodedMessage&) = delete;
DecodedMessage(DecodedMessage&&) = delete;
DecodedMessage* operator=(const DecodedMessage&) = delete;
DecodedMessage* operator=(DecodedMessage&&) = delete;
EventResponse* PrimaryObject() {
ZX_DEBUG_ASSERT(ok());
return reinterpret_cast<EventResponse*>(bytes());
}
// Release the ownership of the decoded message. That means that the
// handles won't be closed When the object is destroyed. After calling
// this method, the DecodedMessage object should not be used anymore.
void ReleasePrimaryObject() { ResetBytes(); }
// These methods should only be used for testing purpose.
// They create an DecodedMessage using the bytes of an outgoing message
// and copying the handles.
static DecodedMessage FromOutgoingWithRawHandleCopy(
UnownedEncodedMessage* outgoing_message) {
return DecodedMessage(outgoing_message->GetOutgoingMessage());
}
static DecodedMessage FromOutgoingWithRawHandleCopy(
OwnedEncodedMessage* outgoing_message) {
return DecodedMessage(outgoing_message->GetOutgoingMessage());
}
private:
DecodedMessage(::fidl::OutgoingMessage& outgoing_message) {
Init(outgoing_message, nullptr, 0);
if (ok()) {
Decode<EventResponse>();
}
}
};
private:
void _InitHeader();
};
class EventHandler {
public:
EventHandler() = default;
virtual ~EventHandler() = default;
virtual void Event(EventResponse* event) {
ZX_PANIC("Got event Event which is marked as [Transitional].");
}
// Method called when an unknown event is found. This methods gives the
// status which, in this case, is returned by HandleOneEvent.
virtual zx_status_t Unknown() = 0;
// Handle all possible events defined in this protocol.
// Blocks to consume exactly one message from the channel, then call the
// corresponding virtual method.
::fidl::Result HandleOneEvent(::zx::unowned_channel client_end);
};
// Collection of return types of FIDL calls in this protocol.
class ResultOf final {
ResultOf() = delete;
public:
class Request final : public ::fidl::Result {
public:
explicit Request(zx_handle_t _client, int64_t x);
Request(zx_handle_t _client, int64_t x, zx_time_t _deadline);
explicit Request(const ::fidl::Result& result) : ::fidl::Result(result) {}
Request(Request&&) = delete;
Request(const Request&) = delete;
Request* operator=(Request&&) = delete;
Request* operator=(const Request&) = delete;
~Request() = default;
RequestResponse* Unwrap() {
ZX_DEBUG_ASSERT(ok());
return reinterpret_cast<RequestResponse*>(bytes_);
}
const RequestResponse* Unwrap() const {
ZX_DEBUG_ASSERT(ok());
return reinterpret_cast<const RequestResponse*>(bytes_);
}
RequestResponse& value() { return *Unwrap(); }
const RequestResponse& value() const { return *Unwrap(); }
RequestResponse* operator->() { return &value(); }
const RequestResponse* operator->() const { return &value(); }
RequestResponse& operator*() { return value(); }
const RequestResponse& operator*() const { return value(); }
private:
FIDL_ALIGNDECL
uint8_t
bytes_[RequestResponse::PrimarySize + RequestResponse::MaxOutOfLine];
};
class OneWay final : public ::fidl::Result {
public:
explicit OneWay(zx_handle_t _client, int64_t x);
explicit OneWay(const ::fidl::Result& result) : ::fidl::Result(result) {}
OneWay(OneWay&&) = delete;
OneWay(const OneWay&) = delete;
OneWay* operator=(OneWay&&) = delete;
OneWay* operator=(const OneWay&) = delete;
~OneWay() = default;
private:
};
};
// Collection of return types of FIDL calls in this protocol,
// when the caller-allocate flavor or in-place call is used.
class UnownedResultOf final {
UnownedResultOf() = delete;
public:
class Request final : public ::fidl::Result {
public:
explicit Request(zx_handle_t _client, uint8_t* _request_bytes,
uint32_t _request_byte_capacity, int64_t x,
uint8_t* _response_bytes,
uint32_t _response_byte_capacity);
explicit Request(const ::fidl::Result& result) : ::fidl::Result(result) {}
Request(Request&&) = delete;
Request(const Request&) = delete;
Request* operator=(Request&&) = delete;
Request* operator=(const Request&) = delete;
~Request() = default;
RequestResponse* Unwrap() {
ZX_DEBUG_ASSERT(ok());
return reinterpret_cast<RequestResponse*>(bytes_);
}
const RequestResponse* Unwrap() const {
ZX_DEBUG_ASSERT(ok());
return reinterpret_cast<const RequestResponse*>(bytes_);
}
RequestResponse& value() { return *Unwrap(); }
const RequestResponse& value() const { return *Unwrap(); }
RequestResponse* operator->() { return &value(); }
const RequestResponse* operator->() const { return &value(); }
RequestResponse& operator*() { return value(); }
const RequestResponse& operator*() const { return value(); }
private:
uint8_t* bytes_;
};
class OneWay final : public ::fidl::Result {
public:
explicit OneWay(zx_handle_t _client, uint8_t* _request_bytes,
uint32_t _request_byte_capacity, int64_t x);
explicit OneWay(const ::fidl::Result& result) : ::fidl::Result(result) {}
OneWay(OneWay&&) = delete;
OneWay(const OneWay&) = delete;
OneWay* operator=(OneWay&&) = delete;
OneWay* operator=(const OneWay&) = delete;
~OneWay() = default;
};
};
// Methods to make a sync FIDL call directly on an unowned channel, avoiding
// setting up a client.
class Call final {
Call() = delete;
public:
// Allocates 48 bytes of message buffer on the stack. No heap allocation
// necessary.
static ResultOf::Request Request(::zx::unowned_channel _client_end,
int64_t x) {
return ResultOf::Request(_client_end->get(), x);
}
// Caller provides the backing storage for FIDL message via request and
// response buffers.
static UnownedResultOf::Request Request(
::zx::unowned_channel _client_end, ::fidl::BufferSpan _request_buffer,
int64_t x, ::fidl::BufferSpan _response_buffer) {
return UnownedResultOf::Request(
_client_end->get(), _request_buffer.data, _request_buffer.capacity, x,
_response_buffer.data, _response_buffer.capacity);
}
// Allocates 24 bytes of message buffer on the stack. No heap allocation
// necessary.
static ResultOf::OneWay OneWay(::zx::unowned_channel _client_end,
int64_t x) {
return ResultOf::OneWay(_client_end->get(), x);
}
// Caller provides the backing storage for FIDL message via request and
// response buffers.
static UnownedResultOf::OneWay OneWay(::zx::unowned_channel _client_end,
::fidl::BufferSpan _request_buffer,
int64_t x) {
return UnownedResultOf::OneWay(_client_end->get(), _request_buffer.data,
_request_buffer.capacity, x);
}
};
class SyncClient final {
public:
SyncClient() = default;
explicit SyncClient(::zx::channel channel) : channel_(std::move(channel)) {}
~SyncClient() = default;
SyncClient(SyncClient&&) = default;
SyncClient& operator=(SyncClient&&) = default;
const ::zx::channel& channel() const { return channel_; }
::zx::channel* mutable_channel() { return &channel_; }
// Allocates 48 bytes of message buffer on the stack. No heap allocation
// necessary.
ResultOf::Request Request(int64_t x) {
return ResultOf::Request(this->channel().get(), x);
}
// Caller provides the backing storage for FIDL message via request and
// response buffers.
UnownedResultOf::Request Request(::fidl::BufferSpan _request_buffer,
int64_t x,
::fidl::BufferSpan _response_buffer) {
return UnownedResultOf::Request(
this->channel().get(), _request_buffer.data, _request_buffer.capacity,
x, _response_buffer.data, _response_buffer.capacity);
}
// Allocates 24 bytes of message buffer on the stack. No heap allocation
// necessary.
ResultOf::OneWay OneWay(int64_t x) {
return ResultOf::OneWay(this->channel().get(), x);
}
// Caller provides the backing storage for FIDL message via request and
// response buffers.
UnownedResultOf::OneWay OneWay(::fidl::BufferSpan _request_buffer,
int64_t x) {
return UnownedResultOf::OneWay(this->channel().get(),
_request_buffer.data,
_request_buffer.capacity, x);
}
// Handle all possible events defined in this protocol.
// Blocks to consume exactly one message from the channel, then call the
// corresponding virtual method defined in |EventHandler|. The return status
// of the handler function is folded with any transport-level errors and
// returned.
::fidl::Result HandleOneEvent(EventHandler& event_handler) {
return event_handler.HandleOneEvent(::zx::unowned_channel(channel_));
}
private:
::zx::channel channel_;
};
struct AsyncEventHandlers;
class RequestResponseContext;
class ClientImpl;
// Pure-virtual interface to be implemented by a server.
class Interface : public ::fidl::internal::IncomingMessageDispatcher {
public:
Interface() = default;
virtual ~Interface() = default;
// The marker protocol type within which this |Interface| class is defined.
using _EnclosingProtocol = Transitional;
class RequestCompleterBase : public ::fidl::CompleterBase {
public:
// In the following methods, the return value indicates internal errors
// during the reply, such as encoding or writing to the transport. Note
// that any error will automatically lead to the destruction of the
// binding, after which the |on_unbound| callback will be triggered with a
// detailed reason.
//
// See //zircon/system/ulib/fidl/include/lib/fidl/llcpp/server.h.
//
// Because the reply status is identical to the unbinding status, it can
// be safely ignored.
::fidl::Result Reply(int64_t y);
::fidl::Result Reply(::fidl::BufferSpan _buffer, int64_t y);
protected:
using ::fidl::CompleterBase::CompleterBase;
};
using RequestCompleter = ::fidl::Completer<RequestCompleterBase>;
virtual void Request(int64_t x, RequestCompleter::Sync& _completer) {
_completer.Close(ZX_ERR_NOT_SUPPORTED);
}
using OneWayCompleter = ::fidl::Completer<>;
virtual void OneWay(int64_t x, OneWayCompleter::Sync& _completer) {
_completer.Close(ZX_ERR_NOT_SUPPORTED);
}
private:
::fidl::DispatchResult dispatch_message(fidl_incoming_msg_t* msg,
::fidl::Transaction* txn) final;
};
// Attempts to dispatch the incoming message to a handler function in the
// server implementation. If there is no matching handler, it returns false,
// leaving the message and transaction intact. In all other cases, it consumes
// the message and returns true. It is possible to chain multiple TryDispatch
// functions in this manner.
static ::fidl::DispatchResult TryDispatch(Interface* impl,
fidl_incoming_msg_t* msg,
::fidl::Transaction* txn);
// Dispatches the incoming message to one of the handlers functions in the
// protocol. If there is no matching handler, it closes all the handles in
// |msg| and closes the channel with a |ZX_ERR_NOT_SUPPORTED| epitaph, before
// returning false. The message should then be discarded.
static ::fidl::DispatchResult Dispatch(Interface* impl,
fidl_incoming_msg_t* msg,
::fidl::Transaction* txn);
// Same as |Dispatch|, but takes a |void*| instead of |Interface*|.
// Only used with |fidl::BindServer| to reduce template expansion.
// Do not call this method manually. Use |Dispatch| instead.
static ::fidl::DispatchResult TypeErasedDispatch(void* impl,
fidl_incoming_msg_t* msg,
::fidl::Transaction* txn) {
return Dispatch(static_cast<Interface*>(impl), msg, txn);
}
static zx_status_t SendEventEvent(::zx::unowned_channel _channel, int64_t x);
// Caller provides the backing storage for FIDL message via response buffers.
static zx_status_t SendEventEvent(::zx::unowned_channel _channel,
::fidl::BufferSpan _buffer, int64_t x);
class EventSender;
class WeakEventSender;
};
extern "C" const fidl_type_t
fidl_test_protocols_ChannelProtocolMethodARequestTable;
extern "C" const fidl_type_t
fidl_test_protocols_ChannelProtocolMethodAResponseTable;
extern "C" const fidl_type_t
fidl_test_protocols_ChannelProtocolEventARequestTable;
extern "C" const fidl_type_t
fidl_test_protocols_ChannelProtocolEventAEventTable;
extern "C" const fidl_type_t
fidl_test_protocols_ChannelProtocolMethodBRequestTable;
extern "C" const fidl_type_t
fidl_test_protocols_ChannelProtocolMethodBResponseTable;
extern "C" const fidl_type_t
fidl_test_protocols_ChannelProtocolTakeHandleRequestTable;
extern "C" const fidl_type_t
fidl_test_protocols_ChannelProtocolTakeHandleResponseTable;
extern "C" const fidl_type_t
fidl_test_protocols_ChannelProtocolMutateSocketRequestTable;
extern "C" const fidl_type_t
fidl_test_protocols_ChannelProtocolMutateSocketResponseTable;
class ChannelProtocol final {
ChannelProtocol() = delete;
public:
struct MethodARequest final {
FIDL_ALIGNDECL
fidl_message_header_t _hdr;
int64_t a;
int64_t b;
explicit MethodARequest(zx_txid_t _txid, int64_t a, int64_t b)
: a(a), b(b) {
_InitHeader(_txid);
}
explicit MethodARequest(zx_txid_t _txid) { _InitHeader(_txid); }
static constexpr const fidl_type_t* Type =
&fidl_test_protocols_ChannelProtocolMethodARequestTable;
static constexpr uint32_t MaxNumHandles = 0;
static constexpr uint32_t PrimarySize = 32;
static constexpr uint32_t MaxOutOfLine = 0;
static constexpr uint32_t AltPrimarySize = 32;
static constexpr uint32_t AltMaxOutOfLine = 0;
static constexpr bool HasFlexibleEnvelope = false;
static constexpr bool HasPointer = false;
static constexpr bool IsResource = false;
static constexpr ::fidl::internal::TransactionalMessageKind MessageKind =
::fidl::internal::TransactionalMessageKind::kRequest;
class UnownedEncodedMessage final {
public:
UnownedEncodedMessage(uint8_t* _bytes, uint32_t _byte_size,
zx_txid_t _txid, int64_t a, int64_t b)
: message_(_bytes, _byte_size, sizeof(MethodARequest), nullptr, 0,
0) {
FIDL_ALIGNDECL MethodARequest _request(_txid, a, b);
message_.LinearizeAndEncode<MethodARequest>(&_request);
}
UnownedEncodedMessage(uint8_t* bytes, uint32_t byte_size,
MethodARequest* request)
: message_(bytes, byte_size, sizeof(MethodARequest), nullptr, 0, 0) {
message_.LinearizeAndEncode<MethodARequest>(request);
}
UnownedEncodedMessage(const UnownedEncodedMessage&) = delete;
UnownedEncodedMessage(UnownedEncodedMessage&&) = delete;
UnownedEncodedMessage* operator=(const UnownedEncodedMessage&) = delete;
UnownedEncodedMessage* operator=(UnownedEncodedMessage&&) = delete;
zx_status_t status() const { return message_.status(); }
#ifdef __Fuchsia__
const char* status_string() const { return message_.status_string(); }
#endif
bool ok() const { return message_.status() == ZX_OK; }
const char* error() const { return message_.error(); }
::fidl::OutgoingMessage& GetOutgoingMessage() { return message_; }
void Write(zx_handle_t client) { message_.Write(client); }
private:
MethodARequest& Message() {
return *reinterpret_cast<MethodARequest*>(message_.bytes());
}
::fidl::OutgoingMessage message_;
};
class OwnedEncodedMessage final {
public:
explicit OwnedEncodedMessage(zx_txid_t _txid, int64_t a, int64_t b)
: message_(bytes_, sizeof(bytes_), _txid, a, b) {}
explicit OwnedEncodedMessage(MethodARequest* request)
: message_(bytes_, sizeof(bytes_), request) {}
OwnedEncodedMessage(const OwnedEncodedMessage&) = delete;
OwnedEncodedMessage(OwnedEncodedMessage&&) = delete;
OwnedEncodedMessage* operator=(const OwnedEncodedMessage&) = delete;
OwnedEncodedMessage* operator=(OwnedEncodedMessage&&) = delete;
zx_status_t status() const { return message_.status(); }
#ifdef __Fuchsia__
const char* status_string() const { return message_.status_string(); }
#endif
bool ok() const { return message_.ok(); }
const char* error() const { return message_.error(); }
::fidl::OutgoingMessage& GetOutgoingMessage() {
return message_.GetOutgoingMessage();
}
void Write(zx_handle_t client) { message_.Write(client); }
private:
FIDL_ALIGNDECL
uint8_t bytes_[PrimarySize + MaxOutOfLine];
UnownedEncodedMessage message_;
};
class DecodedMessage final : public ::fidl::internal::IncomingMessage {
public:
DecodedMessage(uint8_t* bytes, uint32_t byte_actual,
zx_handle_info_t* handles = nullptr,
uint32_t handle_actual = 0)
: ::fidl::internal::IncomingMessage(bytes, byte_actual, handles,
handle_actual) {
Decode<MethodARequest>();
}
DecodedMessage(fidl_incoming_msg_t* msg)
: ::fidl::internal::IncomingMessage(msg) {
Decode<MethodARequest>();
}
DecodedMessage(const DecodedMessage&) = delete;
DecodedMessage(DecodedMessage&&) = delete;
DecodedMessage* operator=(const DecodedMessage&) = delete;
DecodedMessage* operator=(DecodedMessage&&) = delete;
MethodARequest* PrimaryObject() {
ZX_DEBUG_ASSERT(ok());
return reinterpret_cast<MethodARequest*>(bytes());
}
// Release the ownership of the decoded message. That means that the
// handles won't be closed When the object is destroyed. After calling
// this method, the DecodedMessage object should not be used anymore.
void ReleasePrimaryObject() { ResetBytes(); }
// These methods should only be used for testing purpose.
// They create an DecodedMessage using the bytes of an outgoing message
// and copying the handles.
static DecodedMessage FromOutgoingWithRawHandleCopy(
UnownedEncodedMessage* encoded_message) {
return DecodedMessage(encoded_message->GetOutgoingMessage());
}
static DecodedMessage FromOutgoingWithRawHandleCopy(
OwnedEncodedMessage* encoded_message) {
return DecodedMessage(encoded_message->GetOutgoingMessage());
}
private:
DecodedMessage(::fidl::OutgoingMessage& outgoing_message) {
Init(outgoing_message, nullptr, 0);
if (ok()) {
Decode<MethodARequest>();
}
}
};
private:
void _InitHeader(zx_txid_t _txid);
};
struct EventAResponse final {
FIDL_ALIGNDECL
fidl_message_header_t _hdr;
int64_t a;
int64_t b;
explicit EventAResponse(int64_t a, int64_t b) : a(a), b(b) {
_InitHeader();
}
EventAResponse() { _InitHeader(); }
static constexpr const fidl_type_t* Type =
&fidl_test_protocols_ChannelProtocolEventAEventTable;
static constexpr uint32_t MaxNumHandles = 0;
static constexpr uint32_t PrimarySize = 32;
static constexpr uint32_t MaxOutOfLine = 0;
static constexpr bool HasFlexibleEnvelope = false;
static constexpr bool HasPointer = false;
static constexpr bool IsResource = false;
static constexpr ::fidl::internal::TransactionalMessageKind MessageKind =
::fidl::internal::TransactionalMessageKind::kResponse;
class UnownedEncodedMessage final {
public:
UnownedEncodedMessage(uint8_t* _bytes, uint32_t _byte_size, int64_t a,
int64_t b)
: message_(_bytes, _byte_size, sizeof(EventAResponse), nullptr, 0,
0) {
FIDL_ALIGNDECL EventAResponse _response{a, b};
message_.LinearizeAndEncode<EventAResponse>(&_response);
}
UnownedEncodedMessage(uint8_t* bytes, uint32_t byte_size,
EventAResponse* response)
: message_(bytes, byte_size, sizeof(EventAResponse), nullptr, 0, 0) {
message_.LinearizeAndEncode<EventAResponse>(response);
}
UnownedEncodedMessage(const UnownedEncodedMessage&) = delete;
UnownedEncodedMessage(UnownedEncodedMessage&&) = delete;
UnownedEncodedMessage* operator=(const UnownedEncodedMessage&) = delete;
UnownedEncodedMessage* operator=(UnownedEncodedMessage&&) = delete;
zx_status_t status() const { return message_.status(); }
#ifdef __Fuchsia__
const char* status_string() const { return message_.status_string(); }
#endif
bool ok() const { return message_.status() == ZX_OK; }
const char* error() const { return message_.error(); }
::fidl::OutgoingMessage& GetOutgoingMessage() { return message_; }
void Write(zx_handle_t client) { message_.Write(client); }
private:
EventAResponse& Message() {
return *reinterpret_cast<EventAResponse*>(message_.bytes());
}
::fidl::OutgoingMessage message_;
};
class OwnedEncodedMessage final {
public:
explicit OwnedEncodedMessage(int64_t a, int64_t b)
: message_(bytes_, sizeof(bytes_), a, b) {}
explicit OwnedEncodedMessage(EventAResponse* response)
: message_(bytes_, sizeof(bytes_), response) {}
OwnedEncodedMessage(const OwnedEncodedMessage&) = delete;
OwnedEncodedMessage(OwnedEncodedMessage&&) = delete;
OwnedEncodedMessage* operator=(const OwnedEncodedMessage&) = delete;
OwnedEncodedMessage* operator=(OwnedEncodedMessage&&) = delete;
zx_status_t status() const { return message_.status(); }
#ifdef __Fuchsia__
const char* status_string() const { return message_.status_string(); }
#endif
bool ok() const { return message_.ok(); }
const char* error() const { return message_.error(); }
::fidl::OutgoingMessage& GetOutgoingMessage() {
return message_.GetOutgoingMessage();
}
void Write(zx_handle_t client) { message_.Write(client); }
private:
FIDL_ALIGNDECL
uint8_t bytes_[PrimarySize + MaxOutOfLine];
UnownedEncodedMessage message_;
};
class DecodedMessage final : public ::fidl::internal::IncomingMessage {
public:
DecodedMessage(uint8_t* bytes, uint32_t byte_actual,
zx_handle_info_t* handles = nullptr,
uint32_t handle_actual = 0)
: ::fidl::internal::IncomingMessage(bytes, byte_actual, handles,
handle_actual) {
Decode<EventAResponse>();
}
DecodedMessage(fidl_incoming_msg_t* msg)
: ::fidl::internal::IncomingMessage(msg) {
Decode<EventAResponse>();
}
DecodedMessage(const DecodedMessage&) = delete;
DecodedMessage(DecodedMessage&&) = delete;
DecodedMessage* operator=(const DecodedMessage&) = delete;
DecodedMessage* operator=(DecodedMessage&&) = delete;
EventAResponse* PrimaryObject() {
ZX_DEBUG_ASSERT(ok());
return reinterpret_cast<EventAResponse*>(bytes());
}
// Release the ownership of the decoded message. That means that the
// handles won't be closed When the object is destroyed. After calling
// this method, the DecodedMessage object should not be used anymore.
void ReleasePrimaryObject() { ResetBytes(); }
// These methods should only be used for testing purpose.
// They create an DecodedMessage using the bytes of an outgoing message
// and copying the handles.
static DecodedMessage FromOutgoingWithRawHandleCopy(
UnownedEncodedMessage* outgoing_message) {
return DecodedMessage(outgoing_message->GetOutgoingMessage());
}
static DecodedMessage FromOutgoingWithRawHandleCopy(
OwnedEncodedMessage* outgoing_message) {
return DecodedMessage(outgoing_message->GetOutgoingMessage());
}
private:
DecodedMessage(::fidl::OutgoingMessage& outgoing_message) {
Init(outgoing_message, nullptr, 0);
if (ok()) {
Decode<EventAResponse>();
}
}
};
private:
void _InitHeader();
};
struct MethodBResponse final {
FIDL_ALIGNDECL
fidl_message_header_t _hdr;
int64_t result;
explicit MethodBResponse(int64_t result) : result(result) { _InitHeader(); }
MethodBResponse() { _InitHeader(); }
static constexpr const fidl_type_t* Type =
&fidl_test_protocols_ChannelProtocolMethodBResponseTable;
static constexpr uint32_t MaxNumHandles = 0;
static constexpr uint32_t PrimarySize = 24;
static constexpr uint32_t MaxOutOfLine = 0;
static constexpr bool HasFlexibleEnvelope = false;
static constexpr bool HasPointer = false;
static constexpr bool IsResource = false;
static constexpr ::fidl::internal::TransactionalMessageKind MessageKind =
::fidl::internal::TransactionalMessageKind::kResponse;
class UnownedEncodedMessage final {
public:
UnownedEncodedMessage(uint8_t* _bytes, uint32_t _byte_size,
int64_t result)
: message_(_bytes, _byte_size, sizeof(MethodBResponse), nullptr, 0,
0) {
FIDL_ALIGNDECL MethodBResponse _response{result};
message_.LinearizeAndEncode<MethodBResponse>(&_response);
}
UnownedEncodedMessage(uint8_t* bytes, uint32_t byte_size,
MethodBResponse* response)
: message_(bytes, byte_size, sizeof(MethodBResponse), nullptr, 0, 0) {
message_.LinearizeAndEncode<MethodBResponse>(response);
}
UnownedEncodedMessage(const UnownedEncodedMessage&) = delete;
UnownedEncodedMessage(UnownedEncodedMessage&&) = delete;
UnownedEncodedMessage* operator=(const UnownedEncodedMessage&) = delete;
UnownedEncodedMessage* operator=(UnownedEncodedMessage&&) = delete;
zx_status_t status() const { return message_.status(); }
#ifdef __Fuchsia__
const char* status_string() const { return message_.status_string(); }
#endif
bool ok() const { return message_.status() == ZX_OK; }
const char* error() const { return message_.error(); }
::fidl::OutgoingMessage& GetOutgoingMessage() { return message_; }
void Write(zx_handle_t client) { message_.Write(client); }
private:
MethodBResponse& Message() {
return *reinterpret_cast<MethodBResponse*>(message_.bytes());
}
::fidl::OutgoingMessage message_;
};
class OwnedEncodedMessage final {
public:
explicit OwnedEncodedMessage(int64_t result)
: message_(bytes_, sizeof(bytes_), result) {}
explicit OwnedEncodedMessage(MethodBResponse* response)
: message_(bytes_, sizeof(bytes_), response) {}
OwnedEncodedMessage(const OwnedEncodedMessage&) = delete;
OwnedEncodedMessage(OwnedEncodedMessage&&) = delete;
OwnedEncodedMessage* operator=(const OwnedEncodedMessage&) = delete;
OwnedEncodedMessage* operator=(OwnedEncodedMessage&&) = delete;
zx_status_t status() const { return message_.status(); }
#ifdef __Fuchsia__
const char* status_string() const { return message_.status_string(); }
#endif
bool ok() const { return message_.ok(); }
const char* error() const { return message_.error(); }
::fidl::OutgoingMessage& GetOutgoingMessage() {
return message_.GetOutgoingMessage();
}
void Write(zx_handle_t client) { message_.Write(client); }
private:
FIDL_ALIGNDECL
uint8_t bytes_[PrimarySize + MaxOutOfLine];
UnownedEncodedMessage message_;
};
class DecodedMessage final : public ::fidl::internal::IncomingMessage {
public:
DecodedMessage(uint8_t* bytes, uint32_t byte_actual,
zx_handle_info_t* handles = nullptr,
uint32_t handle_actual = 0)
: ::fidl::internal::IncomingMessage(bytes, byte_actual, handles,
handle_actual) {
Decode<MethodBResponse>();
}
DecodedMessage(fidl_incoming_msg_t* msg)
: ::fidl::internal::IncomingMessage(msg) {
Decode<MethodBResponse>();
}
DecodedMessage(const DecodedMessage&) = delete;
DecodedMessage(DecodedMessage&&) = delete;
DecodedMessage* operator=(const DecodedMessage&) = delete;
DecodedMessage* operator=(DecodedMessage&&) = delete;
MethodBResponse* PrimaryObject() {
ZX_DEBUG_ASSERT(ok());
return reinterpret_cast<MethodBResponse*>(bytes());
}
// Release the ownership of the decoded message. That means that the
// handles won't be closed When the object is destroyed. After calling
// this method, the DecodedMessage object should not be used anymore.
void ReleasePrimaryObject() { ResetBytes(); }
// These methods should only be used for testing purpose.
// They create an DecodedMessage using the bytes of an outgoing message
// and copying the handles.
static DecodedMessage FromOutgoingWithRawHandleCopy(
UnownedEncodedMessage* outgoing_message) {
return DecodedMessage(outgoing_message->GetOutgoingMessage());
}
static DecodedMessage FromOutgoingWithRawHandleCopy(
OwnedEncodedMessage* outgoing_message) {
return DecodedMessage(outgoing_message->GetOutgoingMessage());
}
private:
DecodedMessage(::fidl::OutgoingMessage& outgoing_message) {
Init(outgoing_message, nullptr, 0);
if (ok()) {
Decode<MethodBResponse>();
}
}
};
private:
void _InitHeader();
};
struct MethodBRequest final {
FIDL_ALIGNDECL
fidl_message_header_t _hdr;
int64_t a;
int64_t b;
explicit MethodBRequest(zx_txid_t _txid, int64_t a, int64_t b)
: a(a), b(b) {
_InitHeader(_txid);
}
explicit MethodBRequest(zx_txid_t _txid) { _InitHeader(_txid); }
static constexpr const fidl_type_t* Type =
&fidl_test_protocols_ChannelProtocolMethodBRequestTable;
static constexpr uint32_t MaxNumHandles = 0;
static constexpr uint32_t PrimarySize = 32;
static constexpr uint32_t MaxOutOfLine = 0;
static constexpr uint32_t AltPrimarySize = 32;
static constexpr uint32_t AltMaxOutOfLine = 0;
static constexpr bool HasFlexibleEnvelope = false;
static constexpr bool HasPointer = false;
static constexpr bool IsResource = false;
static constexpr ::fidl::internal::TransactionalMessageKind MessageKind =
::fidl::internal::TransactionalMessageKind::kRequest;
using ResponseType = MethodBResponse;
class UnownedEncodedMessage final {
public:
UnownedEncodedMessage(uint8_t* _bytes, uint32_t _byte_size,
zx_txid_t _txid, int64_t a, int64_t b)
: message_(_bytes, _byte_size, sizeof(MethodBRequest), nullptr, 0,
0) {
FIDL_ALIGNDECL MethodBRequest _request(_txid, a, b);
message_.LinearizeAndEncode<MethodBRequest>(&_request);
}
UnownedEncodedMessage(uint8_t* bytes, uint32_t byte_size,
MethodBRequest* request)
: message_(bytes, byte_size, sizeof(MethodBRequest), nullptr, 0, 0) {
message_.LinearizeAndEncode<MethodBRequest>(request);
}
UnownedEncodedMessage(const UnownedEncodedMessage&) = delete;
UnownedEncodedMessage(UnownedEncodedMessage&&) = delete;
UnownedEncodedMessage* operator=(const UnownedEncodedMessage&) = delete;
UnownedEncodedMessage* operator=(UnownedEncodedMessage&&) = delete;
zx_status_t status() const { return message_.status(); }
#ifdef __Fuchsia__
const char* status_string() const { return message_.status_string(); }
#endif
bool ok() const { return message_.status() == ZX_OK; }
const char* error() const { return message_.error(); }
::fidl::OutgoingMessage& GetOutgoingMessage() { return message_; }
void Write(zx_handle_t client) { message_.Write(client); }
private:
MethodBRequest& Message() {
return *reinterpret_cast<MethodBRequest*>(message_.bytes());
}
::fidl::OutgoingMessage message_;
};
class OwnedEncodedMessage final {
public:
explicit OwnedEncodedMessage(zx_txid_t _txid, int64_t a, int64_t b)
: message_(bytes_, sizeof(bytes_), _txid, a, b) {}
explicit OwnedEncodedMessage(MethodBRequest* request)
: message_(bytes_, sizeof(bytes_), request) {}
OwnedEncodedMessage(const OwnedEncodedMessage&) = delete;
OwnedEncodedMessage(OwnedEncodedMessage&&) = delete;
OwnedEncodedMessage* operator=(const OwnedEncodedMessage&) = delete;
OwnedEncodedMessage* operator=(OwnedEncodedMessage&&) = delete;
zx_status_t status() const { return message_.status(); }
#ifdef __Fuchsia__
const char* status_string() const { return message_.status_string(); }
#endif
bool ok() const { return message_.ok(); }
const char* error() const { return message_.error(); }
::fidl::OutgoingMessage& GetOutgoingMessage() {
return message_.GetOutgoingMessage();
}
void Write(zx_handle_t client) { message_.Write(client); }
private:
FIDL_ALIGNDECL
uint8_t bytes_[PrimarySize + MaxOutOfLine];
UnownedEncodedMessage message_;
};
class DecodedMessage final : public ::fidl::internal::IncomingMessage {
public:
DecodedMessage(uint8_t* bytes, uint32_t byte_actual,
zx_handle_info_t* handles = nullptr,
uint32_t handle_actual = 0)
: ::fidl::internal::IncomingMessage(bytes, byte_actual, handles,
handle_actual) {
Decode<MethodBRequest>();
}
DecodedMessage(fidl_incoming_msg_t* msg)
: ::fidl::internal::IncomingMessage(msg) {
Decode<MethodBRequest>();
}
DecodedMessage(const DecodedMessage&) = delete;
DecodedMessage(DecodedMessage&&) = delete;
DecodedMessage* operator=(const DecodedMessage&) = delete;
DecodedMessage* operator=(DecodedMessage&&) = delete;
MethodBRequest* PrimaryObject() {
ZX_DEBUG_ASSERT(ok());
return reinterpret_cast<MethodBRequest*>(bytes());
}
// Release the ownership of the decoded message. That means that the
// handles won't be closed When the object is destroyed. After calling
// this method, the DecodedMessage object should not be used anymore.
void ReleasePrimaryObject() { ResetBytes(); }
// These methods should only be used for testing purpose.
// They create an DecodedMessage using the bytes of an outgoing message
// and copying the handles.
static DecodedMessage FromOutgoingWithRawHandleCopy(
UnownedEncodedMessage* encoded_message) {
return DecodedMessage(encoded_message->GetOutgoingMessage());
}
static DecodedMessage FromOutgoingWithRawHandleCopy(
OwnedEncodedMessage* encoded_message) {
return DecodedMessage(encoded_message->GetOutgoingMessage());
}
private:
DecodedMessage(::fidl::OutgoingMessage& outgoing_message) {
Init(outgoing_message, nullptr, 0);
if (ok()) {
Decode<MethodBRequest>();
}
}
};
private:
void _InitHeader(zx_txid_t _txid);
};
struct TakeHandleResponse final {
FIDL_ALIGNDECL
fidl_message_header_t _hdr;
TakeHandleResponse() { _InitHeader(); }
static constexpr const fidl_type_t* Type =
&::fidl::_llcpp_coding_AnyZeroArgMessageTable;
static constexpr uint32_t MaxNumHandles = 0;
static constexpr uint32_t PrimarySize = 16;
static constexpr uint32_t MaxOutOfLine = 0;
static constexpr bool HasFlexibleEnvelope = false;
static constexpr bool HasPointer = false;
static constexpr bool IsResource = false;
static constexpr ::fidl::internal::TransactionalMessageKind MessageKind =
::fidl::internal::TransactionalMessageKind::kResponse;
class UnownedEncodedMessage final {
public:
UnownedEncodedMessage(uint8_t* _bytes, uint32_t _byte_size)
: message_(_bytes, _byte_size, sizeof(TakeHandleResponse), nullptr, 0,
0) {
FIDL_ALIGNDECL TakeHandleResponse _response{};
message_.LinearizeAndEncode<TakeHandleResponse>(&_response);
}
UnownedEncodedMessage(uint8_t* bytes, uint32_t byte_size,
TakeHandleResponse* response)
: message_(bytes, byte_size, sizeof(TakeHandleResponse), nullptr, 0,
0) {
message_.LinearizeAndEncode<TakeHandleResponse>(response);
}
UnownedEncodedMessage(const UnownedEncodedMessage&) = delete;
UnownedEncodedMessage(UnownedEncodedMessage&&) = delete;
UnownedEncodedMessage* operator=(const UnownedEncodedMessage&) = delete;
UnownedEncodedMessage* operator=(UnownedEncodedMessage&&) = delete;
zx_status_t status() const { return message_.status(); }
#ifdef __Fuchsia__
const char* status_string() const { return message_.status_string(); }
#endif
bool ok() const { return message_.status() == ZX_OK; }
const char* error() const { return message_.error(); }
::fidl::OutgoingMessage& GetOutgoingMessage() { return message_; }
void Write(zx_handle_t client) { message_.Write(client); }
private:
TakeHandleResponse& Message() {
return *reinterpret_cast<TakeHandleResponse*>(message_.bytes());
}
::fidl::OutgoingMessage message_;
};
class OwnedEncodedMessage final {
public:
explicit OwnedEncodedMessage() : message_(bytes_, sizeof(bytes_)) {}
explicit OwnedEncodedMessage(TakeHandleResponse* response)
: message_(bytes_, sizeof(bytes_), response) {}
OwnedEncodedMessage(const OwnedEncodedMessage&) = delete;
OwnedEncodedMessage(OwnedEncodedMessage&&) = delete;
OwnedEncodedMessage* operator=(const OwnedEncodedMessage&) = delete;
OwnedEncodedMessage* operator=(OwnedEncodedMessage&&) = delete;
zx_status_t status() const { return message_.status(); }
#ifdef __Fuchsia__
const char* status_string() const { return message_.status_string(); }
#endif
bool ok() const { return message_.ok(); }
const char* error() const { return message_.error(); }
::fidl::OutgoingMessage& GetOutgoingMessage() {
return message_.GetOutgoingMessage();
}
void Write(zx_handle_t client) { message_.Write(client); }
private:
FIDL_ALIGNDECL
uint8_t bytes_[PrimarySize + MaxOutOfLine];
UnownedEncodedMessage message_;
};
class DecodedMessage final : public ::fidl::internal::IncomingMessage {
public:
DecodedMessage(uint8_t* bytes, uint32_t byte_actual,
zx_handle_info_t* handles = nullptr,
uint32_t handle_actual = 0)
: ::fidl::internal::IncomingMessage(bytes, byte_actual, handles,
handle_actual) {
Decode<TakeHandleResponse>();
}
DecodedMessage(fidl_incoming_msg_t* msg)
: ::fidl::internal::IncomingMessage(msg) {
Decode<TakeHandleResponse>();
}
DecodedMessage(const DecodedMessage&) = delete;
DecodedMessage(DecodedMessage&&) = delete;
DecodedMessage* operator=(const DecodedMessage&) = delete;
DecodedMessage* operator=(DecodedMessage&&) = delete;
TakeHandleResponse* PrimaryObject() {
ZX_DEBUG_ASSERT(ok());
return reinterpret_cast<TakeHandleResponse*>(bytes());
}
// Release the ownership of the decoded message. That means that the
// handles won't be closed When the object is destroyed. After calling
// this method, the DecodedMessage object should not be used anymore.
void ReleasePrimaryObject() { ResetBytes(); }
// These methods should only be used for testing purpose.
// They create an DecodedMessage using the bytes of an outgoing message
// and copying the handles.
static DecodedMessage FromOutgoingWithRawHandleCopy(
UnownedEncodedMessage* outgoing_message) {
return DecodedMessage(outgoing_message->GetOutgoingMessage());
}
static DecodedMessage FromOutgoingWithRawHandleCopy(
OwnedEncodedMessage* outgoing_message) {
return DecodedMessage(outgoing_message->GetOutgoingMessage());
}
private:
DecodedMessage(::fidl::OutgoingMessage& outgoing_message) {
Init(outgoing_message, nullptr, 0);
if (ok()) {
Decode<TakeHandleResponse>();
}
}
};
private:
void _InitHeader();
};
struct TakeHandleRequest final {
FIDL_ALIGNDECL
fidl_message_header_t _hdr;
::zx::handle h;
explicit TakeHandleRequest(zx_txid_t _txid, ::zx::handle& h)
: h(std::move(h)) {
_InitHeader(_txid);
}
explicit TakeHandleRequest(zx_txid_t _txid) { _InitHeader(_txid); }
static constexpr const fidl_type_t* Type =
&fidl_test_protocols_ChannelProtocolTakeHandleRequestTable;
static constexpr uint32_t MaxNumHandles = 1;
static constexpr uint32_t PrimarySize = 24;
static constexpr uint32_t MaxOutOfLine = 0;
static constexpr uint32_t AltPrimarySize = 24;
static constexpr uint32_t AltMaxOutOfLine = 0;
static constexpr bool HasFlexibleEnvelope = false;
static constexpr bool HasPointer = false;
static constexpr bool IsResource = true;
static constexpr ::fidl::internal::TransactionalMessageKind MessageKind =
::fidl::internal::TransactionalMessageKind::kRequest;
void _CloseHandles();
class UnownedEncodedMessage final {
public:
UnownedEncodedMessage(uint8_t* _bytes, uint32_t _byte_size,
zx_txid_t _txid, ::zx::handle& h)
: message_(_bytes, _byte_size, sizeof(TakeHandleRequest), handles_,
std::min(ZX_CHANNEL_MAX_MSG_HANDLES, MaxNumHandles), 0) {
FIDL_ALIGNDECL TakeHandleRequest _request(_txid, h);
message_.LinearizeAndEncode<TakeHandleRequest>(&_request);
}
UnownedEncodedMessage(uint8_t* bytes, uint32_t byte_size,
TakeHandleRequest* request)
: message_(bytes, byte_size, sizeof(TakeHandleRequest), handles_,
std::min(ZX_CHANNEL_MAX_MSG_HANDLES, MaxNumHandles), 0) {
message_.LinearizeAndEncode<TakeHandleRequest>(request);
}
UnownedEncodedMessage(const UnownedEncodedMessage&) = delete;
UnownedEncodedMessage(UnownedEncodedMessage&&) = delete;
UnownedEncodedMessage* operator=(const UnownedEncodedMessage&) = delete;
UnownedEncodedMessage* operator=(UnownedEncodedMessage&&) = delete;
zx_status_t status() const { return message_.status(); }
#ifdef __Fuchsia__
const char* status_string() const { return message_.status_string(); }
#endif
bool ok() const { return message_.status() == ZX_OK; }
const char* error() const { return message_.error(); }
::fidl::OutgoingMessage& GetOutgoingMessage() { return message_; }
void Write(zx_handle_t client) { message_.Write(client); }
private:
TakeHandleRequest& Message() {
return *reinterpret_cast<TakeHandleRequest*>(message_.bytes());
}
zx_handle_disposition_t
handles_[std::min(ZX_CHANNEL_MAX_MSG_HANDLES, MaxNumHandles)];
::fidl::OutgoingMessage message_;
};
class OwnedEncodedMessage final {
public:
explicit OwnedEncodedMessage(zx_txid_t _txid, ::zx::handle& h)
: message_(bytes_, sizeof(bytes_), _txid, h) {}
explicit OwnedEncodedMessage(TakeHandleRequest* request)
: message_(bytes_, sizeof(bytes_), request) {}
OwnedEncodedMessage(const OwnedEncodedMessage&) = delete;
OwnedEncodedMessage(OwnedEncodedMessage&&) = delete;
OwnedEncodedMessage* operator=(const OwnedEncodedMessage&) = delete;
OwnedEncodedMessage* operator=(OwnedEncodedMessage&&) = delete;
zx_status_t status() const { return message_.status(); }
#ifdef __Fuchsia__
const char* status_string() const { return message_.status_string(); }
#endif
bool ok() const { return message_.ok(); }
const char* error() const { return message_.error(); }
::fidl::OutgoingMessage& GetOutgoingMessage() {
return message_.GetOutgoingMessage();
}
void Write(zx_handle_t client) { message_.Write(client); }
private:
FIDL_ALIGNDECL
uint8_t bytes_[PrimarySize + MaxOutOfLine];
UnownedEncodedMessage message_;
};
class DecodedMessage final : public ::fidl::internal::IncomingMessage {
public:
DecodedMessage(uint8_t* bytes, uint32_t byte_actual,
zx_handle_info_t* handles = nullptr,
uint32_t handle_actual = 0)
: ::fidl::internal::IncomingMessage(bytes, byte_actual, handles,
handle_actual) {
Decode<TakeHandleRequest>();
}
DecodedMessage(fidl_incoming_msg_t* msg)
: ::fidl::internal::IncomingMessage(msg) {
Decode<TakeHandleRequest>();
}
DecodedMessage(const DecodedMessage&) = delete;
DecodedMessage(DecodedMessage&&) = delete;
DecodedMessage* operator=(const DecodedMessage&) = delete;
DecodedMessage* operator=(DecodedMessage&&) = delete;
~DecodedMessage() {
if (ok() && (PrimaryObject() != nullptr)) {
PrimaryObject()->_CloseHandles();
}
}
TakeHandleRequest* PrimaryObject() {
ZX_DEBUG_ASSERT(ok());
return reinterpret_cast<TakeHandleRequest*>(bytes());
}
// Release the ownership of the decoded message. That means that the
// handles won't be closed When the object is destroyed. After calling
// this method, the DecodedMessage object should not be used anymore.
void ReleasePrimaryObject() { ResetBytes(); }
// These methods should only be used for testing purpose.
// They create an DecodedMessage using the bytes of an outgoing message
// and copying the handles.
static DecodedMessage FromOutgoingWithRawHandleCopy(
UnownedEncodedMessage* encoded_message) {
return DecodedMessage(encoded_message->GetOutgoingMessage());
}
static DecodedMessage FromOutgoingWithRawHandleCopy(
OwnedEncodedMessage* encoded_message) {
return DecodedMessage(encoded_message->GetOutgoingMessage());
}
private:
DecodedMessage(::fidl::OutgoingMessage& outgoing_message) {
zx_handle_info_t
handles[std::min(ZX_CHANNEL_MAX_MSG_HANDLES, MaxNumHandles)];
Init(outgoing_message, handles,
std::min(ZX_CHANNEL_MAX_MSG_HANDLES, MaxNumHandles));
if (ok()) {
Decode<TakeHandleRequest>();
}
}
};
private:
void _InitHeader(zx_txid_t _txid);
};
struct MutateSocketResponse final {
FIDL_ALIGNDECL
fidl_message_header_t _hdr;
::zx::socket b;
explicit MutateSocketResponse(::zx::socket& b) : b(std::move(b)) {
_InitHeader();
}
MutateSocketResponse() { _InitHeader(); }
static constexpr const fidl_type_t* Type =
&fidl_test_protocols_ChannelProtocolMutateSocketResponseTable;
static constexpr uint32_t MaxNumHandles = 1;
static constexpr uint32_t PrimarySize = 24;
static constexpr uint32_t MaxOutOfLine = 0;
static constexpr bool HasFlexibleEnvelope = false;
static constexpr bool HasPointer = false;
static constexpr bool IsResource = true;
static constexpr ::fidl::internal::TransactionalMessageKind MessageKind =
::fidl::internal::TransactionalMessageKind::kResponse;
void _CloseHandles();
class UnownedEncodedMessage final {
public:
UnownedEncodedMessage(uint8_t* _bytes, uint32_t _byte_size,
::zx::socket& b)
: message_(_bytes, _byte_size, sizeof(MutateSocketResponse), handles_,
std::min(ZX_CHANNEL_MAX_MSG_HANDLES, MaxNumHandles), 0) {
FIDL_ALIGNDECL MutateSocketResponse _response{b};
message_.LinearizeAndEncode<MutateSocketResponse>(&_response);
}
UnownedEncodedMessage(uint8_t* bytes, uint32_t byte_size,
MutateSocketResponse* response)
: message_(bytes, byte_size, sizeof(MutateSocketResponse), handles_,
std::min(ZX_CHANNEL_MAX_MSG_HANDLES, MaxNumHandles), 0) {
message_.LinearizeAndEncode<MutateSocketResponse>(response);
}
UnownedEncodedMessage(const UnownedEncodedMessage&) = delete;
UnownedEncodedMessage(UnownedEncodedMessage&&) = delete;
UnownedEncodedMessage* operator=(const UnownedEncodedMessage&) = delete;
UnownedEncodedMessage* operator=(UnownedEncodedMessage&&) = delete;
zx_status_t status() const { return message_.status(); }
#ifdef __Fuchsia__
const char* status_string() const { return message_.status_string(); }
#endif
bool ok() const { return message_.status() == ZX_OK; }
const char* error() const { return message_.error(); }
::fidl::OutgoingMessage& GetOutgoingMessage() { return message_; }
void Write(zx_handle_t client) { message_.Write(client); }
private:
MutateSocketResponse& Message() {
return *reinterpret_cast<MutateSocketResponse*>(message_.bytes());
}
zx_handle_disposition_t
handles_[std::min(ZX_CHANNEL_MAX_MSG_HANDLES, MaxNumHandles)];
::fidl::OutgoingMessage message_;
};
class OwnedEncodedMessage final {
public:
explicit OwnedEncodedMessage(::zx::socket& b)
: message_(bytes_, sizeof(bytes_), b) {}
explicit OwnedEncodedMessage(MutateSocketResponse* response)
: message_(bytes_, sizeof(bytes_), response) {}
OwnedEncodedMessage(const OwnedEncodedMessage&) = delete;
OwnedEncodedMessage(OwnedEncodedMessage&&) = delete;
OwnedEncodedMessage* operator=(const OwnedEncodedMessage&) = delete;
OwnedEncodedMessage* operator=(OwnedEncodedMessage&&) = delete;
zx_status_t status() const { return message_.status(); }
#ifdef __Fuchsia__
const char* status_string() const { return message_.status_string(); }
#endif
bool ok() const { return message_.ok(); }
const char* error() const { return message_.error(); }
::fidl::OutgoingMessage& GetOutgoingMessage() {
return message_.GetOutgoingMessage();
}
void Write(zx_handle_t client) { message_.Write(client); }
private:
FIDL_ALIGNDECL
uint8_t bytes_[PrimarySize + MaxOutOfLine];
UnownedEncodedMessage message_;
};
class DecodedMessage final : public ::fidl::internal::IncomingMessage {
public:
DecodedMessage(uint8_t* bytes, uint32_t byte_actual,
zx_handle_info_t* handles = nullptr,
uint32_t handle_actual = 0)
: ::fidl::internal::IncomingMessage(bytes, byte_actual, handles,
handle_actual) {
Decode<MutateSocketResponse>();
}
DecodedMessage(fidl_incoming_msg_t* msg)
: ::fidl::internal::IncomingMessage(msg) {
Decode<MutateSocketResponse>();
}
DecodedMessage(const DecodedMessage&) = delete;
DecodedMessage(DecodedMessage&&) = delete;
DecodedMessage* operator=(const DecodedMessage&) = delete;
DecodedMessage* operator=(DecodedMessage&&) = delete;
~DecodedMessage() {
if (ok() && (PrimaryObject() != nullptr)) {
PrimaryObject()->_CloseHandles();
}
}
MutateSocketResponse* PrimaryObject() {
ZX_DEBUG_ASSERT(ok());
return reinterpret_cast<MutateSocketResponse*>(bytes());
}
// Release the ownership of the decoded message. That means that the
// handles won't be closed When the object is destroyed. After calling
// this method, the DecodedMessage object should not be used anymore.
void ReleasePrimaryObject() { ResetBytes(); }
// These methods should only be used for testing purpose.
// They create an DecodedMessage using the bytes of an outgoing message
// and copying the handles.
static DecodedMessage FromOutgoingWithRawHandleCopy(
UnownedEncodedMessage* outgoing_message) {
return DecodedMessage(outgoing_message->GetOutgoingMessage());
}
static DecodedMessage FromOutgoingWithRawHandleCopy(
OwnedEncodedMessage* outgoing_message) {
return DecodedMessage(outgoing_message->GetOutgoingMessage());
}
private:
DecodedMessage(::fidl::OutgoingMessage& outgoing_message) {
zx_handle_info_t
handles[std::min(ZX_CHANNEL_MAX_MSG_HANDLES, MaxNumHandles)];
Init(outgoing_message, handles,
std::min(ZX_CHANNEL_MAX_MSG_HANDLES, MaxNumHandles));
if (ok()) {
Decode<MutateSocketResponse>();
}
}
};
private:
void _InitHeader();
};
struct MutateSocketRequest final {
FIDL_ALIGNDECL
fidl_message_header_t _hdr;
::zx::socket a;
explicit MutateSocketRequest(zx_txid_t _txid, ::zx::socket& a)
: a(std::move(a)) {
_InitHeader(_txid);
}
explicit MutateSocketRequest(zx_txid_t _txid) { _InitHeader(_txid); }
static constexpr const fidl_type_t* Type =
&fidl_test_protocols_ChannelProtocolMutateSocketRequestTable;
static constexpr uint32_t MaxNumHandles = 1;
static constexpr uint32_t PrimarySize = 24;
static constexpr uint32_t MaxOutOfLine = 0;
static constexpr uint32_t AltPrimarySize = 24;
static constexpr uint32_t AltMaxOutOfLine = 0;
static constexpr bool HasFlexibleEnvelope = false;
static constexpr bool HasPointer = false;
static constexpr bool IsResource = true;
static constexpr ::fidl::internal::TransactionalMessageKind MessageKind =
::fidl::internal::TransactionalMessageKind::kRequest;
using ResponseType = MutateSocketResponse;
void _CloseHandles();
class UnownedEncodedMessage final {
public:
UnownedEncodedMessage(uint8_t* _bytes, uint32_t _byte_size,
zx_txid_t _txid, ::zx::socket& a)
: message_(_bytes, _byte_size, sizeof(MutateSocketRequest), handles_,
std::min(ZX_CHANNEL_MAX_MSG_HANDLES, MaxNumHandles), 0) {
FIDL_ALIGNDECL MutateSocketRequest _request(_txid, a);
message_.LinearizeAndEncode<MutateSocketRequest>(&_request);
}
UnownedEncodedMessage(uint8_t* bytes, uint32_t byte_size,
MutateSocketRequest* request)
: message_(bytes, byte_size, sizeof(MutateSocketRequest), handles_,
std::min(ZX_CHANNEL_MAX_MSG_HANDLES, MaxNumHandles), 0) {
message_.LinearizeAndEncode<MutateSocketRequest>(request);
}
UnownedEncodedMessage(const UnownedEncodedMessage&) = delete;
UnownedEncodedMessage(UnownedEncodedMessage&&) = delete;
UnownedEncodedMessage* operator=(const UnownedEncodedMessage&) = delete;
UnownedEncodedMessage* operator=(UnownedEncodedMessage&&) = delete;
zx_status_t status() const { return message_.status(); }
#ifdef __Fuchsia__
const char* status_string() const { return message_.status_string(); }
#endif
bool ok() const { return message_.status() == ZX_OK; }
const char* error() const { return message_.error(); }
::fidl::OutgoingMessage& GetOutgoingMessage() { return message_; }
void Write(zx_handle_t client) { message_.Write(client); }
private:
MutateSocketRequest& Message() {
return *reinterpret_cast<MutateSocketRequest*>(message_.bytes());
}
zx_handle_disposition_t
handles_[std::min(ZX_CHANNEL_MAX_MSG_HANDLES, MaxNumHandles)];
::fidl::OutgoingMessage message_;
};
class OwnedEncodedMessage final {
public:
explicit OwnedEncodedMessage(zx_txid_t _txid, ::zx::socket& a)
: message_(bytes_, sizeof(bytes_), _txid, a) {}
explicit OwnedEncodedMessage(MutateSocketRequest* request)
: message_(bytes_, sizeof(bytes_), request) {}
OwnedEncodedMessage(const OwnedEncodedMessage&) = delete;
OwnedEncodedMessage(OwnedEncodedMessage&&) = delete;
OwnedEncodedMessage* operator=(const OwnedEncodedMessage&) = delete;
OwnedEncodedMessage* operator=(OwnedEncodedMessage&&) = delete;
zx_status_t status() const { return message_.status(); }
#ifdef __Fuchsia__
const char* status_string() const { return message_.status_string(); }
#endif
bool ok() const { return message_.ok(); }
const char* error() const { return message_.error(); }
::fidl::OutgoingMessage& GetOutgoingMessage() {
return message_.GetOutgoingMessage();
}
void Write(zx_handle_t client) { message_.Write(client); }
private:
FIDL_ALIGNDECL
uint8_t bytes_[PrimarySize + MaxOutOfLine];
UnownedEncodedMessage message_;
};
class DecodedMessage final : public ::fidl::internal::IncomingMessage {
public:
DecodedMessage(uint8_t* bytes, uint32_t byte_actual,
zx_handle_info_t* handles = nullptr,
uint32_t handle_actual = 0)
: ::fidl::internal::IncomingMessage(bytes, byte_actual, handles,
handle_actual) {
Decode<MutateSocketRequest>();
}
DecodedMessage(fidl_incoming_msg_t* msg)
: ::fidl::internal::IncomingMessage(msg) {
Decode<MutateSocketRequest>();
}
DecodedMessage(const DecodedMessage&) = delete;
DecodedMessage(DecodedMessage&&) = delete;
DecodedMessage* operator=(const DecodedMessage&) = delete;
DecodedMessage* operator=(DecodedMessage&&) = delete;
~DecodedMessage() {
if (ok() && (PrimaryObject() != nullptr)) {
PrimaryObject()->_CloseHandles();
}
}
MutateSocketRequest* PrimaryObject() {
ZX_DEBUG_ASSERT(ok());
return reinterpret_cast<MutateSocketRequest*>(bytes());
}
// Release the ownership of the decoded message. That means that the
// handles won't be closed When the object is destroyed. After calling
// this method, the DecodedMessage object should not be used anymore.
void ReleasePrimaryObject() { ResetBytes(); }
// These methods should only be used for testing purpose.
// They create an DecodedMessage using the bytes of an outgoing message
// and copying the handles.
static DecodedMessage FromOutgoingWithRawHandleCopy(
UnownedEncodedMessage* encoded_message) {
return DecodedMessage(encoded_message->GetOutgoingMessage());
}
static DecodedMessage FromOutgoingWithRawHandleCopy(
OwnedEncodedMessage* encoded_message) {
return DecodedMessage(encoded_message->GetOutgoingMessage());
}
private:
DecodedMessage(::fidl::OutgoingMessage& outgoing_message) {
zx_handle_info_t
handles[std::min(ZX_CHANNEL_MAX_MSG_HANDLES, MaxNumHandles)];
Init(outgoing_message, handles,
std::min(ZX_CHANNEL_MAX_MSG_HANDLES, MaxNumHandles));
if (ok()) {
Decode<MutateSocketRequest>();
}
}
};
private:
void _InitHeader(zx_txid_t _txid);
};
class EventHandler {
public:
EventHandler() = default;
virtual ~EventHandler() = default;
virtual void EventA(EventAResponse* event) = 0;
// Method called when an unknown event is found. This methods gives the
// status which, in this case, is returned by HandleOneEvent.
virtual zx_status_t Unknown() = 0;
// Handle all possible events defined in this protocol.
// Blocks to consume exactly one message from the channel, then call the
// corresponding virtual method.
::fidl::Result HandleOneEvent(::zx::unowned_channel client_end);
};
// Collection of return types of FIDL calls in this protocol.
class ResultOf final {
ResultOf() = delete;
public:
class MethodA final : public ::fidl::Result {
public:
explicit MethodA(zx_handle_t _client, int64_t a, int64_t b);
explicit MethodA(const ::fidl::Result& result) : ::fidl::Result(result) {}
MethodA(MethodA&&) = delete;
MethodA(const MethodA&) = delete;
MethodA* operator=(MethodA&&) = delete;
MethodA* operator=(const MethodA&) = delete;
~MethodA() = default;
private:
};
class MethodB final : public ::fidl::Result {
public:
explicit MethodB(zx_handle_t _client, int64_t a, int64_t b);
MethodB(zx_handle_t _client, int64_t a, int64_t b, zx_time_t _deadline);
explicit MethodB(const ::fidl::Result& result) : ::fidl::Result(result) {}
MethodB(MethodB&&) = delete;
MethodB(const MethodB&) = delete;
MethodB* operator=(MethodB&&) = delete;
MethodB* operator=(const MethodB&) = delete;
~MethodB() = default;
MethodBResponse* Unwrap() {
ZX_DEBUG_ASSERT(ok());
return reinterpret_cast<MethodBResponse*>(bytes_);
}
const MethodBResponse* Unwrap() const {
ZX_DEBUG_ASSERT(ok());
return reinterpret_cast<const MethodBResponse*>(bytes_);
}
MethodBResponse& value() { return *Unwrap(); }
const MethodBResponse& value() const { return *Unwrap(); }
MethodBResponse* operator->() { return &value(); }
const MethodBResponse* operator->() const { return &value(); }
MethodBResponse& operator*() { return value(); }
const MethodBResponse& operator*() const { return value(); }
private:
FIDL_ALIGNDECL
uint8_t
bytes_[MethodBResponse::PrimarySize + MethodBResponse::MaxOutOfLine];
};
class TakeHandle final : public ::fidl::Result {
public:
explicit TakeHandle(zx_handle_t _client, ::zx::handle& h);
TakeHandle(zx_handle_t _client, ::zx::handle& h, zx_time_t _deadline);
explicit TakeHandle(const ::fidl::Result& result)
: ::fidl::Result(result) {}
TakeHandle(TakeHandle&&) = delete;
TakeHandle(const TakeHandle&) = delete;
TakeHandle* operator=(TakeHandle&&) = delete;
TakeHandle* operator=(const TakeHandle&) = delete;
~TakeHandle() = default;
TakeHandleResponse* Unwrap() {
ZX_DEBUG_ASSERT(ok());
return reinterpret_cast<TakeHandleResponse*>(bytes_);
}
const TakeHandleResponse* Unwrap() const {
ZX_DEBUG_ASSERT(ok());
return reinterpret_cast<const TakeHandleResponse*>(bytes_);
}
TakeHandleResponse& value() { return *Unwrap(); }
const TakeHandleResponse& value() const { return *Unwrap(); }
TakeHandleResponse* operator->() { return &value(); }
const TakeHandleResponse* operator->() const { return &value(); }
TakeHandleResponse& operator*() { return value(); }
const TakeHandleResponse& operator*() const { return value(); }
private:
FIDL_ALIGNDECL
uint8_t bytes_[TakeHandleResponse::PrimarySize +
TakeHandleResponse::MaxOutOfLine];
};
class MutateSocket final : public ::fidl::Result {
public:
explicit MutateSocket(zx_handle_t _client, ::zx::socket& a);
MutateSocket(zx_handle_t _client, ::zx::socket& a, zx_time_t _deadline);
explicit MutateSocket(const ::fidl::Result& result)
: ::fidl::Result(result) {}
MutateSocket(MutateSocket&&) = delete;
MutateSocket(const MutateSocket&) = delete;
MutateSocket* operator=(MutateSocket&&) = delete;
MutateSocket* operator=(const MutateSocket&) = delete;
~MutateSocket() {
if (ok()) {
Unwrap()->_CloseHandles();
}
}
MutateSocketResponse* Unwrap() {
ZX_DEBUG_ASSERT(ok());
return reinterpret_cast<MutateSocketResponse*>(bytes_);
}
const MutateSocketResponse* Unwrap() const {
ZX_DEBUG_ASSERT(ok());
return reinterpret_cast<const MutateSocketResponse*>(bytes_);
}
MutateSocketResponse& value() { return *Unwrap(); }
const MutateSocketResponse& value() const { return *Unwrap(); }
MutateSocketResponse* operator->() { return &value(); }
const MutateSocketResponse* operator->() const { return &value(); }
MutateSocketResponse& operator*() { return value(); }
const MutateSocketResponse& operator*() const { return value(); }
private:
FIDL_ALIGNDECL
uint8_t bytes_[MutateSocketResponse::PrimarySize +
MutateSocketResponse::MaxOutOfLine];
};
};
// Collection of return types of FIDL calls in this protocol,
// when the caller-allocate flavor or in-place call is used.
class UnownedResultOf final {
UnownedResultOf() = delete;
public:
class MethodA final : public ::fidl::Result {
public:
explicit MethodA(zx_handle_t _client, uint8_t* _request_bytes,
uint32_t _request_byte_capacity, int64_t a, int64_t b);
explicit MethodA(const ::fidl::Result& result) : ::fidl::Result(result) {}
MethodA(MethodA&&) = delete;
MethodA(const MethodA&) = delete;
MethodA* operator=(MethodA&&) = delete;
MethodA* operator=(const MethodA&) = delete;
~MethodA() = default;
};
class MethodB final : public ::fidl::Result {
public:
explicit MethodB(zx_handle_t _client, uint8_t* _request_bytes,
uint32_t _request_byte_capacity, int64_t a, int64_t b,
uint8_t* _response_bytes,
uint32_t _response_byte_capacity);
explicit MethodB(const ::fidl::Result& result) : ::fidl::Result(result) {}
MethodB(MethodB&&) = delete;
MethodB(const MethodB&) = delete;
MethodB* operator=(MethodB&&) = delete;
MethodB* operator=(const MethodB&) = delete;
~MethodB() = default;
MethodBResponse* Unwrap() {
ZX_DEBUG_ASSERT(ok());
return reinterpret_cast<MethodBResponse*>(bytes_);
}
const MethodBResponse* Unwrap() const {
ZX_DEBUG_ASSERT(ok());
return reinterpret_cast<const MethodBResponse*>(bytes_);
}
MethodBResponse& value() { return *Unwrap(); }
const MethodBResponse& value() const { return *Unwrap(); }
MethodBResponse* operator->() { return &value(); }
const MethodBResponse* operator->() const { return &value(); }
MethodBResponse& operator*() { return value(); }
const MethodBResponse& operator*() const { return value(); }
private:
uint8_t* bytes_;
};
class TakeHandle final : public ::fidl::Result {
public:
explicit TakeHandle(zx_handle_t _client, uint8_t* _request_bytes,
uint32_t _request_byte_capacity, ::zx::handle& h,
uint8_t* _response_bytes,
uint32_t _response_byte_capacity);
explicit TakeHandle(const ::fidl::Result& result)
: ::fidl::Result(result) {}
TakeHandle(TakeHandle&&) = delete;
TakeHandle(const TakeHandle&) = delete;
TakeHandle* operator=(TakeHandle&&) = delete;
TakeHandle* operator=(const TakeHandle&) = delete;
~TakeHandle() = default;
TakeHandleResponse* Unwrap() {
ZX_DEBUG_ASSERT(ok());
return reinterpret_cast<TakeHandleResponse*>(bytes_);
}
const TakeHandleResponse* Unwrap() const {
ZX_DEBUG_ASSERT(ok());
return reinterpret_cast<const TakeHandleResponse*>(bytes_);
}
TakeHandleResponse& value() { return *Unwrap(); }
const TakeHandleResponse& value() const { return *Unwrap(); }
TakeHandleResponse* operator->() { return &value(); }
const TakeHandleResponse* operator->() const { return &value(); }
TakeHandleResponse& operator*() { return value(); }
const TakeHandleResponse& operator*() const { return value(); }
private:
uint8_t* bytes_;
};
class MutateSocket final : public ::fidl::Result {
public:
explicit MutateSocket(zx_handle_t _client, uint8_t* _request_bytes,
uint32_t _request_byte_capacity, ::zx::socket& a,
uint8_t* _response_bytes,
uint32_t _response_byte_capacity);
explicit MutateSocket(const ::fidl::Result& result)
: ::fidl::Result(result) {}
MutateSocket(MutateSocket&&) = delete;
MutateSocket(const MutateSocket&) = delete;
MutateSocket* operator=(MutateSocket&&) = delete;
MutateSocket* operator=(const MutateSocket&) = delete;
~MutateSocket() {
if (ok()) {
Unwrap()->_CloseHandles();
}
}
MutateSocketResponse* Unwrap() {
ZX_DEBUG_ASSERT(ok());
return reinterpret_cast<MutateSocketResponse*>(bytes_);
}
const MutateSocketResponse* Unwrap() const {
ZX_DEBUG_ASSERT(ok());
return reinterpret_cast<const MutateSocketResponse*>(bytes_);
}
MutateSocketResponse& value() { return *Unwrap(); }
const MutateSocketResponse& value() const { return *Unwrap(); }
MutateSocketResponse* operator->() { return &value(); }
const MutateSocketResponse* operator->() const { return &value(); }
MutateSocketResponse& operator*() { return value(); }
const MutateSocketResponse& operator*() const { return value(); }
private:
uint8_t* bytes_;
};
};
// Methods to make a sync FIDL call directly on an unowned channel, avoiding
// setting up a client.
class Call final {
Call() = delete;
public:
// Allocates 32 bytes of message buffer on the stack. No heap allocation
// necessary.
static ResultOf::MethodA MethodA(::zx::unowned_channel _client_end,
int64_t a, int64_t b) {
return ResultOf::MethodA(_client_end->get(), a, b);
}
// Caller provides the backing storage for FIDL message via request and
// response buffers.
static UnownedResultOf::MethodA MethodA(::zx::unowned_channel _client_end,
::fidl::BufferSpan _request_buffer,
int64_t a, int64_t b) {
return UnownedResultOf::MethodA(_client_end->get(), _request_buffer.data,
_request_buffer.capacity, a, b);
}
// Allocates 56 bytes of message buffer on the stack. No heap allocation
// necessary.
static ResultOf::MethodB MethodB(::zx::unowned_channel _client_end,
int64_t a, int64_t b) {
return ResultOf::MethodB(_client_end->get(), a, b);
}
// Caller provides the backing storage for FIDL message via request and
// response buffers.
static UnownedResultOf::MethodB MethodB(
::zx::unowned_channel _client_end, ::fidl::BufferSpan _request_buffer,
int64_t a, int64_t b, ::fidl::BufferSpan _response_buffer) {
return UnownedResultOf::MethodB(
_client_end->get(), _request_buffer.data, _request_buffer.capacity, a,
b, _response_buffer.data, _response_buffer.capacity);
}
// Allocates 40 bytes of message buffer on the stack. No heap allocation
// necessary.
static ResultOf::TakeHandle TakeHandle(::zx::unowned_channel _client_end,
::zx::handle h) {
return ResultOf::TakeHandle(_client_end->get(), h);
}
// Caller provides the backing storage for FIDL message via request and
// response buffers.
static UnownedResultOf::TakeHandle TakeHandle(
::zx::unowned_channel _client_end, ::fidl::BufferSpan _request_buffer,
::zx::handle h, ::fidl::BufferSpan _response_buffer) {
return UnownedResultOf::TakeHandle(
_client_end->get(), _request_buffer.data, _request_buffer.capacity, h,
_response_buffer.data, _response_buffer.capacity);
}
// Allocates 48 bytes of message buffer on the stack. No heap allocation
// necessary.
static ResultOf::MutateSocket MutateSocket(
::zx::unowned_channel _client_end, ::zx::socket a) {
return ResultOf::MutateSocket(_client_end->get(), a);
}
// Caller provides the backing storage for FIDL message via request and
// response buffers.
static UnownedResultOf::MutateSocket MutateSocket(
::zx::unowned_channel _client_end, ::fidl::BufferSpan _request_buffer,
::zx::socket a, ::fidl::BufferSpan _response_buffer) {
return UnownedResultOf::MutateSocket(
_client_end->get(), _request_buffer.data, _request_buffer.capacity, a,
_response_buffer.data, _response_buffer.capacity);
}
};
class SyncClient final {
public:
SyncClient() = default;
explicit SyncClient(::zx::channel channel) : channel_(std::move(channel)) {}
~SyncClient() = default;
SyncClient(SyncClient&&) = default;
SyncClient& operator=(SyncClient&&) = default;
const ::zx::channel& channel() const { return channel_; }
::zx::channel* mutable_channel() { return &channel_; }
// Allocates 32 bytes of message buffer on the stack. No heap allocation
// necessary.
ResultOf::MethodA MethodA(int64_t a, int64_t b) {
return ResultOf::MethodA(this->channel().get(), a, b);
}
// Caller provides the backing storage for FIDL message via request and
// response buffers.
UnownedResultOf::MethodA MethodA(::fidl::BufferSpan _request_buffer,
int64_t a, int64_t b) {
return UnownedResultOf::MethodA(this->channel().get(),
_request_buffer.data,
_request_buffer.capacity, a, b);
}
// Allocates 56 bytes of message buffer on the stack. No heap allocation
// necessary.
ResultOf::MethodB MethodB(int64_t a, int64_t b) {
return ResultOf::MethodB(this->channel().get(), a, b);
}
// Caller provides the backing storage for FIDL message via request and
// response buffers.
UnownedResultOf::MethodB MethodB(::fidl::BufferSpan _request_buffer,
int64_t a, int64_t b,
::fidl::BufferSpan _response_buffer) {
return UnownedResultOf::MethodB(
this->channel().get(), _request_buffer.data, _request_buffer.capacity,
a, b, _response_buffer.data, _response_buffer.capacity);
}
// Allocates 40 bytes of message buffer on the stack. No heap allocation
// necessary.
ResultOf::TakeHandle TakeHandle(::zx::handle h) {
return ResultOf::TakeHandle(this->channel().get(), h);
}
// Caller provides the backing storage for FIDL message via request and
// response buffers.
UnownedResultOf::TakeHandle TakeHandle(
::fidl::BufferSpan _request_buffer, ::zx::handle h,
::fidl::BufferSpan _response_buffer) {
return UnownedResultOf::TakeHandle(
this->channel().get(), _request_buffer.data, _request_buffer.capacity,
h, _response_buffer.data, _response_buffer.capacity);
}
// Allocates 48 bytes of message buffer on the stack. No heap allocation
// necessary.
ResultOf::MutateSocket MutateSocket(::zx::socket a) {
return ResultOf::MutateSocket(this->channel().get(), a);
}
// Caller provides the backing storage for FIDL message via request and
// response buffers.
UnownedResultOf::MutateSocket MutateSocket(
::fidl::BufferSpan _request_buffer, ::zx::socket a,
::fidl::BufferSpan _response_buffer) {
return UnownedResultOf::MutateSocket(
this->channel().get(), _request_buffer.data, _request_buffer.capacity,
a, _response_buffer.data, _response_buffer.capacity);
}
// Handle all possible events defined in this protocol.
// Blocks to consume exactly one message from the channel, then call the
// corresponding virtual method defined in |EventHandler|. The return status
// of the handler function is folded with any transport-level errors and
// returned.
::fidl::Result HandleOneEvent(EventHandler& event_handler) {
return event_handler.HandleOneEvent(::zx::unowned_channel(channel_));
}
private:
::zx::channel channel_;
};
struct AsyncEventHandlers;
class MethodBResponseContext;
class TakeHandleResponseContext;
class MutateSocketResponseContext;
class ClientImpl;
// Pure-virtual interface to be implemented by a server.
class Interface : public ::fidl::internal::IncomingMessageDispatcher {
public:
Interface() = default;
virtual ~Interface() = default;
// The marker protocol type within which this |Interface| class is defined.
using _EnclosingProtocol = ChannelProtocol;
using MethodACompleter = ::fidl::Completer<>;
virtual void MethodA(int64_t a, int64_t b,
MethodACompleter::Sync& _completer) = 0;
class MethodBCompleterBase : public ::fidl::CompleterBase {
public:
// In the following methods, the return value indicates internal errors
// during the reply, such as encoding or writing to the transport. Note
// that any error will automatically lead to the destruction of the
// binding, after which the |on_unbound| callback will be triggered with a
// detailed reason.
//
// See //zircon/system/ulib/fidl/include/lib/fidl/llcpp/server.h.
//
// Because the reply status is identical to the unbinding status, it can
// be safely ignored.
::fidl::Result Reply(int64_t result);
::fidl::Result Reply(::fidl::BufferSpan _buffer, int64_t result);
protected:
using ::fidl::CompleterBase::CompleterBase;
};
using MethodBCompleter = ::fidl::Completer<MethodBCompleterBase>;
virtual void MethodB(int64_t a, int64_t b,
MethodBCompleter::Sync& _completer) = 0;
class TakeHandleCompleterBase : public ::fidl::CompleterBase {
public:
// In the following methods, the return value indicates internal errors
// during the reply, such as encoding or writing to the transport. Note
// that any error will automatically lead to the destruction of the
// binding, after which the |on_unbound| callback will be triggered with a
// detailed reason.
//
// See //zircon/system/ulib/fidl/include/lib/fidl/llcpp/server.h.
//
// Because the reply status is identical to the unbinding status, it can
// be safely ignored.
::fidl::Result Reply();
protected:
using ::fidl::CompleterBase::CompleterBase;
};
using TakeHandleCompleter = ::fidl::Completer<TakeHandleCompleterBase>;
virtual void TakeHandle(::zx::handle h,
TakeHandleCompleter::Sync& _completer) = 0;
class MutateSocketCompleterBase : public ::fidl::CompleterBase {
public:
// In the following methods, the return value indicates internal errors
// during the reply, such as encoding or writing to the transport. Note
// that any error will automatically lead to the destruction of the
// binding, after which the |on_unbound| callback will be triggered with a
// detailed reason.
//
// See //zircon/system/ulib/fidl/include/lib/fidl/llcpp/server.h.
//
// Because the reply status is identical to the unbinding status, it can
// be safely ignored.
::fidl::Result Reply(::zx::socket b);
::fidl::Result Reply(::fidl::BufferSpan _buffer, ::zx::socket b);
protected:
using ::fidl::CompleterBase::CompleterBase;
};
using MutateSocketCompleter = ::fidl::Completer<MutateSocketCompleterBase>;
virtual void MutateSocket(::zx::socket a,
MutateSocketCompleter::Sync& _completer) = 0;
private:
::fidl::DispatchResult dispatch_message(fidl_incoming_msg_t* msg,
::fidl::Transaction* txn) final;
};
// Attempts to dispatch the incoming message to a handler function in the
// server implementation. If there is no matching handler, it returns false,
// leaving the message and transaction intact. In all other cases, it consumes
// the message and returns true. It is possible to chain multiple TryDispatch
// functions in this manner.
static ::fidl::DispatchResult TryDispatch(Interface* impl,
fidl_incoming_msg_t* msg,
::fidl::Transaction* txn);
// Dispatches the incoming message to one of the handlers functions in the
// protocol. If there is no matching handler, it closes all the handles in
// |msg| and closes the channel with a |ZX_ERR_NOT_SUPPORTED| epitaph, before
// returning false. The message should then be discarded.
static ::fidl::DispatchResult Dispatch(Interface* impl,
fidl_incoming_msg_t* msg,
::fidl::Transaction* txn);
// Same as |Dispatch|, but takes a |void*| instead of |Interface*|.
// Only used with |fidl::BindServer| to reduce template expansion.
// Do not call this method manually. Use |Dispatch| instead.
static ::fidl::DispatchResult TypeErasedDispatch(void* impl,
fidl_incoming_msg_t* msg,
::fidl::Transaction* txn) {
return Dispatch(static_cast<Interface*>(impl), msg, txn);
}
static zx_status_t SendEventAEvent(::zx::unowned_channel _channel, int64_t a,
int64_t b);
// Caller provides the backing storage for FIDL message via response buffers.
static zx_status_t SendEventAEvent(::zx::unowned_channel _channel,
::fidl::BufferSpan _buffer, int64_t a,
int64_t b);
class EventSender;
class WeakEventSender;
};
extern "C" const fidl_type_t
fidl_test_protocols_WithAndWithoutRequestResponseNoRequestNoResponseRequestTable;
extern "C" const fidl_type_t
fidl_test_protocols_WithAndWithoutRequestResponseNoRequestNoResponseResponseTable;
extern "C" const fidl_type_t
fidl_test_protocols_WithAndWithoutRequestResponseNoRequestEmptyResponseRequestTable;
extern "C" const fidl_type_t
fidl_test_protocols_WithAndWithoutRequestResponseNoRequestEmptyResponseResponseTable;
extern "C" const fidl_type_t
fidl_test_protocols_WithAndWithoutRequestResponseNoRequestWithResponseRequestTable;
extern "C" const fidl_type_t
fidl_test_protocols_WithAndWithoutRequestResponseNoRequestWithResponseResponseTable;
extern "C" const fidl_type_t
fidl_test_protocols_WithAndWithoutRequestResponseWithRequestNoResponseRequestTable;
extern "C" const fidl_type_t
fidl_test_protocols_WithAndWithoutRequestResponseWithRequestNoResponseResponseTable;
extern "C" const fidl_type_t
fidl_test_protocols_WithAndWithoutRequestResponseWithRequestEmptyResponseRequestTable;
extern "C" const fidl_type_t
fidl_test_protocols_WithAndWithoutRequestResponseWithRequestEmptyResponseResponseTable;
extern "C" const fidl_type_t
fidl_test_protocols_WithAndWithoutRequestResponseWithRequestWithResponseRequestTable;
extern "C" const fidl_type_t
fidl_test_protocols_WithAndWithoutRequestResponseWithRequestWithResponseResponseTable;
extern "C" const fidl_type_t
fidl_test_protocols_WithAndWithoutRequestResponseOnEmptyResponseRequestTable;
extern "C" const fidl_type_t
fidl_test_protocols_WithAndWithoutRequestResponseOnEmptyResponseEventTable;
extern "C" const fidl_type_t
fidl_test_protocols_WithAndWithoutRequestResponseOnWithResponseRequestTable;
extern "C" const fidl_type_t
fidl_test_protocols_WithAndWithoutRequestResponseOnWithResponseEventTable;
class WithAndWithoutRequestResponse final {
WithAndWithoutRequestResponse() = delete;
public:
struct NoRequestNoResponseRequest final {
FIDL_ALIGNDECL
fidl_message_header_t _hdr;
explicit NoRequestNoResponseRequest(zx_txid_t _txid) { _InitHeader(_txid); }
static constexpr const fidl_type_t* Type =
&::fidl::_llcpp_coding_AnyZeroArgMessageTable;
static constexpr uint32_t MaxNumHandles = 0;
static constexpr uint32_t PrimarySize = 16;
static constexpr uint32_t MaxOutOfLine = 0;
static constexpr uint32_t AltPrimarySize = 16;
static constexpr uint32_t AltMaxOutOfLine = 0;
static constexpr bool HasFlexibleEnvelope = false;
static constexpr bool HasPointer = false;
static constexpr bool IsResource = false;
static constexpr ::fidl::internal::TransactionalMessageKind MessageKind =
::fidl::internal::TransactionalMessageKind::kRequest;
class UnownedEncodedMessage final {
public:
UnownedEncodedMessage(uint8_t* _bytes, uint32_t _byte_size,
zx_txid_t _txid)
: message_(_bytes, _byte_size, sizeof(NoRequestNoResponseRequest),
nullptr, 0, 0) {
FIDL_ALIGNDECL NoRequestNoResponseRequest _request(_txid);
message_.LinearizeAndEncode<NoRequestNoResponseRequest>(&_request);
}
UnownedEncodedMessage(uint8_t* bytes, uint32_t byte_size,
NoRequestNoResponseRequest* request)
: message_(bytes, byte_size, sizeof(NoRequestNoResponseRequest),
nullptr, 0, 0) {
message_.LinearizeAndEncode<NoRequestNoResponseRequest>(request);
}
UnownedEncodedMessage(const UnownedEncodedMessage&) = delete;
UnownedEncodedMessage(UnownedEncodedMessage&&) = delete;
UnownedEncodedMessage* operator=(const UnownedEncodedMessage&) = delete;
UnownedEncodedMessage* operator=(UnownedEncodedMessage&&) = delete;
zx_status_t status() const { return message_.status(); }
#ifdef __Fuchsia__
const char* status_string() const { return message_.status_string(); }
#endif
bool ok() const { return message_.status() == ZX_OK; }
const char* error() const { return message_.error(); }
::fidl::OutgoingMessage& GetOutgoingMessage() { return message_; }
void Write(zx_handle_t client) { message_.Write(client); }
private:
NoRequestNoResponseRequest& Message() {
return *reinterpret_cast<NoRequestNoResponseRequest*>(message_.bytes());
}
::fidl::OutgoingMessage message_;
};
class OwnedEncodedMessage final {
public:
explicit OwnedEncodedMessage(zx_txid_t _txid)
: message_(bytes_, sizeof(bytes_), _txid) {}
explicit OwnedEncodedMessage(NoRequestNoResponseRequest* request)
: message_(bytes_, sizeof(bytes_), request) {}
OwnedEncodedMessage(const OwnedEncodedMessage&) = delete;
OwnedEncodedMessage(OwnedEncodedMessage&&) = delete;
OwnedEncodedMessage* operator=(const OwnedEncodedMessage&) = delete;
OwnedEncodedMessage* operator=(OwnedEncodedMessage&&) = delete;
zx_status_t status() const { return message_.status(); }
#ifdef __Fuchsia__
const char* status_string() const { return message_.status_string(); }
#endif
bool ok() const { return message_.ok(); }
const char* error() const { return message_.error(); }
::fidl::OutgoingMessage& GetOutgoingMessage() {
return message_.GetOutgoingMessage();
}
void Write(zx_handle_t client) { message_.Write(client); }
private:
FIDL_ALIGNDECL
uint8_t bytes_[PrimarySize + MaxOutOfLine];
UnownedEncodedMessage message_;
};
class DecodedMessage final : public ::fidl::internal::IncomingMessage {
public:
DecodedMessage(uint8_t* bytes, uint32_t byte_actual,
zx_handle_info_t* handles = nullptr,
uint32_t handle_actual = 0)
: ::fidl::internal::IncomingMessage(bytes, byte_actual, handles,
handle_actual) {
Decode<NoRequestNoResponseRequest>();
}
DecodedMessage(fidl_incoming_msg_t* msg)
: ::fidl::internal::IncomingMessage(msg) {
Decode<NoRequestNoResponseRequest>();
}
DecodedMessage(const DecodedMessage&) = delete;
DecodedMessage(DecodedMessage&&) = delete;
DecodedMessage* operator=(const DecodedMessage&) = delete;
DecodedMessage* operator=(DecodedMessage&&) = delete;
NoRequestNoResponseRequest* PrimaryObject() {
ZX_DEBUG_ASSERT(ok());
return reinterpret_cast<NoRequestNoResponseRequest*>(bytes());
}
// Release the ownership of the decoded message. That means that the
// handles won't be closed When the object is destroyed. After calling
// this method, the DecodedMessage object should not be used anymore.
void ReleasePrimaryObject() { ResetBytes(); }
// These methods should only be used for testing purpose.
// They create an DecodedMessage using the bytes of an outgoing message
// and copying the handles.
static DecodedMessage FromOutgoingWithRawHandleCopy(
UnownedEncodedMessage* encoded_message) {
return DecodedMessage(encoded_message->GetOutgoingMessage());
}
static DecodedMessage FromOutgoingWithRawHandleCopy(
OwnedEncodedMessage* encoded_message) {
return DecodedMessage(encoded_message->GetOutgoingMessage());
}
private:
DecodedMessage(::fidl::OutgoingMessage& outgoing_message) {
Init(outgoing_message, nullptr, 0);
if (ok()) {
Decode<NoRequestNoResponseRequest>();
}
}
};
private:
void _InitHeader(zx_txid_t _txid);
};
struct NoRequestEmptyResponseResponse final {
FIDL_ALIGNDECL
fidl_message_header_t _hdr;
NoRequestEmptyResponseResponse() { _InitHeader(); }
static constexpr const fidl_type_t* Type =
&::fidl::_llcpp_coding_AnyZeroArgMessageTable;
static constexpr uint32_t MaxNumHandles = 0;
static constexpr uint32_t PrimarySize = 16;
static constexpr uint32_t MaxOutOfLine = 0;
static constexpr bool HasFlexibleEnvelope = false;
static constexpr bool HasPointer = false;
static constexpr bool IsResource = false;
static constexpr ::fidl::internal::TransactionalMessageKind MessageKind =
::fidl::internal::TransactionalMessageKind::kResponse;
class UnownedEncodedMessage final {
public:
UnownedEncodedMessage(uint8_t* _bytes, uint32_t _byte_size)
: message_(_bytes, _byte_size, sizeof(NoRequestEmptyResponseResponse),
nullptr, 0, 0) {
FIDL_ALIGNDECL NoRequestEmptyResponseResponse _response{};
message_.LinearizeAndEncode<NoRequestEmptyResponseResponse>(&_response);
}
UnownedEncodedMessage(uint8_t* bytes, uint32_t byte_size,
NoRequestEmptyResponseResponse* response)
: message_(bytes, byte_size, sizeof(NoRequestEmptyResponseResponse),
nullptr, 0, 0) {
message_.LinearizeAndEncode<NoRequestEmptyResponseResponse>(response);
}
UnownedEncodedMessage(const UnownedEncodedMessage&) = delete;
UnownedEncodedMessage(UnownedEncodedMessage&&) = delete;
UnownedEncodedMessage* operator=(const UnownedEncodedMessage&) = delete;
UnownedEncodedMessage* operator=(UnownedEncodedMessage&&) = delete;
zx_status_t status() const { return message_.status(); }
#ifdef __Fuchsia__
const char* status_string() const { return message_.status_string(); }
#endif
bool ok() const { return message_.status() == ZX_OK; }
const char* error() const { return message_.error(); }
::fidl::OutgoingMessage& GetOutgoingMessage() { return message_; }
void Write(zx_handle_t client) { message_.Write(client); }
private:
NoRequestEmptyResponseResponse& Message() {
return *reinterpret_cast<NoRequestEmptyResponseResponse*>(
message_.bytes());
}
::fidl::OutgoingMessage message_;
};
class OwnedEncodedMessage final {
public:
explicit OwnedEncodedMessage() : message_(bytes_, sizeof(bytes_)) {}
explicit OwnedEncodedMessage(NoRequestEmptyResponseResponse* response)
: message_(bytes_, sizeof(bytes_), response) {}
OwnedEncodedMessage(const OwnedEncodedMessage&) = delete;
OwnedEncodedMessage(OwnedEncodedMessage&&) = delete;
OwnedEncodedMessage* operator=(const OwnedEncodedMessage&) = delete;
OwnedEncodedMessage* operator=(OwnedEncodedMessage&&) = delete;
zx_status_t status() const { return message_.status(); }
#ifdef __Fuchsia__
const char* status_string() const { return message_.status_string(); }
#endif
bool ok() const { return message_.ok(); }
const char* error() const { return message_.error(); }
::fidl::OutgoingMessage& GetOutgoingMessage() {
return message_.GetOutgoingMessage();
}
void Write(zx_handle_t client) { message_.Write(client); }
private:
FIDL_ALIGNDECL
uint8_t bytes_[PrimarySize + MaxOutOfLine];
UnownedEncodedMessage message_;
};
class DecodedMessage final : public ::fidl::internal::IncomingMessage {
public:
DecodedMessage(uint8_t* bytes, uint32_t byte_actual,
zx_handle_info_t* handles = nullptr,
uint32_t handle_actual = 0)
: ::fidl::internal::IncomingMessage(bytes, byte_actual, handles,
handle_actual) {
Decode<NoRequestEmptyResponseResponse>();
}
DecodedMessage(fidl_incoming_msg_t* msg)
: ::fidl::internal::IncomingMessage(msg) {
Decode<NoRequestEmptyResponseResponse>();
}
DecodedMessage(const DecodedMessage&) = delete;
DecodedMessage(DecodedMessage&&) = delete;
DecodedMessage* operator=(const DecodedMessage&) = delete;
DecodedMessage* operator=(DecodedMessage&&) = delete;
NoRequestEmptyResponseResponse* PrimaryObject() {
ZX_DEBUG_ASSERT(ok());
return reinterpret_cast<NoRequestEmptyResponseResponse*>(bytes());
}
// Release the ownership of the decoded message. That means that the
// handles won't be closed When the object is destroyed. After calling
// this method, the DecodedMessage object should not be used anymore.
void ReleasePrimaryObject() { ResetBytes(); }
// These methods should only be used for testing purpose.
// They create an DecodedMessage using the bytes of an outgoing message
// and copying the handles.
static DecodedMessage FromOutgoingWithRawHandleCopy(
UnownedEncodedMessage* outgoing_message) {
return DecodedMessage(outgoing_message->GetOutgoingMessage());
}
static DecodedMessage FromOutgoingWithRawHandleCopy(
OwnedEncodedMessage* outgoing_message) {
return DecodedMessage(outgoing_message->GetOutgoingMessage());
}
private:
DecodedMessage(::fidl::OutgoingMessage& outgoing_message) {
Init(outgoing_message, nullptr, 0);
if (ok()) {
Decode<NoRequestEmptyResponseResponse>();
}
}
};
private:
void _InitHeader();
};
struct NoRequestEmptyResponseRequest final {
FIDL_ALIGNDECL
fidl_message_header_t _hdr;
explicit NoRequestEmptyResponseRequest(zx_txid_t _txid) {
_InitHeader(_txid);
}
static constexpr const fidl_type_t* Type =
&::fidl::_llcpp_coding_AnyZeroArgMessageTable;
static constexpr uint32_t MaxNumHandles = 0;
static constexpr uint32_t PrimarySize = 16;
static constexpr uint32_t MaxOutOfLine = 0;
static constexpr uint32_t AltPrimarySize = 16;
static constexpr uint32_t AltMaxOutOfLine = 0;
static constexpr bool HasFlexibleEnvelope = false;
static constexpr bool HasPointer = false;
static constexpr bool IsResource = false;
static constexpr ::fidl::internal::TransactionalMessageKind MessageKind =
::fidl::internal::TransactionalMessageKind::kRequest;
class UnownedEncodedMessage final {
public:
UnownedEncodedMessage(uint8_t* _bytes, uint32_t _byte_size,
zx_txid_t _txid)
: message_(_bytes, _byte_size, sizeof(NoRequestEmptyResponseRequest),
nullptr, 0, 0) {
FIDL_ALIGNDECL NoRequestEmptyResponseRequest _request(_txid);
message_.LinearizeAndEncode<NoRequestEmptyResponseRequest>(&_request);
}
UnownedEncodedMessage(uint8_t* bytes, uint32_t byte_size,
NoRequestEmptyResponseRequest* request)
: message_(bytes, byte_size, sizeof(NoRequestEmptyResponseRequest),
nullptr, 0, 0) {
message_.LinearizeAndEncode<NoRequestEmptyResponseRequest>(request);
}
UnownedEncodedMessage(const UnownedEncodedMessage&) = delete;
UnownedEncodedMessage(UnownedEncodedMessage&&) = delete;
UnownedEncodedMessage* operator=(const UnownedEncodedMessage&) = delete;
UnownedEncodedMessage* operator=(UnownedEncodedMessage&&) = delete;
zx_status_t status() const { return message_.status(); }
#ifdef __Fuchsia__
const char* status_string() const { return message_.status_string(); }
#endif
bool ok() const { return message_.status() == ZX_OK; }
const char* error() const { return message_.error(); }
::fidl::OutgoingMessage& GetOutgoingMessage() { return message_; }
void Write(zx_handle_t client) { message_.Write(client); }
private:
NoRequestEmptyResponseRequest& Message() {
return *reinterpret_cast<NoRequestEmptyResponseRequest*>(
message_.bytes());
}
::fidl::OutgoingMessage message_;
};
class OwnedEncodedMessage final {
public:
explicit OwnedEncodedMessage(zx_txid_t _txid)
: message_(bytes_, sizeof(bytes_), _txid) {}
explicit OwnedEncodedMessage(NoRequestEmptyResponseRequest* request)
: message_(bytes_, sizeof(bytes_), request) {}
OwnedEncodedMessage(const OwnedEncodedMessage&) = delete;
OwnedEncodedMessage(OwnedEncodedMessage&&) = delete;
OwnedEncodedMessage* operator=(const OwnedEncodedMessage&) = delete;
OwnedEncodedMessage* operator=(OwnedEncodedMessage&&) = delete;
zx_status_t status() const { return message_.status(); }
#ifdef __Fuchsia__
const char* status_string() const { return message_.status_string(); }
#endif
bool ok() const { return message_.ok(); }
const char* error() const { return message_.error(); }
::fidl::OutgoingMessage& GetOutgoingMessage() {
return message_.GetOutgoingMessage();
}
void Write(zx_handle_t client) { message_.Write(client); }
private:
FIDL_ALIGNDECL
uint8_t bytes_[PrimarySize + MaxOutOfLine];
UnownedEncodedMessage message_;
};
class DecodedMessage final : public ::fidl::internal::IncomingMessage {
public:
DecodedMessage(uint8_t* bytes, uint32_t byte_actual,
zx_handle_info_t* handles = nullptr,
uint32_t handle_actual = 0)
: ::fidl::internal::IncomingMessage(bytes, byte_actual, handles,
handle_actual) {
Decode<NoRequestEmptyResponseRequest>();
}
DecodedMessage(fidl_incoming_msg_t* msg)
: ::fidl::internal::IncomingMessage(msg) {
Decode<NoRequestEmptyResponseRequest>();
}
DecodedMessage(const DecodedMessage&) = delete;
DecodedMessage(DecodedMessage&&) = delete;
DecodedMessage* operator=(const DecodedMessage&) = delete;
DecodedMessage* operator=(DecodedMessage&&) = delete;
NoRequestEmptyResponseRequest* PrimaryObject() {
ZX_DEBUG_ASSERT(ok());
return reinterpret_cast<NoRequestEmptyResponseRequest*>(bytes());
}
// Release the ownership of the decoded message. That means that the
// handles won't be closed When the object is destroyed. After calling
// this method, the DecodedMessage object should not be used anymore.
void ReleasePrimaryObject() { ResetBytes(); }
// These methods should only be used for testing purpose.
// They create an DecodedMessage using the bytes of an outgoing message
// and copying the handles.
static DecodedMessage FromOutgoingWithRawHandleCopy(
UnownedEncodedMessage* encoded_message) {
return DecodedMessage(encoded_message->GetOutgoingMessage());
}
static DecodedMessage FromOutgoingWithRawHandleCopy(
OwnedEncodedMessage* encoded_message) {
return DecodedMessage(encoded_message->GetOutgoingMessage());
}
private:
DecodedMessage(::fidl::OutgoingMessage& outgoing_message) {
Init(outgoing_message, nullptr, 0);
if (ok()) {
Decode<NoRequestEmptyResponseRequest>();
}
}
};
private:
void _InitHeader(zx_txid_t _txid);
};
struct NoRequestWithResponseResponse final {
FIDL_ALIGNDECL
fidl_message_header_t _hdr;
::fidl::StringView ret;
explicit NoRequestWithResponseResponse(const ::fidl::StringView& ret)
: ret(::fidl::unowned_ptr_t<const char>(ret.data()), ret.size()) {
_InitHeader();
}
NoRequestWithResponseResponse() { _InitHeader(); }
static constexpr const fidl_type_t* Type =
&fidl_test_protocols_WithAndWithoutRequestResponseNoRequestWithResponseResponseTable;
static constexpr uint32_t MaxNumHandles = 0;
static constexpr uint32_t PrimarySize = 32;
static constexpr uint32_t MaxOutOfLine = 4294967295;
static constexpr bool HasFlexibleEnvelope = false;
static constexpr bool HasPointer = true;
static constexpr bool IsResource = false;
static constexpr ::fidl::internal::TransactionalMessageKind MessageKind =
::fidl::internal::TransactionalMessageKind::kResponse;
class UnownedEncodedMessage final {
public:
UnownedEncodedMessage(uint8_t* _bytes, uint32_t _byte_size,
const ::fidl::StringView& ret)
: message_(_bytes, _byte_size, sizeof(NoRequestWithResponseResponse),
nullptr, 0, 0) {
FIDL_ALIGNDECL NoRequestWithResponseResponse _response{ret};
message_.LinearizeAndEncode<NoRequestWithResponseResponse>(&_response);
}
UnownedEncodedMessage(uint8_t* bytes, uint32_t byte_size,
NoRequestWithResponseResponse* response)
: message_(bytes, byte_size, sizeof(NoRequestWithResponseResponse),
nullptr, 0, 0) {
message_.LinearizeAndEncode<NoRequestWithResponseResponse>(response);
}
UnownedEncodedMessage(const UnownedEncodedMessage&) = delete;
UnownedEncodedMessage(UnownedEncodedMessage&&) = delete;
UnownedEncodedMessage* operator=(const UnownedEncodedMessage&) = delete;
UnownedEncodedMessage* operator=(UnownedEncodedMessage&&) = delete;
zx_status_t status() const { return message_.status(); }
#ifdef __Fuchsia__
const char* status_string() const { return message_.status_string(); }
#endif
bool ok() const { return message_.status() == ZX_OK; }
const char* error() const { return message_.error(); }
::fidl::OutgoingMessage& GetOutgoingMessage() { return message_; }
void Write(zx_handle_t client) { message_.Write(client); }
private:
NoRequestWithResponseResponse& Message() {
return *reinterpret_cast<NoRequestWithResponseResponse*>(
message_.bytes());
}
::fidl::OutgoingMessage message_;
};
class OwnedEncodedMessage final {
public:
explicit OwnedEncodedMessage(const ::fidl::StringView& ret)
: bytes_(std::make_unique<::fidl::internal::AlignedBuffer<
ZX_CHANNEL_MAX_MSG_BYTES>>()),
message_(bytes_->data(), ZX_CHANNEL_MAX_MSG_BYTES, ret) {}
explicit OwnedEncodedMessage(NoRequestWithResponseResponse* response)
: bytes_(std::make_unique<::fidl::internal::AlignedBuffer<
ZX_CHANNEL_MAX_MSG_BYTES>>()),
message_(bytes_->data(), ZX_CHANNEL_MAX_MSG_BYTES, response) {}
OwnedEncodedMessage(const OwnedEncodedMessage&) = delete;
OwnedEncodedMessage(OwnedEncodedMessage&&) = delete;
OwnedEncodedMessage* operator=(const OwnedEncodedMessage&) = delete;
OwnedEncodedMessage* operator=(OwnedEncodedMessage&&) = delete;
zx_status_t status() const { return message_.status(); }
#ifdef __Fuchsia__
const char* status_string() const { return message_.status_string(); }
#endif
bool ok() const { return message_.ok(); }
const char* error() const { return message_.error(); }
::fidl::OutgoingMessage& GetOutgoingMessage() {
return message_.GetOutgoingMessage();
}
void Write(zx_handle_t client) { message_.Write(client); }
private:
std::unique_ptr<::fidl::internal::AlignedBuffer<ZX_CHANNEL_MAX_MSG_BYTES>>
bytes_;
UnownedEncodedMessage message_;
};
class DecodedMessage final : public ::fidl::internal::IncomingMessage {
public:
DecodedMessage(uint8_t* bytes, uint32_t byte_actual,
zx_handle_info_t* handles = nullptr,
uint32_t handle_actual = 0)
: ::fidl::internal::IncomingMessage(bytes, byte_actual, handles,
handle_actual) {
Decode<NoRequestWithResponseResponse>();
}
DecodedMessage(fidl_incoming_msg_t* msg)
: ::fidl::internal::IncomingMessage(msg) {
Decode<NoRequestWithResponseResponse>();
}
DecodedMessage(const DecodedMessage&) = delete;
DecodedMessage(DecodedMessage&&) = delete;
DecodedMessage* operator=(const DecodedMessage&) = delete;
DecodedMessage* operator=(DecodedMessage&&) = delete;
NoRequestWithResponseResponse* PrimaryObject() {
ZX_DEBUG_ASSERT(ok());
return reinterpret_cast<NoRequestWithResponseResponse*>(bytes());
}
// Release the ownership of the decoded message. That means that the
// handles won't be closed When the object is destroyed. After calling
// this method, the DecodedMessage object should not be used anymore.
void ReleasePrimaryObject() { ResetBytes(); }
// These methods should only be used for testing purpose.
// They create an DecodedMessage using the bytes of an outgoing message
// and copying the handles.
static DecodedMessage FromOutgoingWithRawHandleCopy(
UnownedEncodedMessage* outgoing_message) {
return DecodedMessage(outgoing_message->GetOutgoingMessage());
}
static DecodedMessage FromOutgoingWithRawHandleCopy(
OwnedEncodedMessage* outgoing_message) {
return DecodedMessage(outgoing_message->GetOutgoingMessage());
}
private:
DecodedMessage(::fidl::OutgoingMessage& outgoing_message) {
Init(outgoing_message, nullptr, 0);
if (ok()) {
Decode<NoRequestWithResponseResponse>();
}
}
};
private:
void _InitHeader();
};
struct NoRequestWithResponseRequest final {
FIDL_ALIGNDECL
fidl_message_header_t _hdr;
explicit NoRequestWithResponseRequest(zx_txid_t _txid) {
_InitHeader(_txid);
}
static constexpr const fidl_type_t* Type =
&::fidl::_llcpp_coding_AnyZeroArgMessageTable;
static constexpr uint32_t MaxNumHandles = 0;
static constexpr uint32_t PrimarySize = 16;
static constexpr uint32_t MaxOutOfLine = 0;
static constexpr uint32_t AltPrimarySize = 16;
static constexpr uint32_t AltMaxOutOfLine = 0;
static constexpr bool HasFlexibleEnvelope = false;
static constexpr bool HasPointer = false;
static constexpr bool IsResource = false;
static constexpr ::fidl::internal::TransactionalMessageKind MessageKind =
::fidl::internal::TransactionalMessageKind::kRequest;
using ResponseType = NoRequestWithResponseResponse;
class UnownedEncodedMessage final {
public:
UnownedEncodedMessage(uint8_t* _bytes, uint32_t _byte_size,
zx_txid_t _txid)
: message_(_bytes, _byte_size, sizeof(NoRequestWithResponseRequest),
nullptr, 0, 0) {
FIDL_ALIGNDECL NoRequestWithResponseRequest _request(_txid);
message_.LinearizeAndEncode<NoRequestWithResponseRequest>(&_request);
}
UnownedEncodedMessage(uint8_t* bytes, uint32_t byte_size,
NoRequestWithResponseRequest* request)
: message_(bytes, byte_size, sizeof(NoRequestWithResponseRequest),
nullptr, 0, 0) {
message_.LinearizeAndEncode<NoRequestWithResponseRequest>(request);
}
UnownedEncodedMessage(const UnownedEncodedMessage&) = delete;
UnownedEncodedMessage(UnownedEncodedMessage&&) = delete;
UnownedEncodedMessage* operator=(const UnownedEncodedMessage&) = delete;
UnownedEncodedMessage* operator=(UnownedEncodedMessage&&) = delete;
zx_status_t status() const { return message_.status(); }
#ifdef __Fuchsia__
const char* status_string() const { return message_.status_string(); }
#endif
bool ok() const { return message_.status() == ZX_OK; }
const char* error() const { return message_.error(); }
::fidl::OutgoingMessage& GetOutgoingMessage() { return message_; }
void Write(zx_handle_t client) { message_.Write(client); }
private:
NoRequestWithResponseRequest& Message() {
return *reinterpret_cast<NoRequestWithResponseRequest*>(
message_.bytes());
}
::fidl::OutgoingMessage message_;
};
class OwnedEncodedMessage final {
public:
explicit OwnedEncodedMessage(zx_txid_t _txid)
: message_(bytes_, sizeof(bytes_), _txid) {}
explicit OwnedEncodedMessage(NoRequestWithResponseRequest* request)
: message_(bytes_, sizeof(bytes_), request) {}
OwnedEncodedMessage(const OwnedEncodedMessage&) = delete;
OwnedEncodedMessage(OwnedEncodedMessage&&) = delete;
OwnedEncodedMessage* operator=(const OwnedEncodedMessage&) = delete;
OwnedEncodedMessage* operator=(OwnedEncodedMessage&&) = delete;
zx_status_t status() const { return message_.status(); }
#ifdef __Fuchsia__
const char* status_string() const { return message_.status_string(); }
#endif
bool ok() const { return message_.ok(); }
const char* error() const { return message_.error(); }
::fidl::OutgoingMessage& GetOutgoingMessage() {
return message_.GetOutgoingMessage();
}
void Write(zx_handle_t client) { message_.Write(client); }
private:
FIDL_ALIGNDECL
uint8_t bytes_[PrimarySize + MaxOutOfLine];
UnownedEncodedMessage message_;
};
class DecodedMessage final : public ::fidl::internal::IncomingMessage {
public:
DecodedMessage(uint8_t* bytes, uint32_t byte_actual,
zx_handle_info_t* handles = nullptr,
uint32_t handle_actual = 0)
: ::fidl::internal::IncomingMessage(bytes, byte_actual, handles,
handle_actual) {
Decode<NoRequestWithResponseRequest>();
}
DecodedMessage(fidl_incoming_msg_t* msg)
: ::fidl::internal::IncomingMessage(msg) {
Decode<NoRequestWithResponseRequest>();
}
DecodedMessage(const DecodedMessage&) = delete;
DecodedMessage(DecodedMessage&&) = delete;
DecodedMessage* operator=(const DecodedMessage&) = delete;
DecodedMessage* operator=(DecodedMessage&&) = delete;
NoRequestWithResponseRequest* PrimaryObject() {
ZX_DEBUG_ASSERT(ok());
return reinterpret_cast<NoRequestWithResponseRequest*>(bytes());
}
// Release the ownership of the decoded message. That means that the
// handles won't be closed When the object is destroyed. After calling
// this method, the DecodedMessage object should not be used anymore.
void ReleasePrimaryObject() { ResetBytes(); }
// These methods should only be used for testing purpose.
// They create an DecodedMessage using the bytes of an outgoing message
// and copying the handles.
static DecodedMessage FromOutgoingWithRawHandleCopy(
UnownedEncodedMessage* encoded_message) {
return DecodedMessage(encoded_message->GetOutgoingMessage());
}
static DecodedMessage FromOutgoingWithRawHandleCopy(
OwnedEncodedMessage* encoded_message) {
return DecodedMessage(encoded_message->GetOutgoingMessage());
}
private:
DecodedMessage(::fidl::OutgoingMessage& outgoing_message) {
Init(outgoing_message, nullptr, 0);
if (ok()) {
Decode<NoRequestWithResponseRequest>();
}
}
};
private:
void _InitHeader(zx_txid_t _txid);
};
struct WithRequestNoResponseRequest final {
FIDL_ALIGNDECL
fidl_message_header_t _hdr;
::fidl::StringView arg;
explicit WithRequestNoResponseRequest(zx_txid_t _txid,
const ::fidl::StringView& arg)
: arg(::fidl::unowned_ptr_t<const char>(arg.data()), arg.size()) {
_InitHeader(_txid);
}
explicit WithRequestNoResponseRequest(zx_txid_t _txid) {
_InitHeader(_txid);
}
static constexpr const fidl_type_t* Type =
&fidl_test_protocols_WithAndWithoutRequestResponseWithRequestNoResponseRequestTable;
static constexpr uint32_t MaxNumHandles = 0;
static constexpr uint32_t PrimarySize = 32;
static constexpr uint32_t MaxOutOfLine = 4294967295;
static constexpr uint32_t AltPrimarySize = 32;
static constexpr uint32_t AltMaxOutOfLine = 4294967295;
static constexpr bool HasFlexibleEnvelope = false;
static constexpr bool HasPointer = true;
static constexpr bool IsResource = false;
static constexpr ::fidl::internal::TransactionalMessageKind MessageKind =
::fidl::internal::TransactionalMessageKind::kRequest;
class UnownedEncodedMessage final {
public:
UnownedEncodedMessage(uint8_t* _bytes, uint32_t _byte_size,
zx_txid_t _txid, const ::fidl::StringView& arg)
: message_(_bytes, _byte_size, sizeof(WithRequestNoResponseRequest),
nullptr, 0, 0) {
FIDL_ALIGNDECL WithRequestNoResponseRequest _request(_txid, arg);
message_.LinearizeAndEncode<WithRequestNoResponseRequest>(&_request);
}
UnownedEncodedMessage(uint8_t* bytes, uint32_t byte_size,
WithRequestNoResponseRequest* request)
: message_(bytes, byte_size, sizeof(WithRequestNoResponseRequest),
nullptr, 0, 0) {
message_.LinearizeAndEncode<WithRequestNoResponseRequest>(request);
}
UnownedEncodedMessage(const UnownedEncodedMessage&) = delete;
UnownedEncodedMessage(UnownedEncodedMessage&&) = delete;
UnownedEncodedMessage* operator=(const UnownedEncodedMessage&) = delete;
UnownedEncodedMessage* operator=(UnownedEncodedMessage&&) = delete;
zx_status_t status() const { return message_.status(); }
#ifdef __Fuchsia__
const char* status_string() const { return message_.status_string(); }
#endif
bool ok() const { return message_.status() == ZX_OK; }
const char* error() const { return message_.error(); }
::fidl::OutgoingMessage& GetOutgoingMessage() { return message_; }
void Write(zx_handle_t client) { message_.Write(client); }
private:
WithRequestNoResponseRequest& Message() {
return *reinterpret_cast<WithRequestNoResponseRequest*>(
message_.bytes());
}
::fidl::OutgoingMessage message_;
};
class OwnedEncodedMessage final {
public:
explicit OwnedEncodedMessage(zx_txid_t _txid,
const ::fidl::StringView& arg)
: bytes_(std::make_unique<::fidl::internal::AlignedBuffer<
ZX_CHANNEL_MAX_MSG_BYTES>>()),
message_(bytes_->data(), ZX_CHANNEL_MAX_MSG_BYTES, _txid, arg) {}
explicit OwnedEncodedMessage(WithRequestNoResponseRequest* request)
: bytes_(std::make_unique<::fidl::internal::AlignedBuffer<
ZX_CHANNEL_MAX_MSG_BYTES>>()),
message_(bytes_->data(), ZX_CHANNEL_MAX_MSG_BYTES, request) {}
OwnedEncodedMessage(const OwnedEncodedMessage&) = delete;
OwnedEncodedMessage(OwnedEncodedMessage&&) = delete;
OwnedEncodedMessage* operator=(const OwnedEncodedMessage&) = delete;
OwnedEncodedMessage* operator=(OwnedEncodedMessage&&) = delete;
zx_status_t status() const { return message_.status(); }
#ifdef __Fuchsia__
const char* status_string() const { return message_.status_string(); }
#endif
bool ok() const { return message_.ok(); }
const char* error() const { return message_.error(); }
::fidl::OutgoingMessage& GetOutgoingMessage() {
return message_.GetOutgoingMessage();
}
void Write(zx_handle_t client) { message_.Write(client); }
private:
std::unique_ptr<::fidl::internal::AlignedBuffer<ZX_CHANNEL_MAX_MSG_BYTES>>
bytes_;
UnownedEncodedMessage message_;
};
class DecodedMessage final : public ::fidl::internal::IncomingMessage {
public:
DecodedMessage(uint8_t* bytes, uint32_t byte_actual,
zx_handle_info_t* handles = nullptr,
uint32_t handle_actual = 0)
: ::fidl::internal::IncomingMessage(bytes, byte_actual, handles,
handle_actual) {
Decode<WithRequestNoResponseRequest>();
}
DecodedMessage(fidl_incoming_msg_t* msg)
: ::fidl::internal::IncomingMessage(msg) {
Decode<WithRequestNoResponseRequest>();
}
DecodedMessage(const DecodedMessage&) = delete;
DecodedMessage(DecodedMessage&&) = delete;
DecodedMessage* operator=(const DecodedMessage&) = delete;
DecodedMessage* operator=(DecodedMessage&&) = delete;
WithRequestNoResponseRequest* PrimaryObject() {
ZX_DEBUG_ASSERT(ok());
return reinterpret_cast<WithRequestNoResponseRequest*>(bytes());
}
// Release the ownership of the decoded message. That means that the
// handles won't be closed When the object is destroyed. After calling
// this method, the DecodedMessage object should not be used anymore.
void ReleasePrimaryObject() { ResetBytes(); }
// These methods should only be used for testing purpose.
// They create an DecodedMessage using the bytes of an outgoing message
// and copying the handles.
static DecodedMessage FromOutgoingWithRawHandleCopy(
UnownedEncodedMessage* encoded_message) {
return DecodedMessage(encoded_message->GetOutgoingMessage());
}
static DecodedMessage FromOutgoingWithRawHandleCopy(
OwnedEncodedMessage* encoded_message) {
return DecodedMessage(encoded_message->GetOutgoingMessage());
}
private:
DecodedMessage(::fidl::OutgoingMessage& outgoing_message) {
Init(outgoing_message, nullptr, 0);
if (ok()) {
Decode<WithRequestNoResponseRequest>();
}
}
};
private:
void _InitHeader(zx_txid_t _txid);
};
struct WithRequestEmptyResponseResponse final {
FIDL_ALIGNDECL
fidl_message_header_t _hdr;
WithRequestEmptyResponseResponse() { _InitHeader(); }
static constexpr const fidl_type_t* Type =
&::fidl::_llcpp_coding_AnyZeroArgMessageTable;
static constexpr uint32_t MaxNumHandles = 0;
static constexpr uint32_t PrimarySize = 16;
static constexpr uint32_t MaxOutOfLine = 0;
static constexpr bool HasFlexibleEnvelope = false;
static constexpr bool HasPointer = false;
static constexpr bool IsResource = false;
static constexpr ::fidl::internal::TransactionalMessageKind MessageKind =
::fidl::internal::TransactionalMessageKind::kResponse;
class UnownedEncodedMessage final {
public:
UnownedEncodedMessage(uint8_t* _bytes, uint32_t _byte_size)
: message_(_bytes, _byte_size,
sizeof(WithRequestEmptyResponseResponse), nullptr, 0, 0) {
FIDL_ALIGNDECL WithRequestEmptyResponseResponse _response{};
message_.LinearizeAndEncode<WithRequestEmptyResponseResponse>(
&_response);
}
UnownedEncodedMessage(uint8_t* bytes, uint32_t byte_size,
WithRequestEmptyResponseResponse* response)
: message_(bytes, byte_size, sizeof(WithRequestEmptyResponseResponse),
nullptr, 0, 0) {
message_.LinearizeAndEncode<WithRequestEmptyResponseResponse>(response);
}
UnownedEncodedMessage(const UnownedEncodedMessage&) = delete;
UnownedEncodedMessage(UnownedEncodedMessage&&) = delete;
UnownedEncodedMessage* operator=(const UnownedEncodedMessage&) = delete;
UnownedEncodedMessage* operator=(UnownedEncodedMessage&&) = delete;
zx_status_t status() const { return message_.status(); }
#ifdef __Fuchsia__
const char* status_string() const { return message_.status_string(); }
#endif
bool ok() const { return message_.status() == ZX_OK; }
const char* error() const { return message_.error(); }
::fidl::OutgoingMessage& GetOutgoingMessage() { return message_; }
void Write(zx_handle_t client) { message_.Write(client); }
private:
WithRequestEmptyResponseResponse& Message() {
return *reinterpret_cast<WithRequestEmptyResponseResponse*>(
message_.bytes());
}
::fidl::OutgoingMessage message_;
};
class OwnedEncodedMessage final {
public:
explicit OwnedEncodedMessage() : message_(bytes_, sizeof(bytes_)) {}
explicit OwnedEncodedMessage(WithRequestEmptyResponseResponse* response)
: message_(bytes_, sizeof(bytes_), response) {}
OwnedEncodedMessage(const OwnedEncodedMessage&) = delete;
OwnedEncodedMessage(OwnedEncodedMessage&&) = delete;
OwnedEncodedMessage* operator=(const OwnedEncodedMessage&) = delete;
OwnedEncodedMessage* operator=(OwnedEncodedMessage&&) = delete;
zx_status_t status() const { return message_.status(); }
#ifdef __Fuchsia__
const char* status_string() const { return message_.status_string(); }
#endif
bool ok() const { return message_.ok(); }
const char* error() const { return message_.error(); }
::fidl::OutgoingMessage& GetOutgoingMessage() {
return message_.GetOutgoingMessage();
}
void Write(zx_handle_t client) { message_.Write(client); }
private:
FIDL_ALIGNDECL
uint8_t bytes_[PrimarySize + MaxOutOfLine];
UnownedEncodedMessage message_;
};
class DecodedMessage final : public ::fidl::internal::IncomingMessage {
public:
DecodedMessage(uint8_t* bytes, uint32_t byte_actual,
zx_handle_info_t* handles = nullptr,
uint32_t handle_actual = 0)
: ::fidl::internal::IncomingMessage(bytes, byte_actual, handles,
handle_actual) {
Decode<WithRequestEmptyResponseResponse>();
}
DecodedMessage(fidl_incoming_msg_t* msg)
: ::fidl::internal::IncomingMessage(msg) {
Decode<WithRequestEmptyResponseResponse>();
}
DecodedMessage(const DecodedMessage&) = delete;
DecodedMessage(DecodedMessage&&) = delete;
DecodedMessage* operator=(const DecodedMessage&) = delete;
DecodedMessage* operator=(DecodedMessage&&) = delete;
WithRequestEmptyResponseResponse* PrimaryObject() {
ZX_DEBUG_ASSERT(ok());
return reinterpret_cast<WithRequestEmptyResponseResponse*>(bytes());
}
// Release the ownership of the decoded message. That means that the
// handles won't be closed When the object is destroyed. After calling
// this method, the DecodedMessage object should not be used anymore.
void ReleasePrimaryObject() { ResetBytes(); }
// These methods should only be used for testing purpose.
// They create an DecodedMessage using the bytes of an outgoing message
// and copying the handles.
static DecodedMessage FromOutgoingWithRawHandleCopy(
UnownedEncodedMessage* outgoing_message) {
return DecodedMessage(outgoing_message->GetOutgoingMessage());
}
static DecodedMessage FromOutgoingWithRawHandleCopy(
OwnedEncodedMessage* outgoing_message) {
return DecodedMessage(outgoing_message->GetOutgoingMessage());
}
private:
DecodedMessage(::fidl::OutgoingMessage& outgoing_message) {
Init(outgoing_message, nullptr, 0);
if (ok()) {
Decode<WithRequestEmptyResponseResponse>();
}
}
};
private:
void _InitHeader();
};
struct WithRequestEmptyResponseRequest final {
FIDL_ALIGNDECL
fidl_message_header_t _hdr;
::fidl::StringView arg;
explicit WithRequestEmptyResponseRequest(zx_txid_t _txid,
const ::fidl::StringView& arg)
: arg(::fidl::unowned_ptr_t<const char>(arg.data()), arg.size()) {
_InitHeader(_txid);
}
explicit WithRequestEmptyResponseRequest(zx_txid_t _txid) {
_InitHeader(_txid);
}
static constexpr const fidl_type_t* Type =
&fidl_test_protocols_WithAndWithoutRequestResponseWithRequestEmptyResponseRequestTable;
static constexpr uint32_t MaxNumHandles = 0;
static constexpr uint32_t PrimarySize = 32;
static constexpr uint32_t MaxOutOfLine = 4294967295;
static constexpr uint32_t AltPrimarySize = 32;
static constexpr uint32_t AltMaxOutOfLine = 4294967295;
static constexpr bool HasFlexibleEnvelope = false;
static constexpr bool HasPointer = true;
static constexpr bool IsResource = false;
static constexpr ::fidl::internal::TransactionalMessageKind MessageKind =
::fidl::internal::TransactionalMessageKind::kRequest;
class UnownedEncodedMessage final {
public:
UnownedEncodedMessage(uint8_t* _bytes, uint32_t _byte_size,
zx_txid_t _txid, const ::fidl::StringView& arg)
: message_(_bytes, _byte_size,
sizeof(WithRequestEmptyResponseRequest), nullptr, 0, 0) {
FIDL_ALIGNDECL WithRequestEmptyResponseRequest _request(_txid, arg);
message_.LinearizeAndEncode<WithRequestEmptyResponseRequest>(&_request);
}
UnownedEncodedMessage(uint8_t* bytes, uint32_t byte_size,
WithRequestEmptyResponseRequest* request)
: message_(bytes, byte_size, sizeof(WithRequestEmptyResponseRequest),
nullptr, 0, 0) {
message_.LinearizeAndEncode<WithRequestEmptyResponseRequest>(request);
}
UnownedEncodedMessage(const UnownedEncodedMessage&) = delete;
UnownedEncodedMessage(UnownedEncodedMessage&&) = delete;
UnownedEncodedMessage* operator=(const UnownedEncodedMessage&) = delete;
UnownedEncodedMessage* operator=(UnownedEncodedMessage&&) = delete;
zx_status_t status() const { return message_.status(); }
#ifdef __Fuchsia__
const char* status_string() const { return message_.status_string(); }
#endif
bool ok() const { return message_.status() == ZX_OK; }
const char* error() const { return message_.error(); }
::fidl::OutgoingMessage& GetOutgoingMessage() { return message_; }
void Write(zx_handle_t client) { message_.Write(client); }
private:
WithRequestEmptyResponseRequest& Message() {
return *reinterpret_cast<WithRequestEmptyResponseRequest*>(
message_.bytes());
}
::fidl::OutgoingMessage message_;
};
class OwnedEncodedMessage final {
public:
explicit OwnedEncodedMessage(zx_txid_t _txid,
const ::fidl::StringView& arg)
: bytes_(std::make_unique<::fidl::internal::AlignedBuffer<
ZX_CHANNEL_MAX_MSG_BYTES>>()),
message_(bytes_->data(), ZX_CHANNEL_MAX_MSG_BYTES, _txid, arg) {}
explicit OwnedEncodedMessage(WithRequestEmptyResponseRequest* request)
: bytes_(std::make_unique<::fidl::internal::AlignedBuffer<
ZX_CHANNEL_MAX_MSG_BYTES>>()),
message_(bytes_->data(), ZX_CHANNEL_MAX_MSG_BYTES, request) {}
OwnedEncodedMessage(const OwnedEncodedMessage&) = delete;
OwnedEncodedMessage(OwnedEncodedMessage&&) = delete;
OwnedEncodedMessage* operator=(const OwnedEncodedMessage&) = delete;
OwnedEncodedMessage* operator=(OwnedEncodedMessage&&) = delete;
zx_status_t status() const { return message_.status(); }
#ifdef __Fuchsia__
const char* status_string() const { return message_.status_string(); }
#endif
bool ok() const { return message_.ok(); }
const char* error() const { return message_.error(); }
::fidl::OutgoingMessage& GetOutgoingMessage() {
return message_.GetOutgoingMessage();
}
void Write(zx_handle_t client) { message_.Write(client); }
private:
std::unique_ptr<::fidl::internal::AlignedBuffer<ZX_CHANNEL_MAX_MSG_BYTES>>
bytes_;
UnownedEncodedMessage message_;
};
class DecodedMessage final : public ::fidl::internal::IncomingMessage {
public:
DecodedMessage(uint8_t* bytes, uint32_t byte_actual,
zx_handle_info_t* handles = nullptr,
uint32_t handle_actual = 0)
: ::fidl::internal::IncomingMessage(bytes, byte_actual, handles,
handle_actual) {
Decode<WithRequestEmptyResponseRequest>();
}
DecodedMessage(fidl_incoming_msg_t* msg)
: ::fidl::internal::IncomingMessage(msg) {
Decode<WithRequestEmptyResponseRequest>();
}
DecodedMessage(const DecodedMessage&) = delete;
DecodedMessage(DecodedMessage&&) = delete;
DecodedMessage* operator=(const DecodedMessage&) = delete;
DecodedMessage* operator=(DecodedMessage&&) = delete;
WithRequestEmptyResponseRequest* PrimaryObject() {
ZX_DEBUG_ASSERT(ok());
return reinterpret_cast<WithRequestEmptyResponseRequest*>(bytes());
}
// Release the ownership of the decoded message. That means that the
// handles won't be closed When the object is destroyed. After calling
// this method, the DecodedMessage object should not be used anymore.
void ReleasePrimaryObject() { ResetBytes(); }
// These methods should only be used for testing purpose.
// They create an DecodedMessage using the bytes of an outgoing message
// and copying the handles.
static DecodedMessage FromOutgoingWithRawHandleCopy(
UnownedEncodedMessage* encoded_message) {
return DecodedMessage(encoded_message->GetOutgoingMessage());
}
static DecodedMessage FromOutgoingWithRawHandleCopy(
OwnedEncodedMessage* encoded_message) {
return DecodedMessage(encoded_message->GetOutgoingMessage());
}
private:
DecodedMessage(::fidl::OutgoingMessage& outgoing_message) {
Init(outgoing_message, nullptr, 0);
if (ok()) {
Decode<WithRequestEmptyResponseRequest>();
}
}
};
private:
void _InitHeader(zx_txid_t _txid);
};
struct WithRequestWithResponseResponse final {
FIDL_ALIGNDECL
fidl_message_header_t _hdr;
::fidl::StringView ret;
explicit WithRequestWithResponseResponse(const ::fidl::StringView& ret)
: ret(::fidl::unowned_ptr_t<const char>(ret.data()), ret.size()) {
_InitHeader();
}
WithRequestWithResponseResponse() { _InitHeader(); }
static constexpr const fidl_type_t* Type =
&fidl_test_protocols_WithAndWithoutRequestResponseWithRequestWithResponseResponseTable;
static constexpr uint32_t MaxNumHandles = 0;
static constexpr uint32_t PrimarySize = 32;
static constexpr uint32_t MaxOutOfLine = 4294967295;
static constexpr bool HasFlexibleEnvelope = false;
static constexpr bool HasPointer = true;
static constexpr bool IsResource = false;
static constexpr ::fidl::internal::TransactionalMessageKind MessageKind =
::fidl::internal::TransactionalMessageKind::kResponse;
class UnownedEncodedMessage final {
public:
UnownedEncodedMessage(uint8_t* _bytes, uint32_t _byte_size,
const ::fidl::StringView& ret)
: message_(_bytes, _byte_size,
sizeof(WithRequestWithResponseResponse), nullptr, 0, 0) {
FIDL_ALIGNDECL WithRequestWithResponseResponse _response{ret};
message_.LinearizeAndEncode<WithRequestWithResponseResponse>(
&_response);
}
UnownedEncodedMessage(uint8_t* bytes, uint32_t byte_size,
WithRequestWithResponseResponse* response)
: message_(bytes, byte_size, sizeof(WithRequestWithResponseResponse),
nullptr, 0, 0) {
message_.LinearizeAndEncode<WithRequestWithResponseResponse>(response);
}
UnownedEncodedMessage(const UnownedEncodedMessage&) = delete;
UnownedEncodedMessage(UnownedEncodedMessage&&) = delete;
UnownedEncodedMessage* operator=(const UnownedEncodedMessage&) = delete;
UnownedEncodedMessage* operator=(UnownedEncodedMessage&&) = delete;
zx_status_t status() const { return message_.status(); }
#ifdef __Fuchsia__
const char* status_string() const { return message_.status_string(); }
#endif
bool ok() const { return message_.status() == ZX_OK; }
const char* error() const { return message_.error(); }
::fidl::OutgoingMessage& GetOutgoingMessage() { return message_; }
void Write(zx_handle_t client) { message_.Write(client); }
private:
WithRequestWithResponseResponse& Message() {
return *reinterpret_cast<WithRequestWithResponseResponse*>(
message_.bytes());
}
::fidl::OutgoingMessage message_;
};
class OwnedEncodedMessage final {
public:
explicit OwnedEncodedMessage(const ::fidl::StringView& ret)
: bytes_(std::make_unique<::fidl::internal::AlignedBuffer<
ZX_CHANNEL_MAX_MSG_BYTES>>()),
message_(bytes_->data(), ZX_CHANNEL_MAX_MSG_BYTES, ret) {}
explicit OwnedEncodedMessage(WithRequestWithResponseResponse* response)
: bytes_(std::make_unique<::fidl::internal::AlignedBuffer<
ZX_CHANNEL_MAX_MSG_BYTES>>()),
message_(bytes_->data(), ZX_CHANNEL_MAX_MSG_BYTES, response) {}
OwnedEncodedMessage(const OwnedEncodedMessage&) = delete;
OwnedEncodedMessage(OwnedEncodedMessage&&) = delete;
OwnedEncodedMessage* operator=(const OwnedEncodedMessage&) = delete;
OwnedEncodedMessage* operator=(OwnedEncodedMessage&&) = delete;
zx_status_t status() const { return message_.status(); }
#ifdef __Fuchsia__
const char* status_string() const { return message_.status_string(); }
#endif
bool ok() const { return message_.ok(); }
const char* error() const { return message_.error(); }
::fidl::OutgoingMessage& GetOutgoingMessage() {
return message_.GetOutgoingMessage();
}
void Write(zx_handle_t client) { message_.Write(client); }
private:
std::unique_ptr<::fidl::internal::AlignedBuffer<ZX_CHANNEL_MAX_MSG_BYTES>>
bytes_;
UnownedEncodedMessage message_;
};
class DecodedMessage final : public ::fidl::internal::IncomingMessage {
public:
DecodedMessage(uint8_t* bytes, uint32_t byte_actual,
zx_handle_info_t* handles = nullptr,
uint32_t handle_actual = 0)
: ::fidl::internal::IncomingMessage(bytes, byte_actual, handles,
handle_actual) {
Decode<WithRequestWithResponseResponse>();
}
DecodedMessage(fidl_incoming_msg_t* msg)
: ::fidl::internal::IncomingMessage(msg) {
Decode<WithRequestWithResponseResponse>();
}
DecodedMessage(const DecodedMessage&) = delete;
DecodedMessage(DecodedMessage&&) = delete;
DecodedMessage* operator=(const DecodedMessage&) = delete;
DecodedMessage* operator=(DecodedMessage&&) = delete;
WithRequestWithResponseResponse* PrimaryObject() {
ZX_DEBUG_ASSERT(ok());
return reinterpret_cast<WithRequestWithResponseResponse*>(bytes());
}
// Release the ownership of the decoded message. That means that the
// handles won't be closed When the object is destroyed. After calling
// this method, the DecodedMessage object should not be used anymore.
void ReleasePrimaryObject() { ResetBytes(); }
// These methods should only be used for testing purpose.
// They create an DecodedMessage using the bytes of an outgoing message
// and copying the handles.
static DecodedMessage FromOutgoingWithRawHandleCopy(
UnownedEncodedMessage* outgoing_message) {
return DecodedMessage(outgoing_message->GetOutgoingMessage());
}
static DecodedMessage FromOutgoingWithRawHandleCopy(
OwnedEncodedMessage* outgoing_message) {
return DecodedMessage(outgoing_message->GetOutgoingMessage());
}
private:
DecodedMessage(::fidl::OutgoingMessage& outgoing_message) {
Init(outgoing_message, nullptr, 0);
if (ok()) {
Decode<WithRequestWithResponseResponse>();
}
}
};
private:
void _InitHeader();
};
struct WithRequestWithResponseRequest final {
FIDL_ALIGNDECL
fidl_message_header_t _hdr;
::fidl::StringView arg;
explicit WithRequestWithResponseRequest(zx_txid_t _txid,
const ::fidl::StringView& arg)
: arg(::fidl::unowned_ptr_t<const char>(arg.data()), arg.size()) {
_InitHeader(_txid);
}
explicit WithRequestWithResponseRequest(zx_txid_t _txid) {
_InitHeader(_txid);
}
static constexpr const fidl_type_t* Type =
&fidl_test_protocols_WithAndWithoutRequestResponseWithRequestWithResponseRequestTable;
static constexpr uint32_t MaxNumHandles = 0;
static constexpr uint32_t PrimarySize = 32;
static constexpr uint32_t MaxOutOfLine = 4294967295;
static constexpr uint32_t AltPrimarySize = 32;
static constexpr uint32_t AltMaxOutOfLine = 4294967295;
static constexpr bool HasFlexibleEnvelope = false;
static constexpr bool HasPointer = true;
static constexpr bool IsResource = false;
static constexpr ::fidl::internal::TransactionalMessageKind MessageKind =
::fidl::internal::TransactionalMessageKind::kRequest;
using ResponseType = WithRequestWithResponseResponse;
class UnownedEncodedMessage final {
public:
UnownedEncodedMessage(uint8_t* _bytes, uint32_t _byte_size,
zx_txid_t _txid, const ::fidl::StringView& arg)
: message_(_bytes, _byte_size, sizeof(WithRequestWithResponseRequest),
nullptr, 0, 0) {
FIDL_ALIGNDECL WithRequestWithResponseRequest _request(_txid, arg);
message_.LinearizeAndEncode<WithRequestWithResponseRequest>(&_request);
}
UnownedEncodedMessage(uint8_t* bytes, uint32_t byte_size,
WithRequestWithResponseRequest* request)
: message_(bytes, byte_size, sizeof(WithRequestWithResponseRequest),
nullptr, 0, 0) {
message_.LinearizeAndEncode<WithRequestWithResponseRequest>(request);
}
UnownedEncodedMessage(const UnownedEncodedMessage&) = delete;
UnownedEncodedMessage(UnownedEncodedMessage&&) = delete;
UnownedEncodedMessage* operator=(const UnownedEncodedMessage&) = delete;
UnownedEncodedMessage* operator=(UnownedEncodedMessage&&) = delete;
zx_status_t status() const { return message_.status(); }
#ifdef __Fuchsia__
const char* status_string() const { return message_.status_string(); }
#endif
bool ok() const { return message_.status() == ZX_OK; }
const char* error() const { return message_.error(); }
::fidl::OutgoingMessage& GetOutgoingMessage() { return message_; }
void Write(zx_handle_t client) { message_.Write(client); }
private:
WithRequestWithResponseRequest& Message() {
return *reinterpret_cast<WithRequestWithResponseRequest*>(
message_.bytes());
}
::fidl::OutgoingMessage message_;
};
class OwnedEncodedMessage final {
public:
explicit OwnedEncodedMessage(zx_txid_t _txid,
const ::fidl::StringView& arg)
: bytes_(std::make_unique<::fidl::internal::AlignedBuffer<
ZX_CHANNEL_MAX_MSG_BYTES>>()),
message_(bytes_->data(), ZX_CHANNEL_MAX_MSG_BYTES, _txid, arg) {}
explicit OwnedEncodedMessage(WithRequestWithResponseRequest* request)
: bytes_(std::make_unique<::fidl::internal::AlignedBuffer<
ZX_CHANNEL_MAX_MSG_BYTES>>()),
message_(bytes_->data(), ZX_CHANNEL_MAX_MSG_BYTES, request) {}
OwnedEncodedMessage(const OwnedEncodedMessage&) = delete;
OwnedEncodedMessage(OwnedEncodedMessage&&) = delete;
OwnedEncodedMessage* operator=(const OwnedEncodedMessage&) = delete;
OwnedEncodedMessage* operator=(OwnedEncodedMessage&&) = delete;
zx_status_t status() const { return message_.status(); }
#ifdef __Fuchsia__
const char* status_string() const { return message_.status_string(); }
#endif
bool ok() const { return message_.ok(); }
const char* error() const { return message_.error(); }
::fidl::OutgoingMessage& GetOutgoingMessage() {
return message_.GetOutgoingMessage();
}
void Write(zx_handle_t client) { message_.Write(client); }
private:
std::unique_ptr<::fidl::internal::AlignedBuffer<ZX_CHANNEL_MAX_MSG_BYTES>>
bytes_;
UnownedEncodedMessage message_;
};
class DecodedMessage final : public ::fidl::internal::IncomingMessage {
public:
DecodedMessage(uint8_t* bytes, uint32_t byte_actual,
zx_handle_info_t* handles = nullptr,
uint32_t handle_actual = 0)
: ::fidl::internal::IncomingMessage(bytes, byte_actual, handles,
handle_actual) {
Decode<WithRequestWithResponseRequest>();
}
DecodedMessage(fidl_incoming_msg_t* msg)
: ::fidl::internal::IncomingMessage(msg) {
Decode<WithRequestWithResponseRequest>();
}
DecodedMessage(const DecodedMessage&) = delete;
DecodedMessage(DecodedMessage&&) = delete;
DecodedMessage* operator=(const DecodedMessage&) = delete;
DecodedMessage* operator=(DecodedMessage&&) = delete;
WithRequestWithResponseRequest* PrimaryObject() {
ZX_DEBUG_ASSERT(ok());
return reinterpret_cast<WithRequestWithResponseRequest*>(bytes());
}
// Release the ownership of the decoded message. That means that the
// handles won't be closed When the object is destroyed. After calling
// this method, the DecodedMessage object should not be used anymore.
void ReleasePrimaryObject() { ResetBytes(); }
// These methods should only be used for testing purpose.
// They create an DecodedMessage using the bytes of an outgoing message
// and copying the handles.
static DecodedMessage FromOutgoingWithRawHandleCopy(
UnownedEncodedMessage* encoded_message) {
return DecodedMessage(encoded_message->GetOutgoingMessage());
}
static DecodedMessage FromOutgoingWithRawHandleCopy(
OwnedEncodedMessage* encoded_message) {
return DecodedMessage(encoded_message->GetOutgoingMessage());
}
private:
DecodedMessage(::fidl::OutgoingMessage& outgoing_message) {
Init(outgoing_message, nullptr, 0);
if (ok()) {
Decode<WithRequestWithResponseRequest>();
}
}
};
private:
void _InitHeader(zx_txid_t _txid);
};
struct OnEmptyResponseResponse final {
FIDL_ALIGNDECL
fidl_message_header_t _hdr;
OnEmptyResponseResponse() { _InitHeader(); }
static constexpr const fidl_type_t* Type =
&::fidl::_llcpp_coding_AnyZeroArgMessageTable;
static constexpr uint32_t MaxNumHandles = 0;
static constexpr uint32_t PrimarySize = 16;
static constexpr uint32_t MaxOutOfLine = 0;
static constexpr bool HasFlexibleEnvelope = false;
static constexpr bool HasPointer = false;
static constexpr bool IsResource = false;
static constexpr ::fidl::internal::TransactionalMessageKind MessageKind =
::fidl::internal::TransactionalMessageKind::kResponse;
class UnownedEncodedMessage final {
public:
UnownedEncodedMessage(uint8_t* _bytes, uint32_t _byte_size)
: message_(_bytes, _byte_size, sizeof(OnEmptyResponseResponse),
nullptr, 0, 0) {
FIDL_ALIGNDECL OnEmptyResponseResponse _response{};
message_.LinearizeAndEncode<OnEmptyResponseResponse>(&_response);
}
UnownedEncodedMessage(uint8_t* bytes, uint32_t byte_size,
OnEmptyResponseResponse* response)
: message_(bytes, byte_size, sizeof(OnEmptyResponseResponse), nullptr,
0, 0) {
message_.LinearizeAndEncode<OnEmptyResponseResponse>(response);
}
UnownedEncodedMessage(const UnownedEncodedMessage&) = delete;
UnownedEncodedMessage(UnownedEncodedMessage&&) = delete;
UnownedEncodedMessage* operator=(const UnownedEncodedMessage&) = delete;
UnownedEncodedMessage* operator=(UnownedEncodedMessage&&) = delete;
zx_status_t status() const { return message_.status(); }
#ifdef __Fuchsia__
const char* status_string() const { return message_.status_string(); }
#endif
bool ok() const { return message_.status() == ZX_OK; }
const char* error() const { return message_.error(); }
::fidl::OutgoingMessage& GetOutgoingMessage() { return message_; }
void Write(zx_handle_t client) { message_.Write(client); }
private:
OnEmptyResponseResponse& Message() {
return *reinterpret_cast<OnEmptyResponseResponse*>(message_.bytes());
}
::fidl::OutgoingMessage message_;
};
class OwnedEncodedMessage final {
public:
explicit OwnedEncodedMessage() : message_(bytes_, sizeof(bytes_)) {}
explicit OwnedEncodedMessage(OnEmptyResponseResponse* response)
: message_(bytes_, sizeof(bytes_), response) {}
OwnedEncodedMessage(const OwnedEncodedMessage&) = delete;
OwnedEncodedMessage(OwnedEncodedMessage&&) = delete;
OwnedEncodedMessage* operator=(const OwnedEncodedMessage&) = delete;
OwnedEncodedMessage* operator=(OwnedEncodedMessage&&) = delete;
zx_status_t status() const { return message_.status(); }
#ifdef __Fuchsia__
const char* status_string() const { return message_.status_string(); }
#endif
bool ok() const { return message_.ok(); }
const char* error() const { return message_.error(); }
::fidl::OutgoingMessage& GetOutgoingMessage() {
return message_.GetOutgoingMessage();
}
void Write(zx_handle_t client) { message_.Write(client); }
private:
FIDL_ALIGNDECL
uint8_t bytes_[PrimarySize + MaxOutOfLine];
UnownedEncodedMessage message_;
};
class DecodedMessage final : public ::fidl::internal::IncomingMessage {
public:
DecodedMessage(uint8_t* bytes, uint32_t byte_actual,
zx_handle_info_t* handles = nullptr,
uint32_t handle_actual = 0)
: ::fidl::internal::IncomingMessage(bytes, byte_actual, handles,
handle_actual) {
Decode<OnEmptyResponseResponse>();
}
DecodedMessage(fidl_incoming_msg_t* msg)
: ::fidl::internal::IncomingMessage(msg) {
Decode<OnEmptyResponseResponse>();
}
DecodedMessage(const DecodedMessage&) = delete;
DecodedMessage(DecodedMessage&&) = delete;
DecodedMessage* operator=(const DecodedMessage&) = delete;
DecodedMessage* operator=(DecodedMessage&&) = delete;
OnEmptyResponseResponse* PrimaryObject() {
ZX_DEBUG_ASSERT(ok());
return reinterpret_cast<OnEmptyResponseResponse*>(bytes());
}
// Release the ownership of the decoded message. That means that the
// handles won't be closed When the object is destroyed. After calling
// this method, the DecodedMessage object should not be used anymore.
void ReleasePrimaryObject() { ResetBytes(); }
// These methods should only be used for testing purpose.
// They create an DecodedMessage using the bytes of an outgoing message
// and copying the handles.
static DecodedMessage FromOutgoingWithRawHandleCopy(
UnownedEncodedMessage* outgoing_message) {
return DecodedMessage(outgoing_message->GetOutgoingMessage());
}
static DecodedMessage FromOutgoingWithRawHandleCopy(
OwnedEncodedMessage* outgoing_message) {
return DecodedMessage(outgoing_message->GetOutgoingMessage());
}
private:
DecodedMessage(::fidl::OutgoingMessage& outgoing_message) {
Init(outgoing_message, nullptr, 0);
if (ok()) {
Decode<OnEmptyResponseResponse>();
}
}
};
private:
void _InitHeader();
};
struct OnWithResponseResponse final {
FIDL_ALIGNDECL
fidl_message_header_t _hdr;
::fidl::StringView ret;
explicit OnWithResponseResponse(const ::fidl::StringView& ret)
: ret(::fidl::unowned_ptr_t<const char>(ret.data()), ret.size()) {
_InitHeader();
}
OnWithResponseResponse() { _InitHeader(); }
static constexpr const fidl_type_t* Type =
&fidl_test_protocols_WithAndWithoutRequestResponseOnWithResponseEventTable;
static constexpr uint32_t MaxNumHandles = 0;
static constexpr uint32_t PrimarySize = 32;
static constexpr uint32_t MaxOutOfLine = 4294967295;
static constexpr bool HasFlexibleEnvelope = false;
static constexpr bool HasPointer = true;
static constexpr bool IsResource = false;
static constexpr ::fidl::internal::TransactionalMessageKind MessageKind =
::fidl::internal::TransactionalMessageKind::kResponse;
class UnownedEncodedMessage final {
public:
UnownedEncodedMessage(uint8_t* _bytes, uint32_t _byte_size,
const ::fidl::StringView& ret)
: message_(_bytes, _byte_size, sizeof(OnWithResponseResponse),
nullptr, 0, 0) {
FIDL_ALIGNDECL OnWithResponseResponse _response{ret};
message_.LinearizeAndEncode<OnWithResponseResponse>(&_response);
}
UnownedEncodedMessage(uint8_t* bytes, uint32_t byte_size,
OnWithResponseResponse* response)
: message_(bytes, byte_size, sizeof(OnWithResponseResponse), nullptr,
0, 0) {
message_.LinearizeAndEncode<OnWithResponseResponse>(response);
}
UnownedEncodedMessage(const UnownedEncodedMessage&) = delete;
UnownedEncodedMessage(UnownedEncodedMessage&&) = delete;
UnownedEncodedMessage* operator=(const UnownedEncodedMessage&) = delete;
UnownedEncodedMessage* operator=(UnownedEncodedMessage&&) = delete;
zx_status_t status() const { return message_.status(); }
#ifdef __Fuchsia__
const char* status_string() const { return message_.status_string(); }
#endif
bool ok() const { return message_.status() == ZX_OK; }
const char* error() const { return message_.error(); }
::fidl::OutgoingMessage& GetOutgoingMessage() { return message_; }
void Write(zx_handle_t client) { message_.Write(client); }
private:
OnWithResponseResponse& Message() {
return *reinterpret_cast<OnWithResponseResponse*>(message_.bytes());
}
::fidl::OutgoingMessage message_;
};
class OwnedEncodedMessage final {
public:
explicit OwnedEncodedMessage(const ::fidl::StringView& ret)
: bytes_(std::make_unique<::fidl::internal::AlignedBuffer<
ZX_CHANNEL_MAX_MSG_BYTES>>()),
message_(bytes_->data(), ZX_CHANNEL_MAX_MSG_BYTES, ret) {}
explicit OwnedEncodedMessage(OnWithResponseResponse* response)
: bytes_(std::make_unique<::fidl::internal::AlignedBuffer<
ZX_CHANNEL_MAX_MSG_BYTES>>()),
message_(bytes_->data(), ZX_CHANNEL_MAX_MSG_BYTES, response) {}
OwnedEncodedMessage(const OwnedEncodedMessage&) = delete;
OwnedEncodedMessage(OwnedEncodedMessage&&) = delete;
OwnedEncodedMessage* operator=(const OwnedEncodedMessage&) = delete;
OwnedEncodedMessage* operator=(OwnedEncodedMessage&&) = delete;
zx_status_t status() const { return message_.status(); }
#ifdef __Fuchsia__
const char* status_string() const { return message_.status_string(); }
#endif
bool ok() const { return message_.ok(); }
const char* error() const { return message_.error(); }
::fidl::OutgoingMessage& GetOutgoingMessage() {
return message_.GetOutgoingMessage();
}
void Write(zx_handle_t client) { message_.Write(client); }
private:
std::unique_ptr<::fidl::internal::AlignedBuffer<ZX_CHANNEL_MAX_MSG_BYTES>>
bytes_;
UnownedEncodedMessage message_;
};
class DecodedMessage final : public ::fidl::internal::IncomingMessage {
public:
DecodedMessage(uint8_t* bytes, uint32_t byte_actual,
zx_handle_info_t* handles = nullptr,
uint32_t handle_actual = 0)
: ::fidl::internal::IncomingMessage(bytes, byte_actual, handles,
handle_actual) {
Decode<OnWithResponseResponse>();
}
DecodedMessage(fidl_incoming_msg_t* msg)
: ::fidl::internal::IncomingMessage(msg) {
Decode<OnWithResponseResponse>();
}
DecodedMessage(const DecodedMessage&) = delete;
DecodedMessage(DecodedMessage&&) = delete;
DecodedMessage* operator=(const DecodedMessage&) = delete;
DecodedMessage* operator=(DecodedMessage&&) = delete;
OnWithResponseResponse* PrimaryObject() {
ZX_DEBUG_ASSERT(ok());
return reinterpret_cast<OnWithResponseResponse*>(bytes());
}
// Release the ownership of the decoded message. That means that the
// handles won't be closed When the object is destroyed. After calling
// this method, the DecodedMessage object should not be used anymore.
void ReleasePrimaryObject() { ResetBytes(); }
// These methods should only be used for testing purpose.
// They create an DecodedMessage using the bytes of an outgoing message
// and copying the handles.
static DecodedMessage FromOutgoingWithRawHandleCopy(
UnownedEncodedMessage* outgoing_message) {
return DecodedMessage(outgoing_message->GetOutgoingMessage());
}
static DecodedMessage FromOutgoingWithRawHandleCopy(
OwnedEncodedMessage* outgoing_message) {
return DecodedMessage(outgoing_message->GetOutgoingMessage());
}
private:
DecodedMessage(::fidl::OutgoingMessage& outgoing_message) {
Init(outgoing_message, nullptr, 0);
if (ok()) {
Decode<OnWithResponseResponse>();
}
}
};
private:
void _InitHeader();
};
class EventHandler {
public:
EventHandler() = default;
virtual ~EventHandler() = default;
virtual void OnEmptyResponse(OnEmptyResponseResponse* event) = 0;
virtual void OnWithResponse(OnWithResponseResponse* event) = 0;
// Method called when an unknown event is found. This methods gives the
// status which, in this case, is returned by HandleOneEvent.
virtual zx_status_t Unknown() = 0;
// Handle all possible events defined in this protocol.
// Blocks to consume exactly one message from the channel, then call the
// corresponding virtual method.
::fidl::Result HandleOneEvent(::zx::unowned_channel client_end);
};
// Collection of return types of FIDL calls in this protocol.
class ResultOf final {
ResultOf() = delete;
public:
class NoRequestNoResponse final : public ::fidl::Result {
public:
explicit NoRequestNoResponse(zx_handle_t _client);
explicit NoRequestNoResponse(const ::fidl::Result& result)
: ::fidl::Result(result) {}
NoRequestNoResponse(NoRequestNoResponse&&) = delete;
NoRequestNoResponse(const NoRequestNoResponse&) = delete;
NoRequestNoResponse* operator=(NoRequestNoResponse&&) = delete;
NoRequestNoResponse* operator=(const NoRequestNoResponse&) = delete;
~NoRequestNoResponse() = default;
private:
};
class NoRequestEmptyResponse final : public ::fidl::Result {
public:
explicit NoRequestEmptyResponse(zx_handle_t _client);
NoRequestEmptyResponse(zx_handle_t _client, zx_time_t _deadline);
explicit NoRequestEmptyResponse(const ::fidl::Result& result)
: ::fidl::Result(result) {}
NoRequestEmptyResponse(NoRequestEmptyResponse&&) = delete;
NoRequestEmptyResponse(const NoRequestEmptyResponse&) = delete;
NoRequestEmptyResponse* operator=(NoRequestEmptyResponse&&) = delete;
NoRequestEmptyResponse* operator=(const NoRequestEmptyResponse&) = delete;
~NoRequestEmptyResponse() = default;
NoRequestEmptyResponseResponse* Unwrap() {
ZX_DEBUG_ASSERT(ok());
return reinterpret_cast<NoRequestEmptyResponseResponse*>(bytes_);
}
const NoRequestEmptyResponseResponse* Unwrap() const {
ZX_DEBUG_ASSERT(ok());
return reinterpret_cast<const NoRequestEmptyResponseResponse*>(bytes_);
}
NoRequestEmptyResponseResponse& value() { return *Unwrap(); }
const NoRequestEmptyResponseResponse& value() const { return *Unwrap(); }
NoRequestEmptyResponseResponse* operator->() { return &value(); }
const NoRequestEmptyResponseResponse* operator->() const {
return &value();
}
NoRequestEmptyResponseResponse& operator*() { return value(); }
const NoRequestEmptyResponseResponse& operator*() const {
return value();
}
private:
FIDL_ALIGNDECL
uint8_t bytes_[NoRequestEmptyResponseResponse::PrimarySize +
NoRequestEmptyResponseResponse::MaxOutOfLine];
};
class NoRequestWithResponse final : public ::fidl::Result {
public:
explicit NoRequestWithResponse(zx_handle_t _client);
NoRequestWithResponse(zx_handle_t _client, zx_time_t _deadline);
explicit NoRequestWithResponse(const ::fidl::Result& result)
: ::fidl::Result(result) {}
NoRequestWithResponse(NoRequestWithResponse&&) = delete;
NoRequestWithResponse(const NoRequestWithResponse&) = delete;
NoRequestWithResponse* operator=(NoRequestWithResponse&&) = delete;
NoRequestWithResponse* operator=(const NoRequestWithResponse&) = delete;
~NoRequestWithResponse() = default;
NoRequestWithResponseResponse* Unwrap() {
ZX_DEBUG_ASSERT(ok());
return reinterpret_cast<NoRequestWithResponseResponse*>(bytes_->data());
}
const NoRequestWithResponseResponse* Unwrap() const {
ZX_DEBUG_ASSERT(ok());
return reinterpret_cast<const NoRequestWithResponseResponse*>(
bytes_->data());
}
NoRequestWithResponseResponse& value() { return *Unwrap(); }
const NoRequestWithResponseResponse& value() const { return *Unwrap(); }
NoRequestWithResponseResponse* operator->() { return &value(); }
const NoRequestWithResponseResponse* operator->() const {
return &value();
}
NoRequestWithResponseResponse& operator*() { return value(); }
const NoRequestWithResponseResponse& operator*() const { return value(); }
private:
std::unique_ptr<::fidl::internal::AlignedBuffer<ZX_CHANNEL_MAX_MSG_BYTES>>
bytes_;
};
class WithRequestNoResponse final : public ::fidl::Result {
public:
explicit WithRequestNoResponse(zx_handle_t _client,
const ::fidl::StringView& arg);
explicit WithRequestNoResponse(const ::fidl::Result& result)
: ::fidl::Result(result) {}
WithRequestNoResponse(WithRequestNoResponse&&) = delete;
WithRequestNoResponse(const WithRequestNoResponse&) = delete;
WithRequestNoResponse* operator=(WithRequestNoResponse&&) = delete;
WithRequestNoResponse* operator=(const WithRequestNoResponse&) = delete;
~WithRequestNoResponse() = default;
private:
};
class WithRequestEmptyResponse final : public ::fidl::Result {
public:
explicit WithRequestEmptyResponse(zx_handle_t _client,
const ::fidl::StringView& arg);
WithRequestEmptyResponse(zx_handle_t _client,
const ::fidl::StringView& arg,
zx_time_t _deadline);
explicit WithRequestEmptyResponse(const ::fidl::Result& result)
: ::fidl::Result(result) {}
WithRequestEmptyResponse(WithRequestEmptyResponse&&) = delete;
WithRequestEmptyResponse(const WithRequestEmptyResponse&) = delete;
WithRequestEmptyResponse* operator=(WithRequestEmptyResponse&&) = delete;
WithRequestEmptyResponse* operator=(const WithRequestEmptyResponse&) =
delete;
~WithRequestEmptyResponse() = default;
WithRequestEmptyResponseResponse* Unwrap() {
ZX_DEBUG_ASSERT(ok());
return reinterpret_cast<WithRequestEmptyResponseResponse*>(bytes_);
}
const WithRequestEmptyResponseResponse* Unwrap() const {
ZX_DEBUG_ASSERT(ok());
return reinterpret_cast<const WithRequestEmptyResponseResponse*>(
bytes_);
}
WithRequestEmptyResponseResponse& value() { return *Unwrap(); }
const WithRequestEmptyResponseResponse& value() const {
return *Unwrap();
}
WithRequestEmptyResponseResponse* operator->() { return &value(); }
const WithRequestEmptyResponseResponse* operator->() const {
return &value();
}
WithRequestEmptyResponseResponse& operator*() { return value(); }
const WithRequestEmptyResponseResponse& operator*() const {
return value();
}
private:
FIDL_ALIGNDECL
uint8_t bytes_[WithRequestEmptyResponseResponse::PrimarySize +
WithRequestEmptyResponseResponse::MaxOutOfLine];
};
class WithRequestWithResponse final : public ::fidl::Result {
public:
explicit WithRequestWithResponse(zx_handle_t _client,
const ::fidl::StringView& arg);
WithRequestWithResponse(zx_handle_t _client,
const ::fidl::StringView& arg,
zx_time_t _deadline);
explicit WithRequestWithResponse(const ::fidl::Result& result)
: ::fidl::Result(result) {}
WithRequestWithResponse(WithRequestWithResponse&&) = delete;
WithRequestWithResponse(const WithRequestWithResponse&) = delete;
WithRequestWithResponse* operator=(WithRequestWithResponse&&) = delete;
WithRequestWithResponse* operator=(const WithRequestWithResponse&) =
delete;
~WithRequestWithResponse() = default;
WithRequestWithResponseResponse* Unwrap() {
ZX_DEBUG_ASSERT(ok());
return reinterpret_cast<WithRequestWithResponseResponse*>(
bytes_->data());
}
const WithRequestWithResponseResponse* Unwrap() const {
ZX_DEBUG_ASSERT(ok());
return reinterpret_cast<const WithRequestWithResponseResponse*>(
bytes_->data());
}
WithRequestWithResponseResponse& value() { return *Unwrap(); }
const WithRequestWithResponseResponse& value() const { return *Unwrap(); }
WithRequestWithResponseResponse* operator->() { return &value(); }
const WithRequestWithResponseResponse* operator->() const {
return &value();
}
WithRequestWithResponseResponse& operator*() { return value(); }
const WithRequestWithResponseResponse& operator*() const {
return value();
}
private:
std::unique_ptr<::fidl::internal::AlignedBuffer<ZX_CHANNEL_MAX_MSG_BYTES>>
bytes_;
};
};
// Collection of return types of FIDL calls in this protocol,
// when the caller-allocate flavor or in-place call is used.
class UnownedResultOf final {
UnownedResultOf() = delete;
public:
class NoRequestNoResponse final : public ::fidl::Result {
public:
explicit NoRequestNoResponse(zx_handle_t _client);
explicit NoRequestNoResponse(const ::fidl::Result& result)
: ::fidl::Result(result) {}
NoRequestNoResponse(NoRequestNoResponse&&) = delete;
NoRequestNoResponse(const NoRequestNoResponse&) = delete;
NoRequestNoResponse* operator=(NoRequestNoResponse&&) = delete;
NoRequestNoResponse* operator=(const NoRequestNoResponse&) = delete;
~NoRequestNoResponse() = default;
};
class NoRequestEmptyResponse final : public ::fidl::Result {
public:
explicit NoRequestEmptyResponse(zx_handle_t _client,
uint8_t* _response_bytes,
uint32_t _response_byte_capacity);
explicit NoRequestEmptyResponse(const ::fidl::Result& result)
: ::fidl::Result(result) {}
NoRequestEmptyResponse(NoRequestEmptyResponse&&) = delete;
NoRequestEmptyResponse(const NoRequestEmptyResponse&) = delete;
NoRequestEmptyResponse* operator=(NoRequestEmptyResponse&&) = delete;
NoRequestEmptyResponse* operator=(const NoRequestEmptyResponse&) = delete;
~NoRequestEmptyResponse() = default;
NoRequestEmptyResponseResponse* Unwrap() {
ZX_DEBUG_ASSERT(ok());
return reinterpret_cast<NoRequestEmptyResponseResponse*>(bytes_);
}
const NoRequestEmptyResponseResponse* Unwrap() const {
ZX_DEBUG_ASSERT(ok());
return reinterpret_cast<const NoRequestEmptyResponseResponse*>(bytes_);
}
NoRequestEmptyResponseResponse& value() { return *Unwrap(); }
const NoRequestEmptyResponseResponse& value() const { return *Unwrap(); }
NoRequestEmptyResponseResponse* operator->() { return &value(); }
const NoRequestEmptyResponseResponse* operator->() const {
return &value();
}
NoRequestEmptyResponseResponse& operator*() { return value(); }
const NoRequestEmptyResponseResponse& operator*() const {
return value();
}
private:
uint8_t* bytes_;
};
class NoRequestWithResponse final : public ::fidl::Result {
public:
explicit NoRequestWithResponse(zx_handle_t _client,
uint8_t* _response_bytes,
uint32_t _response_byte_capacity);
explicit NoRequestWithResponse(const ::fidl::Result& result)
: ::fidl::Result(result) {}
NoRequestWithResponse(NoRequestWithResponse&&) = delete;
NoRequestWithResponse(const NoRequestWithResponse&) = delete;
NoRequestWithResponse* operator=(NoRequestWithResponse&&) = delete;
NoRequestWithResponse* operator=(const NoRequestWithResponse&) = delete;
~NoRequestWithResponse() = default;
NoRequestWithResponseResponse* Unwrap() {
ZX_DEBUG_ASSERT(ok());
return reinterpret_cast<NoRequestWithResponseResponse*>(bytes_);
}
const NoRequestWithResponseResponse* Unwrap() const {
ZX_DEBUG_ASSERT(ok());
return reinterpret_cast<const NoRequestWithResponseResponse*>(bytes_);
}
NoRequestWithResponseResponse& value() { return *Unwrap(); }
const NoRequestWithResponseResponse& value() const { return *Unwrap(); }
NoRequestWithResponseResponse* operator->() { return &value(); }
const NoRequestWithResponseResponse* operator->() const {
return &value();
}
NoRequestWithResponseResponse& operator*() { return value(); }
const NoRequestWithResponseResponse& operator*() const { return value(); }
private:
uint8_t* bytes_;
};
class WithRequestNoResponse final : public ::fidl::Result {
public:
explicit WithRequestNoResponse(zx_handle_t _client,
uint8_t* _request_bytes,
uint32_t _request_byte_capacity,
const ::fidl::StringView& arg);
explicit WithRequestNoResponse(const ::fidl::Result& result)
: ::fidl::Result(result) {}
WithRequestNoResponse(WithRequestNoResponse&&) = delete;
WithRequestNoResponse(const WithRequestNoResponse&) = delete;
WithRequestNoResponse* operator=(WithRequestNoResponse&&) = delete;
WithRequestNoResponse* operator=(const WithRequestNoResponse&) = delete;
~WithRequestNoResponse() = default;
};
class WithRequestEmptyResponse final : public ::fidl::Result {
public:
explicit WithRequestEmptyResponse(zx_handle_t _client,
uint8_t* _request_bytes,
uint32_t _request_byte_capacity,
const ::fidl::StringView& arg,
uint8_t* _response_bytes,
uint32_t _response_byte_capacity);
explicit WithRequestEmptyResponse(const ::fidl::Result& result)
: ::fidl::Result(result) {}
WithRequestEmptyResponse(WithRequestEmptyResponse&&) = delete;
WithRequestEmptyResponse(const WithRequestEmptyResponse&) = delete;
WithRequestEmptyResponse* operator=(WithRequestEmptyResponse&&) = delete;
WithRequestEmptyResponse* operator=(const WithRequestEmptyResponse&) =
delete;
~WithRequestEmptyResponse() = default;
WithRequestEmptyResponseResponse* Unwrap() {
ZX_DEBUG_ASSERT(ok());
return reinterpret_cast<WithRequestEmptyResponseResponse*>(bytes_);
}
const WithRequestEmptyResponseResponse* Unwrap() const {
ZX_DEBUG_ASSERT(ok());
return reinterpret_cast<const WithRequestEmptyResponseResponse*>(
bytes_);
}
WithRequestEmptyResponseResponse& value() { return *Unwrap(); }
const WithRequestEmptyResponseResponse& value() const {
return *Unwrap();
}
WithRequestEmptyResponseResponse* operator->() { return &value(); }
const WithRequestEmptyResponseResponse* operator->() const {
return &value();
}
WithRequestEmptyResponseResponse& operator*() { return value(); }
const WithRequestEmptyResponseResponse& operator*() const {
return value();
}
private:
uint8_t* bytes_;
};
class WithRequestWithResponse final : public ::fidl::Result {
public:
explicit WithRequestWithResponse(zx_handle_t _client,
uint8_t* _request_bytes,
uint32_t _request_byte_capacity,
const ::fidl::StringView& arg,
uint8_t* _response_bytes,
uint32_t _response_byte_capacity);
explicit WithRequestWithResponse(const ::fidl::Result& result)
: ::fidl::Result(result) {}
WithRequestWithResponse(WithRequestWithResponse&&) = delete;
WithRequestWithResponse(const WithRequestWithResponse&) = delete;
WithRequestWithResponse* operator=(WithRequestWithResponse&&) = delete;
WithRequestWithResponse* operator=(const WithRequestWithResponse&) =
delete;
~WithRequestWithResponse() = default;
WithRequestWithResponseResponse* Unwrap() {
ZX_DEBUG_ASSERT(ok());
return reinterpret_cast<WithRequestWithResponseResponse*>(bytes_);
}
const WithRequestWithResponseResponse* Unwrap() const {
ZX_DEBUG_ASSERT(ok());
return reinterpret_cast<const WithRequestWithResponseResponse*>(bytes_);
}
WithRequestWithResponseResponse& value() { return *Unwrap(); }
const WithRequestWithResponseResponse& value() const { return *Unwrap(); }
WithRequestWithResponseResponse* operator->() { return &value(); }
const WithRequestWithResponseResponse* operator->() const {
return &value();
}
WithRequestWithResponseResponse& operator*() { return value(); }
const WithRequestWithResponseResponse& operator*() const {
return value();
}
private:
uint8_t* bytes_;
};
};
// Methods to make a sync FIDL call directly on an unowned channel, avoiding
// setting up a client.
class Call final {
Call() = delete;
public:
// Allocates 16 bytes of message buffer on the stack. No heap allocation
// necessary.
static ResultOf::NoRequestNoResponse NoRequestNoResponse(
::zx::unowned_channel _client_end) {
return ResultOf::NoRequestNoResponse(_client_end->get());
}
// Allocates 32 bytes of message buffer on the stack. No heap allocation
// necessary.
static ResultOf::NoRequestEmptyResponse NoRequestEmptyResponse(
::zx::unowned_channel _client_end) {
return ResultOf::NoRequestEmptyResponse(_client_end->get());
}
// Allocates 16 bytes of request buffer on the stack. Response is
// heap-allocated.
static ResultOf::NoRequestWithResponse NoRequestWithResponse(
::zx::unowned_channel _client_end) {
return ResultOf::NoRequestWithResponse(_client_end->get());
}
// Caller provides the backing storage for FIDL message via request and
// response buffers.
static UnownedResultOf::NoRequestWithResponse NoRequestWithResponse(
::zx::unowned_channel _client_end
,
::fidl::BufferSpan _response_buffer) {
return UnownedResultOf::NoRequestWithResponse(
_client_end->get(), _response_buffer.data, _response_buffer.capacity);
}
// Request is heap-allocated.
static ResultOf::WithRequestNoResponse WithRequestNoResponse(
::zx::unowned_channel _client_end, ::fidl::StringView arg) {
return ResultOf::WithRequestNoResponse(_client_end->get(), arg);
}
// Caller provides the backing storage for FIDL message via request and
// response buffers.
static UnownedResultOf::WithRequestNoResponse WithRequestNoResponse(
::zx::unowned_channel _client_end, ::fidl::BufferSpan _request_buffer,
::fidl::StringView arg) {
return UnownedResultOf::WithRequestNoResponse(
_client_end->get(), _request_buffer.data, _request_buffer.capacity,
arg);
}
// Allocates 16 bytes of response buffer on the stack. Request is
// heap-allocated.
static ResultOf::WithRequestEmptyResponse WithRequestEmptyResponse(
::zx::unowned_channel _client_end, ::fidl::StringView arg) {
return ResultOf::WithRequestEmptyResponse(_client_end->get(), arg);
}
// Caller provides the backing storage for FIDL message via request and
// response buffers.
static UnownedResultOf::WithRequestEmptyResponse WithRequestEmptyResponse(
::zx::unowned_channel _client_end, ::fidl::BufferSpan _request_buffer,
::fidl::StringView arg, ::fidl::BufferSpan _response_buffer) {
return UnownedResultOf::WithRequestEmptyResponse(
_client_end->get(), _request_buffer.data, _request_buffer.capacity,
arg, _response_buffer.data, _response_buffer.capacity);
}
// Request is heap-allocated. Response is heap-allocated.
static ResultOf::WithRequestWithResponse WithRequestWithResponse(
::zx::unowned_channel _client_end, ::fidl::StringView arg) {
return ResultOf::WithRequestWithResponse(_client_end->get(), arg);
}
// Caller provides the backing storage for FIDL message via request and
// response buffers.
static UnownedResultOf::WithRequestWithResponse WithRequestWithResponse(
::zx::unowned_channel _client_end, ::fidl::BufferSpan _request_buffer,
::fidl::StringView arg, ::fidl::BufferSpan _response_buffer) {
return UnownedResultOf::WithRequestWithResponse(
_client_end->get(), _request_buffer.data, _request_buffer.capacity,
arg, _response_buffer.data, _response_buffer.capacity);
}
};
class SyncClient final {
public:
SyncClient() = default;
explicit SyncClient(::zx::channel channel) : channel_(std::move(channel)) {}
~SyncClient() = default;
SyncClient(SyncClient&&) = default;
SyncClient& operator=(SyncClient&&) = default;
const ::zx::channel& channel() const { return channel_; }
::zx::channel* mutable_channel() { return &channel_; }
// Allocates 16 bytes of message buffer on the stack. No heap allocation
// necessary.
ResultOf::NoRequestNoResponse NoRequestNoResponse() {
return ResultOf::NoRequestNoResponse(this->channel().get());
}
// Allocates 32 bytes of message buffer on the stack. No heap allocation
// necessary.
ResultOf::NoRequestEmptyResponse NoRequestEmptyResponse() {
return ResultOf::NoRequestEmptyResponse(this->channel().get());
}
// Allocates 16 bytes of request buffer on the stack. Response is
// heap-allocated.
ResultOf::NoRequestWithResponse NoRequestWithResponse() {
return ResultOf::NoRequestWithResponse(this->channel().get());
}
// Caller provides the backing storage for FIDL message via request and
// response buffers.
UnownedResultOf::NoRequestWithResponse NoRequestWithResponse(
::fidl::BufferSpan _response_buffer) {
return UnownedResultOf::NoRequestWithResponse(this->channel().get(),
_response_buffer.data,
_response_buffer.capacity);
}
// Request is heap-allocated.
ResultOf::WithRequestNoResponse WithRequestNoResponse(
::fidl::StringView arg) {
return ResultOf::WithRequestNoResponse(this->channel().get(), arg);
}
// Caller provides the backing storage for FIDL message via request and
// response buffers.
UnownedResultOf::WithRequestNoResponse WithRequestNoResponse(
::fidl::BufferSpan _request_buffer, ::fidl::StringView arg) {
return UnownedResultOf::WithRequestNoResponse(
this->channel().get(), _request_buffer.data, _request_buffer.capacity,
arg);
}
// Allocates 16 bytes of response buffer on the stack. Request is
// heap-allocated.
ResultOf::WithRequestEmptyResponse WithRequestEmptyResponse(
::fidl::StringView arg) {
return ResultOf::WithRequestEmptyResponse(this->channel().get(), arg);
}
// Caller provides the backing storage for FIDL message via request and
// response buffers.
UnownedResultOf::WithRequestEmptyResponse WithRequestEmptyResponse(
::fidl::BufferSpan _request_buffer, ::fidl::StringView arg,
::fidl::BufferSpan _response_buffer) {
return UnownedResultOf::WithRequestEmptyResponse(
this->channel().get(), _request_buffer.data, _request_buffer.capacity,
arg, _response_buffer.data, _response_buffer.capacity);
}
// Request is heap-allocated. Response is heap-allocated.
ResultOf::WithRequestWithResponse WithRequestWithResponse(
::fidl::StringView arg) {
return ResultOf::WithRequestWithResponse(this->channel().get(), arg);
}
// Caller provides the backing storage for FIDL message via request and
// response buffers.
UnownedResultOf::WithRequestWithResponse WithRequestWithResponse(
::fidl::BufferSpan _request_buffer, ::fidl::StringView arg,
::fidl::BufferSpan _response_buffer) {
return UnownedResultOf::WithRequestWithResponse(
this->channel().get(), _request_buffer.data, _request_buffer.capacity,
arg, _response_buffer.data, _response_buffer.capacity);
}
// Handle all possible events defined in this protocol.
// Blocks to consume exactly one message from the channel, then call the
// corresponding virtual method defined in |EventHandler|. The return status
// of the handler function is folded with any transport-level errors and
// returned.
::fidl::Result HandleOneEvent(EventHandler& event_handler) {
return event_handler.HandleOneEvent(::zx::unowned_channel(channel_));
}
private:
::zx::channel channel_;
};
struct AsyncEventHandlers;
class NoRequestEmptyResponseResponseContext;
class NoRequestWithResponseResponseContext;
class WithRequestEmptyResponseResponseContext;
class WithRequestWithResponseResponseContext;
class ClientImpl;
// Pure-virtual interface to be implemented by a server.
class Interface : public ::fidl::internal::IncomingMessageDispatcher {
public:
Interface() = default;
virtual ~Interface() = default;
// The marker protocol type within which this |Interface| class is defined.
using _EnclosingProtocol = WithAndWithoutRequestResponse;
using NoRequestNoResponseCompleter = ::fidl::Completer<>;
virtual void NoRequestNoResponse(
NoRequestNoResponseCompleter::Sync& _completer) = 0;
class NoRequestEmptyResponseCompleterBase : public ::fidl::CompleterBase {
public:
// In the following methods, the return value indicates internal errors
// during the reply, such as encoding or writing to the transport. Note
// that any error will automatically lead to the destruction of the
// binding, after which the |on_unbound| callback will be triggered with a
// detailed reason.
//
// See //zircon/system/ulib/fidl/include/lib/fidl/llcpp/server.h.
//
// Because the reply status is identical to the unbinding status, it can
// be safely ignored.
::fidl::Result Reply();
protected:
using ::fidl::CompleterBase::CompleterBase;
};
using NoRequestEmptyResponseCompleter =
::fidl::Completer<NoRequestEmptyResponseCompleterBase>;
virtual void NoRequestEmptyResponse(
NoRequestEmptyResponseCompleter::Sync& _completer) = 0;
class NoRequestWithResponseCompleterBase : public ::fidl::CompleterBase {
public:
// In the following methods, the return value indicates internal errors
// during the reply, such as encoding or writing to the transport. Note
// that any error will automatically lead to the destruction of the
// binding, after which the |on_unbound| callback will be triggered with a
// detailed reason.
//
// See //zircon/system/ulib/fidl/include/lib/fidl/llcpp/server.h.
//
// Because the reply status is identical to the unbinding status, it can
// be safely ignored.
::fidl::Result Reply(::fidl::StringView ret);
::fidl::Result Reply(::fidl::BufferSpan _buffer, ::fidl::StringView ret);
protected:
using ::fidl::CompleterBase::CompleterBase;
};
using NoRequestWithResponseCompleter =
::fidl::Completer<NoRequestWithResponseCompleterBase>;
virtual void NoRequestWithResponse(
NoRequestWithResponseCompleter::Sync& _completer) = 0;
using WithRequestNoResponseCompleter = ::fidl::Completer<>;
virtual void WithRequestNoResponse(
::fidl::StringView arg,
WithRequestNoResponseCompleter::Sync& _completer) = 0;
class WithRequestEmptyResponseCompleterBase : public ::fidl::CompleterBase {
public:
// In the following methods, the return value indicates internal errors
// during the reply, such as encoding or writing to the transport. Note
// that any error will automatically lead to the destruction of the
// binding, after which the |on_unbound| callback will be triggered with a
// detailed reason.
//
// See //zircon/system/ulib/fidl/include/lib/fidl/llcpp/server.h.
//
// Because the reply status is identical to the unbinding status, it can
// be safely ignored.
::fidl::Result Reply();
protected:
using ::fidl::CompleterBase::CompleterBase;
};
using WithRequestEmptyResponseCompleter =
::fidl::Completer<WithRequestEmptyResponseCompleterBase>;
virtual void WithRequestEmptyResponse(
::fidl::StringView arg,
WithRequestEmptyResponseCompleter::Sync& _completer) = 0;
class WithRequestWithResponseCompleterBase : public ::fidl::CompleterBase {
public:
// In the following methods, the return value indicates internal errors
// during the reply, such as encoding or writing to the transport. Note
// that any error will automatically lead to the destruction of the
// binding, after which the |on_unbound| callback will be triggered with a
// detailed reason.
//
// See //zircon/system/ulib/fidl/include/lib/fidl/llcpp/server.h.
//
// Because the reply status is identical to the unbinding status, it can
// be safely ignored.
::fidl::Result Reply(::fidl::StringView ret);
::fidl::Result Reply(::fidl::BufferSpan _buffer, ::fidl::StringView ret);
protected:
using ::fidl::CompleterBase::CompleterBase;
};
using WithRequestWithResponseCompleter =
::fidl::Completer<WithRequestWithResponseCompleterBase>;
virtual void WithRequestWithResponse(
::fidl::StringView arg,
WithRequestWithResponseCompleter::Sync& _completer) = 0;
private:
::fidl::DispatchResult dispatch_message(fidl_incoming_msg_t* msg,
::fidl::Transaction* txn) final;
};
// Attempts to dispatch the incoming message to a handler function in the
// server implementation. If there is no matching handler, it returns false,
// leaving the message and transaction intact. In all other cases, it consumes
// the message and returns true. It is possible to chain multiple TryDispatch
// functions in this manner.
static ::fidl::DispatchResult TryDispatch(Interface* impl,
fidl_incoming_msg_t* msg,
::fidl::Transaction* txn);
// Dispatches the incoming message to one of the handlers functions in the
// protocol. If there is no matching handler, it closes all the handles in
// |msg| and closes the channel with a |ZX_ERR_NOT_SUPPORTED| epitaph, before
// returning false. The message should then be discarded.
static ::fidl::DispatchResult Dispatch(Interface* impl,
fidl_incoming_msg_t* msg,
::fidl::Transaction* txn);
// Same as |Dispatch|, but takes a |void*| instead of |Interface*|.
// Only used with |fidl::BindServer| to reduce template expansion.
// Do not call this method manually. Use |Dispatch| instead.
static ::fidl::DispatchResult TypeErasedDispatch(void* impl,
fidl_incoming_msg_t* msg,
::fidl::Transaction* txn) {
return Dispatch(static_cast<Interface*>(impl), msg, txn);
}
static zx_status_t SendOnEmptyResponseEvent(::zx::unowned_channel _channel);
static zx_status_t SendOnWithResponseEvent(::zx::unowned_channel _channel,
::fidl::StringView ret);
// Caller provides the backing storage for FIDL message via response buffers.
static zx_status_t SendOnWithResponseEvent(::zx::unowned_channel _channel,
::fidl::BufferSpan _buffer,
::fidl::StringView ret);
class EventSender;
class WeakEventSender;
};
extern "C" const fidl_type_t
fidl_test_protocols_WithErrorSyntaxResponseAsStructRequestTable;
extern "C" const fidl_type_t
fidl_test_protocols_WithErrorSyntaxResponseAsStructResponseTable;
extern "C" const fidl_type_t
fidl_test_protocols_WithErrorSyntaxErrorAsPrimitiveRequestTable;
extern "C" const fidl_type_t
fidl_test_protocols_WithErrorSyntaxErrorAsPrimitiveResponseTable;
extern "C" const fidl_type_t
fidl_test_protocols_WithErrorSyntaxErrorAsEnumRequestTable;
extern "C" const fidl_type_t
fidl_test_protocols_WithErrorSyntaxErrorAsEnumResponseTable;
class WithErrorSyntax final {
WithErrorSyntax() = delete;
public:
struct ResponseAsStructResponse final {
FIDL_ALIGNDECL
fidl_message_header_t _hdr;
::llcpp::fidl::test::protocols::WithErrorSyntax_ResponseAsStruct_Result
result;
explicit ResponseAsStructResponse(
::llcpp::fidl::test::protocols::WithErrorSyntax_ResponseAsStruct_Result&
result)
: result(std::move(result)) {
_InitHeader();
}
ResponseAsStructResponse() { _InitHeader(); }
static constexpr const fidl_type_t* Type =
&fidl_test_protocols_WithErrorSyntaxResponseAsStructResponseTable;
static constexpr uint32_t MaxNumHandles = 0;
static constexpr uint32_t PrimarySize = 40;
static constexpr uint32_t MaxOutOfLine = 24;
static constexpr bool HasFlexibleEnvelope = false;
static constexpr bool HasPointer = true;
static constexpr bool IsResource = false;
static constexpr ::fidl::internal::TransactionalMessageKind MessageKind =
::fidl::internal::TransactionalMessageKind::kResponse;
class UnownedEncodedMessage final {
public:
UnownedEncodedMessage(uint8_t* _bytes, uint32_t _byte_size,
::llcpp::fidl::test::protocols::
WithErrorSyntax_ResponseAsStruct_Result& result)
: message_(_bytes, _byte_size, sizeof(ResponseAsStructResponse),
nullptr, 0, 0) {
FIDL_ALIGNDECL ResponseAsStructResponse _response{result};
message_.LinearizeAndEncode<ResponseAsStructResponse>(&_response);
}
UnownedEncodedMessage(uint8_t* bytes, uint32_t byte_size,
ResponseAsStructResponse* response)
: message_(bytes, byte_size, sizeof(ResponseAsStructResponse),
nullptr, 0, 0) {
message_.LinearizeAndEncode<ResponseAsStructResponse>(response);
}
UnownedEncodedMessage(const UnownedEncodedMessage&) = delete;
UnownedEncodedMessage(UnownedEncodedMessage&&) = delete;
UnownedEncodedMessage* operator=(const UnownedEncodedMessage&) = delete;
UnownedEncodedMessage* operator=(UnownedEncodedMessage&&) = delete;
zx_status_t status() const { return message_.status(); }
#ifdef __Fuchsia__
const char* status_string() const { return message_.status_string(); }
#endif
bool ok() const { return message_.status() == ZX_OK; }
const char* error() const { return message_.error(); }
::fidl::OutgoingMessage& GetOutgoingMessage() { return message_; }
void Write(zx_handle_t client) { message_.Write(client); }
private:
ResponseAsStructResponse& Message() {
return *reinterpret_cast<ResponseAsStructResponse*>(message_.bytes());
}
::fidl::OutgoingMessage message_;
};
class OwnedEncodedMessage final {
public:
explicit OwnedEncodedMessage(
::llcpp::fidl::test::protocols::
WithErrorSyntax_ResponseAsStruct_Result& result)
: message_(bytes_, sizeof(bytes_), result) {}
explicit OwnedEncodedMessage(ResponseAsStructResponse* response)
: message_(bytes_, sizeof(bytes_), response) {}
OwnedEncodedMessage(const OwnedEncodedMessage&) = delete;
OwnedEncodedMessage(OwnedEncodedMessage&&) = delete;
OwnedEncodedMessage* operator=(const OwnedEncodedMessage&) = delete;
OwnedEncodedMessage* operator=(OwnedEncodedMessage&&) = delete;
zx_status_t status() const { return message_.status(); }
#ifdef __Fuchsia__
const char* status_string() const { return message_.status_string(); }
#endif
bool ok() const { return message_.ok(); }
const char* error() const { return message_.error(); }
::fidl::OutgoingMessage& GetOutgoingMessage() {
return message_.GetOutgoingMessage();
}
void Write(zx_handle_t client) { message_.Write(client); }
private:
FIDL_ALIGNDECL
uint8_t bytes_[PrimarySize + MaxOutOfLine];
UnownedEncodedMessage message_;
};
class DecodedMessage final : public ::fidl::internal::IncomingMessage {
public:
DecodedMessage(uint8_t* bytes, uint32_t byte_actual,
zx_handle_info_t* handles = nullptr,
uint32_t handle_actual = 0)
: ::fidl::internal::IncomingMessage(bytes, byte_actual, handles,
handle_actual) {
Decode<ResponseAsStructResponse>();
}
DecodedMessage(fidl_incoming_msg_t* msg)
: ::fidl::internal::IncomingMessage(msg) {
Decode<ResponseAsStructResponse>();
}
DecodedMessage(const DecodedMessage&) = delete;
DecodedMessage(DecodedMessage&&) = delete;
DecodedMessage* operator=(const DecodedMessage&) = delete;
DecodedMessage* operator=(DecodedMessage&&) = delete;
ResponseAsStructResponse* PrimaryObject() {
ZX_DEBUG_ASSERT(ok());
return reinterpret_cast<ResponseAsStructResponse*>(bytes());
}
// Release the ownership of the decoded message. That means that the
// handles won't be closed When the object is destroyed. After calling
// this method, the DecodedMessage object should not be used anymore.
void ReleasePrimaryObject() { ResetBytes(); }
// These methods should only be used for testing purpose.
// They create an DecodedMessage using the bytes of an outgoing message
// and copying the handles.
static DecodedMessage FromOutgoingWithRawHandleCopy(
UnownedEncodedMessage* outgoing_message) {
return DecodedMessage(outgoing_message->GetOutgoingMessage());
}
static DecodedMessage FromOutgoingWithRawHandleCopy(
OwnedEncodedMessage* outgoing_message) {
return DecodedMessage(outgoing_message->GetOutgoingMessage());
}
private:
DecodedMessage(::fidl::OutgoingMessage& outgoing_message) {
Init(outgoing_message, nullptr, 0);
if (ok()) {
Decode<ResponseAsStructResponse>();
}
}
};
private:
void _InitHeader();
};
struct ResponseAsStructRequest final {
FIDL_ALIGNDECL
fidl_message_header_t _hdr;
explicit ResponseAsStructRequest(zx_txid_t _txid) { _InitHeader(_txid); }
static constexpr const fidl_type_t* Type =
&::fidl::_llcpp_coding_AnyZeroArgMessageTable;
static constexpr uint32_t MaxNumHandles = 0;
static constexpr uint32_t PrimarySize = 16;
static constexpr uint32_t MaxOutOfLine = 0;
static constexpr uint32_t AltPrimarySize = 16;
static constexpr uint32_t AltMaxOutOfLine = 0;
static constexpr bool HasFlexibleEnvelope = false;
static constexpr bool HasPointer = false;
static constexpr bool IsResource = false;
static constexpr ::fidl::internal::TransactionalMessageKind MessageKind =
::fidl::internal::TransactionalMessageKind::kRequest;
using ResponseType = ResponseAsStructResponse;
class UnownedEncodedMessage final {
public:
UnownedEncodedMessage(uint8_t* _bytes, uint32_t _byte_size,
zx_txid_t _txid)
: message_(_bytes, _byte_size, sizeof(ResponseAsStructRequest),
nullptr, 0, 0) {
FIDL_ALIGNDECL ResponseAsStructRequest _request(_txid);
message_.LinearizeAndEncode<ResponseAsStructRequest>(&_request);
}
UnownedEncodedMessage(uint8_t* bytes, uint32_t byte_size,
ResponseAsStructRequest* request)
: message_(bytes, byte_size, sizeof(ResponseAsStructRequest), nullptr,
0, 0) {
message_.LinearizeAndEncode<ResponseAsStructRequest>(request);
}
UnownedEncodedMessage(const UnownedEncodedMessage&) = delete;
UnownedEncodedMessage(UnownedEncodedMessage&&) = delete;
UnownedEncodedMessage* operator=(const UnownedEncodedMessage&) = delete;
UnownedEncodedMessage* operator=(UnownedEncodedMessage&&) = delete;
zx_status_t status() const { return message_.status(); }
#ifdef __Fuchsia__
const char* status_string() const { return message_.status_string(); }
#endif
bool ok() const { return message_.status() == ZX_OK; }
const char* error() const { return message_.error(); }
::fidl::OutgoingMessage& GetOutgoingMessage() { return message_; }
void Write(zx_handle_t client) { message_.Write(client); }
private:
ResponseAsStructRequest& Message() {
return *reinterpret_cast<ResponseAsStructRequest*>(message_.bytes());
}
::fidl::OutgoingMessage message_;
};
class OwnedEncodedMessage final {
public:
explicit OwnedEncodedMessage(zx_txid_t _txid)
: message_(bytes_, sizeof(bytes_), _txid) {}
explicit OwnedEncodedMessage(ResponseAsStructRequest* request)
: message_(bytes_, sizeof(bytes_), request) {}
OwnedEncodedMessage(const OwnedEncodedMessage&) = delete;
OwnedEncodedMessage(OwnedEncodedMessage&&) = delete;
OwnedEncodedMessage* operator=(const OwnedEncodedMessage&) = delete;
OwnedEncodedMessage* operator=(OwnedEncodedMessage&&) = delete;
zx_status_t status() const { return message_.status(); }
#ifdef __Fuchsia__
const char* status_string() const { return message_.status_string(); }
#endif
bool ok() const { return message_.ok(); }
const char* error() const { return message_.error(); }
::fidl::OutgoingMessage& GetOutgoingMessage() {
return message_.GetOutgoingMessage();
}
void Write(zx_handle_t client) { message_.Write(client); }
private:
FIDL_ALIGNDECL
uint8_t bytes_[PrimarySize + MaxOutOfLine];
UnownedEncodedMessage message_;
};
class DecodedMessage final : public ::fidl::internal::IncomingMessage {
public:
DecodedMessage(uint8_t* bytes, uint32_t byte_actual,
zx_handle_info_t* handles = nullptr,
uint32_t handle_actual = 0)
: ::fidl::internal::IncomingMessage(bytes, byte_actual, handles,
handle_actual) {
Decode<ResponseAsStructRequest>();
}
DecodedMessage(fidl_incoming_msg_t* msg)
: ::fidl::internal::IncomingMessage(msg) {
Decode<ResponseAsStructRequest>();
}
DecodedMessage(const DecodedMessage&) = delete;
DecodedMessage(DecodedMessage&&) = delete;
DecodedMessage* operator=(const DecodedMessage&) = delete;
DecodedMessage* operator=(DecodedMessage&&) = delete;
ResponseAsStructRequest* PrimaryObject() {
ZX_DEBUG_ASSERT(ok());
return reinterpret_cast<ResponseAsStructRequest*>(bytes());
}
// Release the ownership of the decoded message. That means that the
// handles won't be closed When the object is destroyed. After calling
// this method, the DecodedMessage object should not be used anymore.
void ReleasePrimaryObject() { ResetBytes(); }
// These methods should only be used for testing purpose.
// They create an DecodedMessage using the bytes of an outgoing message
// and copying the handles.
static DecodedMessage FromOutgoingWithRawHandleCopy(
UnownedEncodedMessage* encoded_message) {
return DecodedMessage(encoded_message->GetOutgoingMessage());
}
static DecodedMessage FromOutgoingWithRawHandleCopy(
OwnedEncodedMessage* encoded_message) {
return DecodedMessage(encoded_message->GetOutgoingMessage());
}
private:
DecodedMessage(::fidl::OutgoingMessage& outgoing_message) {
Init(outgoing_message, nullptr, 0);
if (ok()) {
Decode<ResponseAsStructRequest>();
}
}
};
private:
void _InitHeader(zx_txid_t _txid);
};
struct ErrorAsPrimitiveResponse final {
FIDL_ALIGNDECL
fidl_message_header_t _hdr;
::llcpp::fidl::test::protocols::WithErrorSyntax_ErrorAsPrimitive_Result
result;
explicit ErrorAsPrimitiveResponse(
::llcpp::fidl::test::protocols::WithErrorSyntax_ErrorAsPrimitive_Result&
result)
: result(std::move(result)) {
_InitHeader();
}
ErrorAsPrimitiveResponse() { _InitHeader(); }
static constexpr const fidl_type_t* Type =
&fidl_test_protocols_WithErrorSyntaxErrorAsPrimitiveResponseTable;
static constexpr uint32_t MaxNumHandles = 0;
static constexpr uint32_t PrimarySize = 40;
static constexpr uint32_t MaxOutOfLine = 8;
static constexpr bool HasFlexibleEnvelope = false;
static constexpr bool HasPointer = true;
static constexpr bool IsResource = false;
static constexpr ::fidl::internal::TransactionalMessageKind MessageKind =
::fidl::internal::TransactionalMessageKind::kResponse;
class UnownedEncodedMessage final {
public:
UnownedEncodedMessage(uint8_t* _bytes, uint32_t _byte_size,
::llcpp::fidl::test::protocols::
WithErrorSyntax_ErrorAsPrimitive_Result& result)
: message_(_bytes, _byte_size, sizeof(ErrorAsPrimitiveResponse),
nullptr, 0, 0) {
FIDL_ALIGNDECL ErrorAsPrimitiveResponse _response{result};
message_.LinearizeAndEncode<ErrorAsPrimitiveResponse>(&_response);
}
UnownedEncodedMessage(uint8_t* bytes, uint32_t byte_size,
ErrorAsPrimitiveResponse* response)
: message_(bytes, byte_size, sizeof(ErrorAsPrimitiveResponse),
nullptr, 0, 0) {
message_.LinearizeAndEncode<ErrorAsPrimitiveResponse>(response);
}
UnownedEncodedMessage(const UnownedEncodedMessage&) = delete;
UnownedEncodedMessage(UnownedEncodedMessage&&) = delete;
UnownedEncodedMessage* operator=(const UnownedEncodedMessage&) = delete;
UnownedEncodedMessage* operator=(UnownedEncodedMessage&&) = delete;
zx_status_t status() const { return message_.status(); }
#ifdef __Fuchsia__
const char* status_string() const { return message_.status_string(); }
#endif
bool ok() const { return message_.status() == ZX_OK; }
const char* error() const { return message_.error(); }
::fidl::OutgoingMessage& GetOutgoingMessage() { return message_; }
void Write(zx_handle_t client) { message_.Write(client); }
private:
ErrorAsPrimitiveResponse& Message() {
return *reinterpret_cast<ErrorAsPrimitiveResponse*>(message_.bytes());
}
::fidl::OutgoingMessage message_;
};
class OwnedEncodedMessage final {
public:
explicit OwnedEncodedMessage(
::llcpp::fidl::test::protocols::
WithErrorSyntax_ErrorAsPrimitive_Result& result)
: message_(bytes_, sizeof(bytes_), result) {}
explicit OwnedEncodedMessage(ErrorAsPrimitiveResponse* response)
: message_(bytes_, sizeof(bytes_), response) {}
OwnedEncodedMessage(const OwnedEncodedMessage&) = delete;
OwnedEncodedMessage(OwnedEncodedMessage&&) = delete;
OwnedEncodedMessage* operator=(const OwnedEncodedMessage&) = delete;
OwnedEncodedMessage* operator=(OwnedEncodedMessage&&) = delete;
zx_status_t status() const { return message_.status(); }
#ifdef __Fuchsia__
const char* status_string() const { return message_.status_string(); }
#endif
bool ok() const { return message_.ok(); }
const char* error() const { return message_.error(); }
::fidl::OutgoingMessage& GetOutgoingMessage() {
return message_.GetOutgoingMessage();
}
void Write(zx_handle_t client) { message_.Write(client); }
private:
FIDL_ALIGNDECL
uint8_t bytes_[PrimarySize + MaxOutOfLine];
UnownedEncodedMessage message_;
};
class DecodedMessage final : public ::fidl::internal::IncomingMessage {
public:
DecodedMessage(uint8_t* bytes, uint32_t byte_actual,
zx_handle_info_t* handles = nullptr,
uint32_t handle_actual = 0)
: ::fidl::internal::IncomingMessage(bytes, byte_actual, handles,
handle_actual) {
Decode<ErrorAsPrimitiveResponse>();
}
DecodedMessage(fidl_incoming_msg_t* msg)
: ::fidl::internal::IncomingMessage(msg) {
Decode<ErrorAsPrimitiveResponse>();
}
DecodedMessage(const DecodedMessage&) = delete;
DecodedMessage(DecodedMessage&&) = delete;
DecodedMessage* operator=(const DecodedMessage&) = delete;
DecodedMessage* operator=(DecodedMessage&&) = delete;
ErrorAsPrimitiveResponse* PrimaryObject() {
ZX_DEBUG_ASSERT(ok());
return reinterpret_cast<ErrorAsPrimitiveResponse*>(bytes());
}
// Release the ownership of the decoded message. That means that the
// handles won't be closed When the object is destroyed. After calling
// this method, the DecodedMessage object should not be used anymore.
void ReleasePrimaryObject() { ResetBytes(); }
// These methods should only be used for testing purpose.
// They create an DecodedMessage using the bytes of an outgoing message
// and copying the handles.
static DecodedMessage FromOutgoingWithRawHandleCopy(
UnownedEncodedMessage* outgoing_message) {
return DecodedMessage(outgoing_message->GetOutgoingMessage());
}
static DecodedMessage FromOutgoingWithRawHandleCopy(
OwnedEncodedMessage* outgoing_message) {
return DecodedMessage(outgoing_message->GetOutgoingMessage());
}
private:
DecodedMessage(::fidl::OutgoingMessage& outgoing_message) {
Init(outgoing_message, nullptr, 0);
if (ok()) {
Decode<ErrorAsPrimitiveResponse>();
}
}
};
private:
void _InitHeader();
};
struct ErrorAsPrimitiveRequest final {
FIDL_ALIGNDECL
fidl_message_header_t _hdr;
explicit ErrorAsPrimitiveRequest(zx_txid_t _txid) { _InitHeader(_txid); }
static constexpr const fidl_type_t* Type =
&::fidl::_llcpp_coding_AnyZeroArgMessageTable;
static constexpr uint32_t MaxNumHandles = 0;
static constexpr uint32_t PrimarySize = 16;
static constexpr uint32_t MaxOutOfLine = 0;
static constexpr uint32_t AltPrimarySize = 16;
static constexpr uint32_t AltMaxOutOfLine = 0;
static constexpr bool HasFlexibleEnvelope = false;
static constexpr bool HasPointer = false;
static constexpr bool IsResource = false;
static constexpr ::fidl::internal::TransactionalMessageKind MessageKind =
::fidl::internal::TransactionalMessageKind::kRequest;
using ResponseType = ErrorAsPrimitiveResponse;
class UnownedEncodedMessage final {
public:
UnownedEncodedMessage(uint8_t* _bytes, uint32_t _byte_size,
zx_txid_t _txid)
: message_(_bytes, _byte_size, sizeof(ErrorAsPrimitiveRequest),
nullptr, 0, 0) {
FIDL_ALIGNDECL ErrorAsPrimitiveRequest _request(_txid);
message_.LinearizeAndEncode<ErrorAsPrimitiveRequest>(&_request);
}
UnownedEncodedMessage(uint8_t* bytes, uint32_t byte_size,
ErrorAsPrimitiveRequest* request)
: message_(bytes, byte_size, sizeof(ErrorAsPrimitiveRequest), nullptr,
0, 0) {
message_.LinearizeAndEncode<ErrorAsPrimitiveRequest>(request);
}
UnownedEncodedMessage(const UnownedEncodedMessage&) = delete;
UnownedEncodedMessage(UnownedEncodedMessage&&) = delete;
UnownedEncodedMessage* operator=(const UnownedEncodedMessage&) = delete;
UnownedEncodedMessage* operator=(UnownedEncodedMessage&&) = delete;
zx_status_t status() const { return message_.status(); }
#ifdef __Fuchsia__
const char* status_string() const { return message_.status_string(); }
#endif
bool ok() const { return message_.status() == ZX_OK; }
const char* error() const { return message_.error(); }
::fidl::OutgoingMessage& GetOutgoingMessage() { return message_; }
void Write(zx_handle_t client) { message_.Write(client); }
private:
ErrorAsPrimitiveRequest& Message() {
return *reinterpret_cast<ErrorAsPrimitiveRequest*>(message_.bytes());
}
::fidl::OutgoingMessage message_;
};
class OwnedEncodedMessage final {
public:
explicit OwnedEncodedMessage(zx_txid_t _txid)
: message_(bytes_, sizeof(bytes_), _txid) {}
explicit OwnedEncodedMessage(ErrorAsPrimitiveRequest* request)
: message_(bytes_, sizeof(bytes_), request) {}
OwnedEncodedMessage(const OwnedEncodedMessage&) = delete;
OwnedEncodedMessage(OwnedEncodedMessage&&) = delete;
OwnedEncodedMessage* operator=(const OwnedEncodedMessage&) = delete;
OwnedEncodedMessage* operator=(OwnedEncodedMessage&&) = delete;
zx_status_t status() const { return message_.status(); }
#ifdef __Fuchsia__
const char* status_string() const { return message_.status_string(); }
#endif
bool ok() const { return message_.ok(); }
const char* error() const { return message_.error(); }
::fidl::OutgoingMessage& GetOutgoingMessage() {
return message_.GetOutgoingMessage();
}
void Write(zx_handle_t client) { message_.Write(client); }
private:
FIDL_ALIGNDECL
uint8_t bytes_[PrimarySize + MaxOutOfLine];
UnownedEncodedMessage message_;
};
class DecodedMessage final : public ::fidl::internal::IncomingMessage {
public:
DecodedMessage(uint8_t* bytes, uint32_t byte_actual,
zx_handle_info_t* handles = nullptr,
uint32_t handle_actual = 0)
: ::fidl::internal::IncomingMessage(bytes, byte_actual, handles,
handle_actual) {
Decode<ErrorAsPrimitiveRequest>();
}
DecodedMessage(fidl_incoming_msg_t* msg)
: ::fidl::internal::IncomingMessage(msg) {
Decode<ErrorAsPrimitiveRequest>();
}
DecodedMessage(const DecodedMessage&) = delete;
DecodedMessage(DecodedMessage&&) = delete;
DecodedMessage* operator=(const DecodedMessage&) = delete;
DecodedMessage* operator=(DecodedMessage&&) = delete;
ErrorAsPrimitiveRequest* PrimaryObject() {
ZX_DEBUG_ASSERT(ok());
return reinterpret_cast<ErrorAsPrimitiveRequest*>(bytes());
}
// Release the ownership of the decoded message. That means that the
// handles won't be closed When the object is destroyed. After calling
// this method, the DecodedMessage object should not be used anymore.
void ReleasePrimaryObject() { ResetBytes(); }
// These methods should only be used for testing purpose.
// They create an DecodedMessage using the bytes of an outgoing message
// and copying the handles.
static DecodedMessage FromOutgoingWithRawHandleCopy(
UnownedEncodedMessage* encoded_message) {
return DecodedMessage(encoded_message->GetOutgoingMessage());
}
static DecodedMessage FromOutgoingWithRawHandleCopy(
OwnedEncodedMessage* encoded_message) {
return DecodedMessage(encoded_message->GetOutgoingMessage());
}
private:
DecodedMessage(::fidl::OutgoingMessage& outgoing_message) {
Init(outgoing_message, nullptr, 0);
if (ok()) {
Decode<ErrorAsPrimitiveRequest>();
}
}
};
private:
void _InitHeader(zx_txid_t _txid);
};
struct ErrorAsEnumResponse final {
FIDL_ALIGNDECL
fidl_message_header_t _hdr;
::llcpp::fidl::test::protocols::WithErrorSyntax_ErrorAsEnum_Result result;
explicit ErrorAsEnumResponse(
::llcpp::fidl::test::protocols::WithErrorSyntax_ErrorAsEnum_Result&
result)
: result(std::move(result)) {
_InitHeader();
}
ErrorAsEnumResponse() { _InitHeader(); }
static constexpr const fidl_type_t* Type =
&fidl_test_protocols_WithErrorSyntaxErrorAsEnumResponseTable;
static constexpr uint32_t MaxNumHandles = 0;
static constexpr uint32_t PrimarySize = 40;
static constexpr uint32_t MaxOutOfLine = 8;
static constexpr bool HasFlexibleEnvelope = false;
static constexpr bool HasPointer = true;
static constexpr bool IsResource = false;
static constexpr ::fidl::internal::TransactionalMessageKind MessageKind =
::fidl::internal::TransactionalMessageKind::kResponse;
class UnownedEncodedMessage final {
public:
UnownedEncodedMessage(
uint8_t* _bytes, uint32_t _byte_size,
::llcpp::fidl::test::protocols::WithErrorSyntax_ErrorAsEnum_Result&
result)
: message_(_bytes, _byte_size, sizeof(ErrorAsEnumResponse), nullptr,
0, 0) {
FIDL_ALIGNDECL ErrorAsEnumResponse _response{result};
message_.LinearizeAndEncode<ErrorAsEnumResponse>(&_response);
}
UnownedEncodedMessage(uint8_t* bytes, uint32_t byte_size,
ErrorAsEnumResponse* response)
: message_(bytes, byte_size, sizeof(ErrorAsEnumResponse), nullptr, 0,
0) {
message_.LinearizeAndEncode<ErrorAsEnumResponse>(response);
}
UnownedEncodedMessage(const UnownedEncodedMessage&) = delete;
UnownedEncodedMessage(UnownedEncodedMessage&&) = delete;
UnownedEncodedMessage* operator=(const UnownedEncodedMessage&) = delete;
UnownedEncodedMessage* operator=(UnownedEncodedMessage&&) = delete;
zx_status_t status() const { return message_.status(); }
#ifdef __Fuchsia__
const char* status_string() const { return message_.status_string(); }
#endif
bool ok() const { return message_.status() == ZX_OK; }
const char* error() const { return message_.error(); }
::fidl::OutgoingMessage& GetOutgoingMessage() { return message_; }
void Write(zx_handle_t client) { message_.Write(client); }
private:
ErrorAsEnumResponse& Message() {
return *reinterpret_cast<ErrorAsEnumResponse*>(message_.bytes());
}
::fidl::OutgoingMessage message_;
};
class OwnedEncodedMessage final {
public:
explicit OwnedEncodedMessage(
::llcpp::fidl::test::protocols::WithErrorSyntax_ErrorAsEnum_Result&
result)
: message_(bytes_, sizeof(bytes_), result) {}
explicit OwnedEncodedMessage(ErrorAsEnumResponse* response)
: message_(bytes_, sizeof(bytes_), response) {}
OwnedEncodedMessage(const OwnedEncodedMessage&) = delete;
OwnedEncodedMessage(OwnedEncodedMessage&&) = delete;
OwnedEncodedMessage* operator=(const OwnedEncodedMessage&) = delete;
OwnedEncodedMessage* operator=(OwnedEncodedMessage&&) = delete;
zx_status_t status() const { return message_.status(); }
#ifdef __Fuchsia__
const char* status_string() const { return message_.status_string(); }
#endif
bool ok() const { return message_.ok(); }
const char* error() const { return message_.error(); }
::fidl::OutgoingMessage& GetOutgoingMessage() {
return message_.GetOutgoingMessage();
}
void Write(zx_handle_t client) { message_.Write(client); }
private:
FIDL_ALIGNDECL
uint8_t bytes_[PrimarySize + MaxOutOfLine];
UnownedEncodedMessage message_;
};
class DecodedMessage final : public ::fidl::internal::IncomingMessage {
public:
DecodedMessage(uint8_t* bytes, uint32_t byte_actual,
zx_handle_info_t* handles = nullptr,
uint32_t handle_actual = 0)
: ::fidl::internal::IncomingMessage(bytes, byte_actual, handles,
handle_actual) {
Decode<ErrorAsEnumResponse>();
}
DecodedMessage(fidl_incoming_msg_t* msg)
: ::fidl::internal::IncomingMessage(msg) {
Decode<ErrorAsEnumResponse>();
}
DecodedMessage(const DecodedMessage&) = delete;
DecodedMessage(DecodedMessage&&) = delete;
DecodedMessage* operator=(const DecodedMessage&) = delete;
DecodedMessage* operator=(DecodedMessage&&) = delete;
ErrorAsEnumResponse* PrimaryObject() {
ZX_DEBUG_ASSERT(ok());
return reinterpret_cast<ErrorAsEnumResponse*>(bytes());
}
// Release the ownership of the decoded message. That means that the
// handles won't be closed When the object is destroyed. After calling
// this method, the DecodedMessage object should not be used anymore.
void ReleasePrimaryObject() { ResetBytes(); }
// These methods should only be used for testing purpose.
// They create an DecodedMessage using the bytes of an outgoing message
// and copying the handles.
static DecodedMessage FromOutgoingWithRawHandleCopy(
UnownedEncodedMessage* outgoing_message) {
return DecodedMessage(outgoing_message->GetOutgoingMessage());
}
static DecodedMessage FromOutgoingWithRawHandleCopy(
OwnedEncodedMessage* outgoing_message) {
return DecodedMessage(outgoing_message->GetOutgoingMessage());
}
private:
DecodedMessage(::fidl::OutgoingMessage& outgoing_message) {
Init(outgoing_message, nullptr, 0);
if (ok()) {
Decode<ErrorAsEnumResponse>();
}
}
};
private:
void _InitHeader();
};
struct ErrorAsEnumRequest final {
FIDL_ALIGNDECL
fidl_message_header_t _hdr;
explicit ErrorAsEnumRequest(zx_txid_t _txid) { _InitHeader(_txid); }
static constexpr const fidl_type_t* Type =
&::fidl::_llcpp_coding_AnyZeroArgMessageTable;
static constexpr uint32_t MaxNumHandles = 0;
static constexpr uint32_t PrimarySize = 16;
static constexpr uint32_t MaxOutOfLine = 0;
static constexpr uint32_t AltPrimarySize = 16;
static constexpr uint32_t AltMaxOutOfLine = 0;
static constexpr bool HasFlexibleEnvelope = false;
static constexpr bool HasPointer = false;
static constexpr bool IsResource = false;
static constexpr ::fidl::internal::TransactionalMessageKind MessageKind =
::fidl::internal::TransactionalMessageKind::kRequest;
using ResponseType = ErrorAsEnumResponse;
class UnownedEncodedMessage final {
public:
UnownedEncodedMessage(uint8_t* _bytes, uint32_t _byte_size,
zx_txid_t _txid)
: message_(_bytes, _byte_size, sizeof(ErrorAsEnumRequest), nullptr, 0,
0) {
FIDL_ALIGNDECL ErrorAsEnumRequest _request(_txid);
message_.LinearizeAndEncode<ErrorAsEnumRequest>(&_request);
}
UnownedEncodedMessage(uint8_t* bytes, uint32_t byte_size,
ErrorAsEnumRequest* request)
: message_(bytes, byte_size, sizeof(ErrorAsEnumRequest), nullptr, 0,
0) {
message_.LinearizeAndEncode<ErrorAsEnumRequest>(request);
}
UnownedEncodedMessage(const UnownedEncodedMessage&) = delete;
UnownedEncodedMessage(UnownedEncodedMessage&&) = delete;
UnownedEncodedMessage* operator=(const UnownedEncodedMessage&) = delete;
UnownedEncodedMessage* operator=(UnownedEncodedMessage&&) = delete;
zx_status_t status() const { return message_.status(); }
#ifdef __Fuchsia__
const char* status_string() const { return message_.status_string(); }
#endif
bool ok() const { return message_.status() == ZX_OK; }
const char* error() const { return message_.error(); }
::fidl::OutgoingMessage& GetOutgoingMessage() { return message_; }
void Write(zx_handle_t client) { message_.Write(client); }
private:
ErrorAsEnumRequest& Message() {
return *reinterpret_cast<ErrorAsEnumRequest*>(message_.bytes());
}
::fidl::OutgoingMessage message_;
};
class OwnedEncodedMessage final {
public:
explicit OwnedEncodedMessage(zx_txid_t _txid)
: message_(bytes_, sizeof(bytes_), _txid) {}
explicit OwnedEncodedMessage(ErrorAsEnumRequest* request)
: message_(bytes_, sizeof(bytes_), request) {}
OwnedEncodedMessage(const OwnedEncodedMessage&) = delete;
OwnedEncodedMessage(OwnedEncodedMessage&&) = delete;
OwnedEncodedMessage* operator=(const OwnedEncodedMessage&) = delete;
OwnedEncodedMessage* operator=(OwnedEncodedMessage&&) = delete;
zx_status_t status() const { return message_.status(); }
#ifdef __Fuchsia__
const char* status_string() const { return message_.status_string(); }
#endif
bool ok() const { return message_.ok(); }
const char* error() const { return message_.error(); }
::fidl::OutgoingMessage& GetOutgoingMessage() {
return message_.GetOutgoingMessage();
}
void Write(zx_handle_t client) { message_.Write(client); }
private:
FIDL_ALIGNDECL
uint8_t bytes_[PrimarySize + MaxOutOfLine];
UnownedEncodedMessage message_;
};
class DecodedMessage final : public ::fidl::internal::IncomingMessage {
public:
DecodedMessage(uint8_t* bytes, uint32_t byte_actual,
zx_handle_info_t* handles = nullptr,
uint32_t handle_actual = 0)
: ::fidl::internal::IncomingMessage(bytes, byte_actual, handles,
handle_actual) {
Decode<ErrorAsEnumRequest>();
}
DecodedMessage(fidl_incoming_msg_t* msg)
: ::fidl::internal::IncomingMessage(msg) {
Decode<ErrorAsEnumRequest>();
}
DecodedMessage(const DecodedMessage&) = delete;
DecodedMessage(DecodedMessage&&) = delete;
DecodedMessage* operator=(const DecodedMessage&) = delete;
DecodedMessage* operator=(DecodedMessage&&) = delete;
ErrorAsEnumRequest* PrimaryObject() {
ZX_DEBUG_ASSERT(ok());
return reinterpret_cast<ErrorAsEnumRequest*>(bytes());
}
// Release the ownership of the decoded message. That means that the
// handles won't be closed When the object is destroyed. After calling
// this method, the DecodedMessage object should not be used anymore.
void ReleasePrimaryObject() { ResetBytes(); }
// These methods should only be used for testing purpose.
// They create an DecodedMessage using the bytes of an outgoing message
// and copying the handles.
static DecodedMessage FromOutgoingWithRawHandleCopy(
UnownedEncodedMessage* encoded_message) {
return DecodedMessage(encoded_message->GetOutgoingMessage());
}
static DecodedMessage FromOutgoingWithRawHandleCopy(
OwnedEncodedMessage* encoded_message) {
return DecodedMessage(encoded_message->GetOutgoingMessage());
}
private:
DecodedMessage(::fidl::OutgoingMessage& outgoing_message) {
Init(outgoing_message, nullptr, 0);
if (ok()) {
Decode<ErrorAsEnumRequest>();
}
}
};
private:
void _InitHeader(zx_txid_t _txid);
};
// Collection of return types of FIDL calls in this protocol.
class ResultOf final {
ResultOf() = delete;
public:
class ResponseAsStruct final : public ::fidl::Result {
public:
explicit ResponseAsStruct(zx_handle_t _client);
ResponseAsStruct(zx_handle_t _client, zx_time_t _deadline);
explicit ResponseAsStruct(const ::fidl::Result& result)
: ::fidl::Result(result) {}
ResponseAsStruct(ResponseAsStruct&&) = delete;
ResponseAsStruct(const ResponseAsStruct&) = delete;
ResponseAsStruct* operator=(ResponseAsStruct&&) = delete;
ResponseAsStruct* operator=(const ResponseAsStruct&) = delete;
~ResponseAsStruct() = default;
ResponseAsStructResponse* Unwrap() {
ZX_DEBUG_ASSERT(ok());
return reinterpret_cast<ResponseAsStructResponse*>(bytes_);
}
const ResponseAsStructResponse* Unwrap() const {
ZX_DEBUG_ASSERT(ok());
return reinterpret_cast<const ResponseAsStructResponse*>(bytes_);
}
ResponseAsStructResponse& value() { return *Unwrap(); }
const ResponseAsStructResponse& value() const { return *Unwrap(); }
ResponseAsStructResponse* operator->() { return &value(); }
const ResponseAsStructResponse* operator->() const { return &value(); }
ResponseAsStructResponse& operator*() { return value(); }
const ResponseAsStructResponse& operator*() const { return value(); }
private:
FIDL_ALIGNDECL
uint8_t bytes_[ResponseAsStructResponse::PrimarySize +
ResponseAsStructResponse::MaxOutOfLine];
};
class ErrorAsPrimitive final : public ::fidl::Result {
public:
explicit ErrorAsPrimitive(zx_handle_t _client);
ErrorAsPrimitive(zx_handle_t _client, zx_time_t _deadline);
explicit ErrorAsPrimitive(const ::fidl::Result& result)
: ::fidl::Result(result) {}
ErrorAsPrimitive(ErrorAsPrimitive&&) = delete;
ErrorAsPrimitive(const ErrorAsPrimitive&) = delete;
ErrorAsPrimitive* operator=(ErrorAsPrimitive&&) = delete;
ErrorAsPrimitive* operator=(const ErrorAsPrimitive&) = delete;
~ErrorAsPrimitive() = default;
ErrorAsPrimitiveResponse* Unwrap() {
ZX_DEBUG_ASSERT(ok());
return reinterpret_cast<ErrorAsPrimitiveResponse*>(bytes_);
}
const ErrorAsPrimitiveResponse* Unwrap() const {
ZX_DEBUG_ASSERT(ok());
return reinterpret_cast<const ErrorAsPrimitiveResponse*>(bytes_);
}
ErrorAsPrimitiveResponse& value() { return *Unwrap(); }
const ErrorAsPrimitiveResponse& value() const { return *Unwrap(); }
ErrorAsPrimitiveResponse* operator->() { return &value(); }
const ErrorAsPrimitiveResponse* operator->() const { return &value(); }
ErrorAsPrimitiveResponse& operator*() { return value(); }
const ErrorAsPrimitiveResponse& operator*() const { return value(); }
private:
FIDL_ALIGNDECL
uint8_t bytes_[ErrorAsPrimitiveResponse::PrimarySize +
ErrorAsPrimitiveResponse::MaxOutOfLine];
};
class ErrorAsEnum final : public ::fidl::Result {
public:
explicit ErrorAsEnum(zx_handle_t _client);
ErrorAsEnum(zx_handle_t _client, zx_time_t _deadline);
explicit ErrorAsEnum(const ::fidl::Result& result)
: ::fidl::Result(result) {}
ErrorAsEnum(ErrorAsEnum&&) = delete;
ErrorAsEnum(const ErrorAsEnum&) = delete;
ErrorAsEnum* operator=(ErrorAsEnum&&) = delete;
ErrorAsEnum* operator=(const ErrorAsEnum&) = delete;
~ErrorAsEnum() = default;
ErrorAsEnumResponse* Unwrap() {
ZX_DEBUG_ASSERT(ok());
return reinterpret_cast<ErrorAsEnumResponse*>(bytes_);
}
const ErrorAsEnumResponse* Unwrap() const {
ZX_DEBUG_ASSERT(ok());
return reinterpret_cast<const ErrorAsEnumResponse*>(bytes_);
}
ErrorAsEnumResponse& value() { return *Unwrap(); }
const ErrorAsEnumResponse& value() const { return *Unwrap(); }
ErrorAsEnumResponse* operator->() { return &value(); }
const ErrorAsEnumResponse* operator->() const { return &value(); }
ErrorAsEnumResponse& operator*() { return value(); }
const ErrorAsEnumResponse& operator*() const { return value(); }
private:
FIDL_ALIGNDECL
uint8_t bytes_[ErrorAsEnumResponse::PrimarySize +
ErrorAsEnumResponse::MaxOutOfLine];
};
};
// Collection of return types of FIDL calls in this protocol,
// when the caller-allocate flavor or in-place call is used.
class UnownedResultOf final {
UnownedResultOf() = delete;
public:
class ResponseAsStruct final : public ::fidl::Result {
public:
explicit ResponseAsStruct(zx_handle_t _client, uint8_t* _response_bytes,
uint32_t _response_byte_capacity);
explicit ResponseAsStruct(const ::fidl::Result& result)
: ::fidl::Result(result) {}
ResponseAsStruct(ResponseAsStruct&&) = delete;
ResponseAsStruct(const ResponseAsStruct&) = delete;
ResponseAsStruct* operator=(ResponseAsStruct&&) = delete;
ResponseAsStruct* operator=(const ResponseAsStruct&) = delete;
~ResponseAsStruct() = default;
ResponseAsStructResponse* Unwrap() {
ZX_DEBUG_ASSERT(ok());
return reinterpret_cast<ResponseAsStructResponse*>(bytes_);
}
const ResponseAsStructResponse* Unwrap() const {
ZX_DEBUG_ASSERT(ok());
return reinterpret_cast<const ResponseAsStructResponse*>(bytes_);
}
ResponseAsStructResponse& value() { return *Unwrap(); }
const ResponseAsStructResponse& value() const { return *Unwrap(); }
ResponseAsStructResponse* operator->() { return &value(); }
const ResponseAsStructResponse* operator->() const { return &value(); }
ResponseAsStructResponse& operator*() { return value(); }
const ResponseAsStructResponse& operator*() const { return value(); }
private:
uint8_t* bytes_;
};
class ErrorAsPrimitive final : public ::fidl::Result {
public:
explicit ErrorAsPrimitive(zx_handle_t _client, uint8_t* _response_bytes,
uint32_t _response_byte_capacity);
explicit ErrorAsPrimitive(const ::fidl::Result& result)
: ::fidl::Result(result) {}
ErrorAsPrimitive(ErrorAsPrimitive&&) = delete;
ErrorAsPrimitive(const ErrorAsPrimitive&) = delete;
ErrorAsPrimitive* operator=(ErrorAsPrimitive&&) = delete;
ErrorAsPrimitive* operator=(const ErrorAsPrimitive&) = delete;
~ErrorAsPrimitive() = default;
ErrorAsPrimitiveResponse* Unwrap() {
ZX_DEBUG_ASSERT(ok());
return reinterpret_cast<ErrorAsPrimitiveResponse*>(bytes_);
}
const ErrorAsPrimitiveResponse* Unwrap() const {
ZX_DEBUG_ASSERT(ok());
return reinterpret_cast<const ErrorAsPrimitiveResponse*>(bytes_);
}
ErrorAsPrimitiveResponse& value() { return *Unwrap(); }
const ErrorAsPrimitiveResponse& value() const { return *Unwrap(); }
ErrorAsPrimitiveResponse* operator->() { return &value(); }
const ErrorAsPrimitiveResponse* operator->() const { return &value(); }
ErrorAsPrimitiveResponse& operator*() { return value(); }
const ErrorAsPrimitiveResponse& operator*() const { return value(); }
private:
uint8_t* bytes_;
};
class ErrorAsEnum final : public ::fidl::Result {
public:
explicit ErrorAsEnum(zx_handle_t _client, uint8_t* _response_bytes,
uint32_t _response_byte_capacity);
explicit ErrorAsEnum(const ::fidl::Result& result)
: ::fidl::Result(result) {}
ErrorAsEnum(ErrorAsEnum&&) = delete;
ErrorAsEnum(const ErrorAsEnum&) = delete;
ErrorAsEnum* operator=(ErrorAsEnum&&) = delete;
ErrorAsEnum* operator=(const ErrorAsEnum&) = delete;
~ErrorAsEnum() = default;
ErrorAsEnumResponse* Unwrap() {
ZX_DEBUG_ASSERT(ok());
return reinterpret_cast<ErrorAsEnumResponse*>(bytes_);
}
const ErrorAsEnumResponse* Unwrap() const {
ZX_DEBUG_ASSERT(ok());
return reinterpret_cast<const ErrorAsEnumResponse*>(bytes_);
}
ErrorAsEnumResponse& value() { return *Unwrap(); }
const ErrorAsEnumResponse& value() const { return *Unwrap(); }
ErrorAsEnumResponse* operator->() { return &value(); }
const ErrorAsEnumResponse* operator->() const { return &value(); }
ErrorAsEnumResponse& operator*() { return value(); }
const ErrorAsEnumResponse& operator*() const { return value(); }
private:
uint8_t* bytes_;
};
};
// Methods to make a sync FIDL call directly on an unowned channel, avoiding
// setting up a client.
class Call final {
Call() = delete;
public:
// Allocates 80 bytes of message buffer on the stack. No heap allocation
// necessary.
static ResultOf::ResponseAsStruct ResponseAsStruct(
::zx::unowned_channel _client_end) {
return ResultOf::ResponseAsStruct(_client_end->get());
}
// Caller provides the backing storage for FIDL message via request and
// response buffers.
static UnownedResultOf::ResponseAsStruct ResponseAsStruct(
::zx::unowned_channel _client_end
,
::fidl::BufferSpan _response_buffer) {
return UnownedResultOf::ResponseAsStruct(
_client_end->get(), _response_buffer.data, _response_buffer.capacity);
}
// Allocates 64 bytes of message buffer on the stack. No heap allocation
// necessary.
static ResultOf::ErrorAsPrimitive ErrorAsPrimitive(
::zx::unowned_channel _client_end) {
return ResultOf::ErrorAsPrimitive(_client_end->get());
}
// Caller provides the backing storage for FIDL message via request and
// response buffers.
static UnownedResultOf::ErrorAsPrimitive ErrorAsPrimitive(
::zx::unowned_channel _client_end
,
::fidl::BufferSpan _response_buffer) {
return UnownedResultOf::ErrorAsPrimitive(
_client_end->get(), _response_buffer.data, _response_buffer.capacity);
}
// Allocates 64 bytes of message buffer on the stack. No heap allocation
// necessary.
static ResultOf::ErrorAsEnum ErrorAsEnum(
::zx::unowned_channel _client_end) {
return ResultOf::ErrorAsEnum(_client_end->get());
}
// Caller provides the backing storage for FIDL message via request and
// response buffers.
static UnownedResultOf::ErrorAsEnum ErrorAsEnum(
::zx::unowned_channel _client_end
,
::fidl::BufferSpan _response_buffer) {
return UnownedResultOf::ErrorAsEnum(
_client_end->get(), _response_buffer.data, _response_buffer.capacity);
}
};
class SyncClient final {
public:
SyncClient() = default;
explicit SyncClient(::zx::channel channel) : channel_(std::move(channel)) {}
~SyncClient() = default;
SyncClient(SyncClient&&) = default;
SyncClient& operator=(SyncClient&&) = default;
const ::zx::channel& channel() const { return channel_; }
::zx::channel* mutable_channel() { return &channel_; }
// Allocates 80 bytes of message buffer on the stack. No heap allocation
// necessary.
ResultOf::ResponseAsStruct ResponseAsStruct() {
return ResultOf::ResponseAsStruct(this->channel().get());
}
// Caller provides the backing storage for FIDL message via request and
// response buffers.
UnownedResultOf::ResponseAsStruct ResponseAsStruct(
::fidl::BufferSpan _response_buffer) {
return UnownedResultOf::ResponseAsStruct(this->channel().get(),
_response_buffer.data,
_response_buffer.capacity);
}
// Allocates 64 bytes of message buffer on the stack. No heap allocation
// necessary.
ResultOf::ErrorAsPrimitive ErrorAsPrimitive() {
return ResultOf::ErrorAsPrimitive(this->channel().get());
}
// Caller provides the backing storage for FIDL message via request and
// response buffers.
UnownedResultOf::ErrorAsPrimitive ErrorAsPrimitive(
::fidl::BufferSpan _response_buffer) {
return UnownedResultOf::ErrorAsPrimitive(this->channel().get(),
_response_buffer.data,
_response_buffer.capacity);
}
// Allocates 64 bytes of message buffer on the stack. No heap allocation
// necessary.
ResultOf::ErrorAsEnum ErrorAsEnum() {
return ResultOf::ErrorAsEnum(this->channel().get());
}
// Caller provides the backing storage for FIDL message via request and
// response buffers.
UnownedResultOf::ErrorAsEnum ErrorAsEnum(
::fidl::BufferSpan _response_buffer) {
return UnownedResultOf::ErrorAsEnum(this->channel().get(),
_response_buffer.data,
_response_buffer.capacity);
}
private:
::zx::channel channel_;
};
struct AsyncEventHandlers;
class ResponseAsStructResponseContext;
class ErrorAsPrimitiveResponseContext;
class ErrorAsEnumResponseContext;
class ClientImpl;
// Pure-virtual interface to be implemented by a server.
class Interface : public ::fidl::internal::IncomingMessageDispatcher {
public:
Interface() = default;
virtual ~Interface() = default;
// The marker protocol type within which this |Interface| class is defined.
using _EnclosingProtocol = WithErrorSyntax;
class ResponseAsStructCompleterBase : public ::fidl::CompleterBase {
public:
// In the following methods, the return value indicates internal errors
// during the reply, such as encoding or writing to the transport. Note
// that any error will automatically lead to the destruction of the
// binding, after which the |on_unbound| callback will be triggered with a
// detailed reason.
//
// See //zircon/system/ulib/fidl/include/lib/fidl/llcpp/server.h.
//
// Because the reply status is identical to the unbinding status, it can
// be safely ignored.
::fidl::Result Reply(::llcpp::fidl::test::protocols::
WithErrorSyntax_ResponseAsStruct_Result result);
::fidl::Result ReplySuccess(int64_t a, int64_t b, int64_t c);
::fidl::Result ReplyError(uint32_t error);
::fidl::Result Reply(::fidl::BufferSpan _buffer,
::llcpp::fidl::test::protocols::
WithErrorSyntax_ResponseAsStruct_Result result);
::fidl::Result ReplySuccess(::fidl::BufferSpan _buffer, int64_t a,
int64_t b, int64_t c);
protected:
using ::fidl::CompleterBase::CompleterBase;
};
using ResponseAsStructCompleter =
::fidl::Completer<ResponseAsStructCompleterBase>;
virtual void ResponseAsStruct(
ResponseAsStructCompleter::Sync& _completer) = 0;
class ErrorAsPrimitiveCompleterBase : public ::fidl::CompleterBase {
public:
// In the following methods, the return value indicates internal errors
// during the reply, such as encoding or writing to the transport. Note
// that any error will automatically lead to the destruction of the
// binding, after which the |on_unbound| callback will be triggered with a
// detailed reason.
//
// See //zircon/system/ulib/fidl/include/lib/fidl/llcpp/server.h.
//
// Because the reply status is identical to the unbinding status, it can
// be safely ignored.
::fidl::Result Reply(::llcpp::fidl::test::protocols::
WithErrorSyntax_ErrorAsPrimitive_Result result);
::fidl::Result ReplySuccess();
::fidl::Result ReplyError(uint32_t error);
::fidl::Result Reply(::fidl::BufferSpan _buffer,
::llcpp::fidl::test::protocols::
WithErrorSyntax_ErrorAsPrimitive_Result result);
::fidl::Result ReplySuccess(::fidl::BufferSpan _buffer);
protected:
using ::fidl::CompleterBase::CompleterBase;
};
using ErrorAsPrimitiveCompleter =
::fidl::Completer<ErrorAsPrimitiveCompleterBase>;
virtual void ErrorAsPrimitive(
ErrorAsPrimitiveCompleter::Sync& _completer) = 0;
class ErrorAsEnumCompleterBase : public ::fidl::CompleterBase {
public:
// In the following methods, the return value indicates internal errors
// during the reply, such as encoding or writing to the transport. Note
// that any error will automatically lead to the destruction of the
// binding, after which the |on_unbound| callback will be triggered with a
// detailed reason.
//
// See //zircon/system/ulib/fidl/include/lib/fidl/llcpp/server.h.
//
// Because the reply status is identical to the unbinding status, it can
// be safely ignored.
::fidl::Result Reply(
::llcpp::fidl::test::protocols::WithErrorSyntax_ErrorAsEnum_Result
result);
::fidl::Result ReplySuccess();
::fidl::Result ReplyError(ErrorEnun error);
::fidl::Result Reply(
::fidl::BufferSpan _buffer,
::llcpp::fidl::test::protocols::WithErrorSyntax_ErrorAsEnum_Result
result);
::fidl::Result ReplySuccess(::fidl::BufferSpan _buffer);
protected:
using ::fidl::CompleterBase::CompleterBase;
};
using ErrorAsEnumCompleter = ::fidl::Completer<ErrorAsEnumCompleterBase>;
virtual void ErrorAsEnum(ErrorAsEnumCompleter::Sync& _completer) = 0;
private:
::fidl::DispatchResult dispatch_message(fidl_incoming_msg_t* msg,
::fidl::Transaction* txn) final;
};
// Attempts to dispatch the incoming message to a handler function in the
// server implementation. If there is no matching handler, it returns false,
// leaving the message and transaction intact. In all other cases, it consumes
// the message and returns true. It is possible to chain multiple TryDispatch
// functions in this manner.
static ::fidl::DispatchResult TryDispatch(Interface* impl,
fidl_incoming_msg_t* msg,
::fidl::Transaction* txn);
// Dispatches the incoming message to one of the handlers functions in the
// protocol. If there is no matching handler, it closes all the handles in
// |msg| and closes the channel with a |ZX_ERR_NOT_SUPPORTED| epitaph, before
// returning false. The message should then be discarded.
static ::fidl::DispatchResult Dispatch(Interface* impl,
fidl_incoming_msg_t* msg,
::fidl::Transaction* txn);
// Same as |Dispatch|, but takes a |void*| instead of |Interface*|.
// Only used with |fidl::BindServer| to reduce template expansion.
// Do not call this method manually. Use |Dispatch| instead.
static ::fidl::DispatchResult TypeErasedDispatch(void* impl,
fidl_incoming_msg_t* msg,
::fidl::Transaction* txn) {
return Dispatch(static_cast<Interface*>(impl), msg, txn);
}
class EventSender;
class WeakEventSender;
};
} // namespace protocols
} // namespace test
} // namespace fidl
} // namespace llcpp
namespace fidl {
template <>
struct IsFidlType<::llcpp::fidl::test::protocols::obj_type>
: public std::true_type {};
template <>
struct IsFidlType<
::llcpp::fidl::test::protocols::WithErrorSyntax_ResponseAsStruct_Response>
: public std::true_type {};
template <>
struct IsStruct<
::llcpp::fidl::test::protocols::WithErrorSyntax_ResponseAsStruct_Response>
: public std::true_type {};
static_assert(
std::is_standard_layout_v<::llcpp::fidl::test::protocols::
WithErrorSyntax_ResponseAsStruct_Response>);
static_assert(offsetof(::llcpp::fidl::test::protocols::
WithErrorSyntax_ResponseAsStruct_Response,
a) == 0);
static_assert(offsetof(::llcpp::fidl::test::protocols::
WithErrorSyntax_ResponseAsStruct_Response,
b) == 8);
static_assert(offsetof(::llcpp::fidl::test::protocols::
WithErrorSyntax_ResponseAsStruct_Response,
c) == 16);
static_assert(sizeof(::llcpp::fidl::test::protocols::
WithErrorSyntax_ResponseAsStruct_Response) ==
::llcpp::fidl::test::protocols::
WithErrorSyntax_ResponseAsStruct_Response::PrimarySize);
template <>
struct IsFidlType<
::llcpp::fidl::test::protocols::WithErrorSyntax_ResponseAsStruct_Result>
: public std::true_type {};
template <>
struct IsUnion<
::llcpp::fidl::test::protocols::WithErrorSyntax_ResponseAsStruct_Result>
: public std::true_type {};
static_assert(
std::is_standard_layout_v<::llcpp::fidl::test::protocols::
WithErrorSyntax_ResponseAsStruct_Result>);
template <>
struct IsFidlType<
::llcpp::fidl::test::protocols::WithErrorSyntax_ErrorAsPrimitive_Response>
: public std::true_type {};
template <>
struct IsStruct<
::llcpp::fidl::test::protocols::WithErrorSyntax_ErrorAsPrimitive_Response>
: public std::true_type {};
static_assert(
std::is_standard_layout_v<::llcpp::fidl::test::protocols::
WithErrorSyntax_ErrorAsPrimitive_Response>);
static_assert(offsetof(::llcpp::fidl::test::protocols::
WithErrorSyntax_ErrorAsPrimitive_Response,
__reserved) == 0);
static_assert(sizeof(::llcpp::fidl::test::protocols::
WithErrorSyntax_ErrorAsPrimitive_Response) ==
::llcpp::fidl::test::protocols::
WithErrorSyntax_ErrorAsPrimitive_Response::PrimarySize);
template <>
struct IsFidlType<
::llcpp::fidl::test::protocols::WithErrorSyntax_ErrorAsPrimitive_Result>
: public std::true_type {};
template <>
struct IsUnion<
::llcpp::fidl::test::protocols::WithErrorSyntax_ErrorAsPrimitive_Result>
: public std::true_type {};
static_assert(
std::is_standard_layout_v<::llcpp::fidl::test::protocols::
WithErrorSyntax_ErrorAsPrimitive_Result>);
template <>
struct IsFidlType<
::llcpp::fidl::test::protocols::WithErrorSyntax_ErrorAsEnum_Response>
: public std::true_type {};
template <>
struct IsStruct<
::llcpp::fidl::test::protocols::WithErrorSyntax_ErrorAsEnum_Response>
: public std::true_type {};
static_assert(
std::is_standard_layout_v<
::llcpp::fidl::test::protocols::WithErrorSyntax_ErrorAsEnum_Response>);
static_assert(
offsetof(
::llcpp::fidl::test::protocols::WithErrorSyntax_ErrorAsEnum_Response,
__reserved) == 0);
static_assert(
sizeof(
::llcpp::fidl::test::protocols::WithErrorSyntax_ErrorAsEnum_Response) ==
::llcpp::fidl::test::protocols::WithErrorSyntax_ErrorAsEnum_Response::
PrimarySize);
template <>
struct IsFidlType<::llcpp::fidl::test::protocols::Transitional::RequestRequest>
: public std::true_type {};
template <>
struct IsFidlMessage<
::llcpp::fidl::test::protocols::Transitional::RequestRequest>
: public std::true_type {};
static_assert(
sizeof(::llcpp::fidl::test::protocols::Transitional::RequestRequest) ==
::llcpp::fidl::test::protocols::Transitional::RequestRequest::PrimarySize);
static_assert(
offsetof(::llcpp::fidl::test::protocols::Transitional::RequestRequest, x) ==
16);
template <>
struct IsFidlType<::llcpp::fidl::test::protocols::Transitional::RequestResponse>
: public std::true_type {};
template <>
struct IsFidlMessage<
::llcpp::fidl::test::protocols::Transitional::RequestResponse>
: public std::true_type {};
static_assert(
sizeof(::llcpp::fidl::test::protocols::Transitional::RequestResponse) ==
::llcpp::fidl::test::protocols::Transitional::RequestResponse::PrimarySize);
static_assert(
offsetof(::llcpp::fidl::test::protocols::Transitional::RequestResponse,
y) == 16);
template <>
struct IsFidlType<::llcpp::fidl::test::protocols::Transitional::OneWayRequest>
: public std::true_type {};
template <>
struct IsFidlMessage<
::llcpp::fidl::test::protocols::Transitional::OneWayRequest>
: public std::true_type {};
static_assert(
sizeof(::llcpp::fidl::test::protocols::Transitional::OneWayRequest) ==
::llcpp::fidl::test::protocols::Transitional::OneWayRequest::PrimarySize);
static_assert(
offsetof(::llcpp::fidl::test::protocols::Transitional::OneWayRequest, x) ==
16);
template <>
struct IsFidlType<::llcpp::fidl::test::protocols::Transitional::EventResponse>
: public std::true_type {};
template <>
struct IsFidlMessage<
::llcpp::fidl::test::protocols::Transitional::EventResponse>
: public std::true_type {};
static_assert(
sizeof(::llcpp::fidl::test::protocols::Transitional::EventResponse) ==
::llcpp::fidl::test::protocols::Transitional::EventResponse::PrimarySize);
static_assert(
offsetof(::llcpp::fidl::test::protocols::Transitional::EventResponse, x) ==
16);
template <>
struct IsFidlType<
::llcpp::fidl::test::protocols::ChannelProtocol::MethodARequest>
: public std::true_type {};
template <>
struct IsFidlMessage<
::llcpp::fidl::test::protocols::ChannelProtocol::MethodARequest>
: public std::true_type {};
static_assert(
sizeof(::llcpp::fidl::test::protocols::ChannelProtocol::MethodARequest) ==
::llcpp::fidl::test::protocols::ChannelProtocol::MethodARequest::
PrimarySize);
static_assert(
offsetof(::llcpp::fidl::test::protocols::ChannelProtocol::MethodARequest,
a) == 16);
static_assert(
offsetof(::llcpp::fidl::test::protocols::ChannelProtocol::MethodARequest,
b) == 24);
template <>
struct IsFidlType<
::llcpp::fidl::test::protocols::ChannelProtocol::EventAResponse>
: public std::true_type {};
template <>
struct IsFidlMessage<
::llcpp::fidl::test::protocols::ChannelProtocol::EventAResponse>
: public std::true_type {};
static_assert(
sizeof(::llcpp::fidl::test::protocols::ChannelProtocol::EventAResponse) ==
::llcpp::fidl::test::protocols::ChannelProtocol::EventAResponse::
PrimarySize);
static_assert(
offsetof(::llcpp::fidl::test::protocols::ChannelProtocol::EventAResponse,
a) == 16);
static_assert(
offsetof(::llcpp::fidl::test::protocols::ChannelProtocol::EventAResponse,
b) == 24);
template <>
struct IsFidlType<
::llcpp::fidl::test::protocols::ChannelProtocol::MethodBRequest>
: public std::true_type {};
template <>
struct IsFidlMessage<
::llcpp::fidl::test::protocols::ChannelProtocol::MethodBRequest>
: public std::true_type {};
static_assert(
sizeof(::llcpp::fidl::test::protocols::ChannelProtocol::MethodBRequest) ==
::llcpp::fidl::test::protocols::ChannelProtocol::MethodBRequest::
PrimarySize);
static_assert(
offsetof(::llcpp::fidl::test::protocols::ChannelProtocol::MethodBRequest,
a) == 16);
static_assert(
offsetof(::llcpp::fidl::test::protocols::ChannelProtocol::MethodBRequest,
b) == 24);
template <>
struct IsFidlType<
::llcpp::fidl::test::protocols::ChannelProtocol::MethodBResponse>
: public std::true_type {};
template <>
struct IsFidlMessage<
::llcpp::fidl::test::protocols::ChannelProtocol::MethodBResponse>
: public std::true_type {};
static_assert(
sizeof(::llcpp::fidl::test::protocols::ChannelProtocol::MethodBResponse) ==
::llcpp::fidl::test::protocols::ChannelProtocol::MethodBResponse::
PrimarySize);
static_assert(
offsetof(::llcpp::fidl::test::protocols::ChannelProtocol::MethodBResponse,
result) == 16);
template <>
struct IsFidlType<
::llcpp::fidl::test::protocols::ChannelProtocol::TakeHandleRequest>
: public std::true_type {};
template <>
struct IsFidlMessage<
::llcpp::fidl::test::protocols::ChannelProtocol::TakeHandleRequest>
: public std::true_type {};
static_assert(
sizeof(
::llcpp::fidl::test::protocols::ChannelProtocol::TakeHandleRequest) ==
::llcpp::fidl::test::protocols::ChannelProtocol::TakeHandleRequest::
PrimarySize);
static_assert(
offsetof(::llcpp::fidl::test::protocols::ChannelProtocol::TakeHandleRequest,
h) == 16);
template <>
struct IsFidlType<
::llcpp::fidl::test::protocols::ChannelProtocol::TakeHandleResponse>
: public std::true_type {};
template <>
struct IsFidlMessage<
::llcpp::fidl::test::protocols::ChannelProtocol::TakeHandleResponse>
: public std::true_type {};
static_assert(
sizeof(
::llcpp::fidl::test::protocols::ChannelProtocol::TakeHandleResponse) ==
::llcpp::fidl::test::protocols::ChannelProtocol::TakeHandleResponse::
PrimarySize);
template <>
struct IsFidlType<
::llcpp::fidl::test::protocols::ChannelProtocol::MutateSocketRequest>
: public std::true_type {};
template <>
struct IsFidlMessage<
::llcpp::fidl::test::protocols::ChannelProtocol::MutateSocketRequest>
: public std::true_type {};
static_assert(
sizeof(
::llcpp::fidl::test::protocols::ChannelProtocol::MutateSocketRequest) ==
::llcpp::fidl::test::protocols::ChannelProtocol::MutateSocketRequest::
PrimarySize);
static_assert(
offsetof(
::llcpp::fidl::test::protocols::ChannelProtocol::MutateSocketRequest,
a) == 16);
template <>
struct IsFidlType<
::llcpp::fidl::test::protocols::ChannelProtocol::MutateSocketResponse>
: public std::true_type {};
template <>
struct IsFidlMessage<
::llcpp::fidl::test::protocols::ChannelProtocol::MutateSocketResponse>
: public std::true_type {};
static_assert(sizeof(::llcpp::fidl::test::protocols::ChannelProtocol::
MutateSocketResponse) ==
::llcpp::fidl::test::protocols::ChannelProtocol::
MutateSocketResponse::PrimarySize);
static_assert(
offsetof(
::llcpp::fidl::test::protocols::ChannelProtocol::MutateSocketResponse,
b) == 16);
template <>
struct IsFidlType<::llcpp::fidl::test::protocols::
WithAndWithoutRequestResponse::NoRequestNoResponseRequest>
: public std::true_type {};
template <>
struct IsFidlMessage<
::llcpp::fidl::test::protocols::WithAndWithoutRequestResponse::
NoRequestNoResponseRequest> : public std::true_type {};
static_assert(
sizeof(::llcpp::fidl::test::protocols::WithAndWithoutRequestResponse::
NoRequestNoResponseRequest) ==
::llcpp::fidl::test::protocols::WithAndWithoutRequestResponse::
NoRequestNoResponseRequest::PrimarySize);
template <>
struct IsFidlType<
::llcpp::fidl::test::protocols::WithAndWithoutRequestResponse::
NoRequestEmptyResponseRequest> : public std::true_type {};
template <>
struct IsFidlMessage<
::llcpp::fidl::test::protocols::WithAndWithoutRequestResponse::
NoRequestEmptyResponseRequest> : public std::true_type {};
static_assert(
sizeof(::llcpp::fidl::test::protocols::WithAndWithoutRequestResponse::
NoRequestEmptyResponseRequest) ==
::llcpp::fidl::test::protocols::WithAndWithoutRequestResponse::
NoRequestEmptyResponseRequest::PrimarySize);
template <>
struct IsFidlType<
::llcpp::fidl::test::protocols::WithAndWithoutRequestResponse::
NoRequestEmptyResponseResponse> : public std::true_type {};
template <>
struct IsFidlMessage<
::llcpp::fidl::test::protocols::WithAndWithoutRequestResponse::
NoRequestEmptyResponseResponse> : public std::true_type {};
static_assert(
sizeof(::llcpp::fidl::test::protocols::WithAndWithoutRequestResponse::
NoRequestEmptyResponseResponse) ==
::llcpp::fidl::test::protocols::WithAndWithoutRequestResponse::
NoRequestEmptyResponseResponse::PrimarySize);
template <>
struct IsFidlType<
::llcpp::fidl::test::protocols::WithAndWithoutRequestResponse::
NoRequestWithResponseRequest> : public std::true_type {};
template <>
struct IsFidlMessage<
::llcpp::fidl::test::protocols::WithAndWithoutRequestResponse::
NoRequestWithResponseRequest> : public std::true_type {};
static_assert(
sizeof(::llcpp::fidl::test::protocols::WithAndWithoutRequestResponse::
NoRequestWithResponseRequest) ==
::llcpp::fidl::test::protocols::WithAndWithoutRequestResponse::
NoRequestWithResponseRequest::PrimarySize);
template <>
struct IsFidlType<
::llcpp::fidl::test::protocols::WithAndWithoutRequestResponse::
NoRequestWithResponseResponse> : public std::true_type {};
template <>
struct IsFidlMessage<
::llcpp::fidl::test::protocols::WithAndWithoutRequestResponse::
NoRequestWithResponseResponse> : public std::true_type {};
static_assert(
sizeof(::llcpp::fidl::test::protocols::WithAndWithoutRequestResponse::
NoRequestWithResponseResponse) ==
::llcpp::fidl::test::protocols::WithAndWithoutRequestResponse::
NoRequestWithResponseResponse::PrimarySize);
static_assert(
offsetof(::llcpp::fidl::test::protocols::WithAndWithoutRequestResponse::
NoRequestWithResponseResponse,
ret) == 16);
template <>
struct IsFidlType<
::llcpp::fidl::test::protocols::WithAndWithoutRequestResponse::
WithRequestNoResponseRequest> : public std::true_type {};
template <>
struct IsFidlMessage<
::llcpp::fidl::test::protocols::WithAndWithoutRequestResponse::
WithRequestNoResponseRequest> : public std::true_type {};
static_assert(
sizeof(::llcpp::fidl::test::protocols::WithAndWithoutRequestResponse::
WithRequestNoResponseRequest) ==
::llcpp::fidl::test::protocols::WithAndWithoutRequestResponse::
WithRequestNoResponseRequest::PrimarySize);
static_assert(
offsetof(::llcpp::fidl::test::protocols::WithAndWithoutRequestResponse::
WithRequestNoResponseRequest,
arg) == 16);
template <>
struct IsFidlType<
::llcpp::fidl::test::protocols::WithAndWithoutRequestResponse::
WithRequestEmptyResponseRequest> : public std::true_type {};
template <>
struct IsFidlMessage<
::llcpp::fidl::test::protocols::WithAndWithoutRequestResponse::
WithRequestEmptyResponseRequest> : public std::true_type {};
static_assert(
sizeof(::llcpp::fidl::test::protocols::WithAndWithoutRequestResponse::
WithRequestEmptyResponseRequest) ==
::llcpp::fidl::test::protocols::WithAndWithoutRequestResponse::
WithRequestEmptyResponseRequest::PrimarySize);
static_assert(
offsetof(::llcpp::fidl::test::protocols::WithAndWithoutRequestResponse::
WithRequestEmptyResponseRequest,
arg) == 16);
template <>
struct IsFidlType<
::llcpp::fidl::test::protocols::WithAndWithoutRequestResponse::
WithRequestEmptyResponseResponse> : public std::true_type {};
template <>
struct IsFidlMessage<
::llcpp::fidl::test::protocols::WithAndWithoutRequestResponse::
WithRequestEmptyResponseResponse> : public std::true_type {};
static_assert(
sizeof(::llcpp::fidl::test::protocols::WithAndWithoutRequestResponse::
WithRequestEmptyResponseResponse) ==
::llcpp::fidl::test::protocols::WithAndWithoutRequestResponse::
WithRequestEmptyResponseResponse::PrimarySize);
template <>
struct IsFidlType<
::llcpp::fidl::test::protocols::WithAndWithoutRequestResponse::
WithRequestWithResponseRequest> : public std::true_type {};
template <>
struct IsFidlMessage<
::llcpp::fidl::test::protocols::WithAndWithoutRequestResponse::
WithRequestWithResponseRequest> : public std::true_type {};
static_assert(
sizeof(::llcpp::fidl::test::protocols::WithAndWithoutRequestResponse::
WithRequestWithResponseRequest) ==
::llcpp::fidl::test::protocols::WithAndWithoutRequestResponse::
WithRequestWithResponseRequest::PrimarySize);
static_assert(
offsetof(::llcpp::fidl::test::protocols::WithAndWithoutRequestResponse::
WithRequestWithResponseRequest,
arg) == 16);
template <>
struct IsFidlType<
::llcpp::fidl::test::protocols::WithAndWithoutRequestResponse::
WithRequestWithResponseResponse> : public std::true_type {};
template <>
struct IsFidlMessage<
::llcpp::fidl::test::protocols::WithAndWithoutRequestResponse::
WithRequestWithResponseResponse> : public std::true_type {};
static_assert(
sizeof(::llcpp::fidl::test::protocols::WithAndWithoutRequestResponse::
WithRequestWithResponseResponse) ==
::llcpp::fidl::test::protocols::WithAndWithoutRequestResponse::
WithRequestWithResponseResponse::PrimarySize);
static_assert(
offsetof(::llcpp::fidl::test::protocols::WithAndWithoutRequestResponse::
WithRequestWithResponseResponse,
ret) == 16);
template <>
struct IsFidlType<::llcpp::fidl::test::protocols::
WithAndWithoutRequestResponse::OnEmptyResponseResponse>
: public std::true_type {};
template <>
struct IsFidlMessage<::llcpp::fidl::test::protocols::
WithAndWithoutRequestResponse::OnEmptyResponseResponse>
: public std::true_type {};
static_assert(
sizeof(::llcpp::fidl::test::protocols::WithAndWithoutRequestResponse::
OnEmptyResponseResponse) ==
::llcpp::fidl::test::protocols::WithAndWithoutRequestResponse::
OnEmptyResponseResponse::PrimarySize);
template <>
struct IsFidlType<::llcpp::fidl::test::protocols::
WithAndWithoutRequestResponse::OnWithResponseResponse>
: public std::true_type {};
template <>
struct IsFidlMessage<::llcpp::fidl::test::protocols::
WithAndWithoutRequestResponse::OnWithResponseResponse>
: public std::true_type {};
static_assert(
sizeof(::llcpp::fidl::test::protocols::WithAndWithoutRequestResponse::
OnWithResponseResponse) ==
::llcpp::fidl::test::protocols::WithAndWithoutRequestResponse::
OnWithResponseResponse::PrimarySize);
static_assert(
offsetof(::llcpp::fidl::test::protocols::WithAndWithoutRequestResponse::
OnWithResponseResponse,
ret) == 16);
template <>
struct IsFidlType<::llcpp::fidl::test::protocols::ErrorEnun>
: public std::true_type {};
template <>
struct IsFidlType<
::llcpp::fidl::test::protocols::WithErrorSyntax_ErrorAsEnum_Result>
: public std::true_type {};
template <>
struct IsUnion<
::llcpp::fidl::test::protocols::WithErrorSyntax_ErrorAsEnum_Result>
: public std::true_type {};
static_assert(
std::is_standard_layout_v<
::llcpp::fidl::test::protocols::WithErrorSyntax_ErrorAsEnum_Result>);
template <>
struct IsFidlType<
::llcpp::fidl::test::protocols::WithErrorSyntax::ResponseAsStructRequest>
: public std::true_type {};
template <>
struct IsFidlMessage<
::llcpp::fidl::test::protocols::WithErrorSyntax::ResponseAsStructRequest>
: public std::true_type {};
static_assert(sizeof(::llcpp::fidl::test::protocols::WithErrorSyntax::
ResponseAsStructRequest) ==
::llcpp::fidl::test::protocols::WithErrorSyntax::
ResponseAsStructRequest::PrimarySize);
template <>
struct IsFidlType<
::llcpp::fidl::test::protocols::WithErrorSyntax::ResponseAsStructResponse>
: public std::true_type {};
template <>
struct IsFidlMessage<
::llcpp::fidl::test::protocols::WithErrorSyntax::ResponseAsStructResponse>
: public std::true_type {};
static_assert(sizeof(::llcpp::fidl::test::protocols::WithErrorSyntax::
ResponseAsStructResponse) ==
::llcpp::fidl::test::protocols::WithErrorSyntax::
ResponseAsStructResponse::PrimarySize);
static_assert(offsetof(::llcpp::fidl::test::protocols::WithErrorSyntax::
ResponseAsStructResponse,
result) == 16);
template <>
struct IsFidlType<
::llcpp::fidl::test::protocols::WithErrorSyntax::ErrorAsPrimitiveRequest>
: public std::true_type {};
template <>
struct IsFidlMessage<
::llcpp::fidl::test::protocols::WithErrorSyntax::ErrorAsPrimitiveRequest>
: public std::true_type {};
static_assert(sizeof(::llcpp::fidl::test::protocols::WithErrorSyntax::
ErrorAsPrimitiveRequest) ==
::llcpp::fidl::test::protocols::WithErrorSyntax::
ErrorAsPrimitiveRequest::PrimarySize);
template <>
struct IsFidlType<
::llcpp::fidl::test::protocols::WithErrorSyntax::ErrorAsPrimitiveResponse>
: public std::true_type {};
template <>
struct IsFidlMessage<
::llcpp::fidl::test::protocols::WithErrorSyntax::ErrorAsPrimitiveResponse>
: public std::true_type {};
static_assert(sizeof(::llcpp::fidl::test::protocols::WithErrorSyntax::
ErrorAsPrimitiveResponse) ==
::llcpp::fidl::test::protocols::WithErrorSyntax::
ErrorAsPrimitiveResponse::PrimarySize);
static_assert(offsetof(::llcpp::fidl::test::protocols::WithErrorSyntax::
ErrorAsPrimitiveResponse,
result) == 16);
template <>
struct IsFidlType<
::llcpp::fidl::test::protocols::WithErrorSyntax::ErrorAsEnumRequest>
: public std::true_type {};
template <>
struct IsFidlMessage<
::llcpp::fidl::test::protocols::WithErrorSyntax::ErrorAsEnumRequest>
: public std::true_type {};
static_assert(
sizeof(
::llcpp::fidl::test::protocols::WithErrorSyntax::ErrorAsEnumRequest) ==
::llcpp::fidl::test::protocols::WithErrorSyntax::ErrorAsEnumRequest::
PrimarySize);
template <>
struct IsFidlType<
::llcpp::fidl::test::protocols::WithErrorSyntax::ErrorAsEnumResponse>
: public std::true_type {};
template <>
struct IsFidlMessage<
::llcpp::fidl::test::protocols::WithErrorSyntax::ErrorAsEnumResponse>
: public std::true_type {};
static_assert(
sizeof(
::llcpp::fidl::test::protocols::WithErrorSyntax::ErrorAsEnumResponse) ==
::llcpp::fidl::test::protocols::WithErrorSyntax::ErrorAsEnumResponse::
PrimarySize);
static_assert(
offsetof(
::llcpp::fidl::test::protocols::WithErrorSyntax::ErrorAsEnumResponse,
result) == 16);
} // namespace fidl
namespace llcpp {
namespace fidl {
namespace test {
namespace protocols {
struct Transitional::AsyncEventHandlers {
::fit::function<void(EventResponse* msg)> event;
};
class Transitional::RequestResponseContext
: public ::fidl::internal::ResponseContext {
public:
RequestResponseContext();
virtual void OnReply(Transitional::RequestResponse* message) = 0;
private:
void OnReply(uint8_t* reply) override;
};
class Transitional::ClientImpl final : private ::fidl::internal::ClientBase {
public:
// Asynchronous variant of |Transitional.Request()|. Allocates 24 bytes of
// request buffer on the stack. The callback is stored on the heap.
::fidl::Result Request(int64_t x,
::fit::callback<void(RequestResponse* response)> _cb);
// Asynchronous variant of |Transitional.Request()|. Caller provides the
// backing storage for FIDL message via request buffer. Ownership of _context
// is given unsafely to the binding until OnError() or OnReply() are called on
// it.
::fidl::Result Request(::fidl::BufferSpan _request_buffer, int64_t x,
RequestResponseContext* _context);
// Synchronous variant of |Transitional.Request()|. Allocates 48 bytes of
// message buffer on the stack. No heap allocation necessary.
ResultOf::Request Request_Sync(int64_t x);
// Synchronous variant of |Transitional.Request()|. Caller provides the
// backing storage for FIDL message via request and response buffers.
UnownedResultOf::Request Request_Sync(::fidl::BufferSpan _request_buffer,
int64_t x,
::fidl::BufferSpan _response_buffer);
// Allocates 24 bytes of message buffer on the stack. No heap allocation
// necessary.
::fidl::Result OneWay(int64_t x);
// Caller provides the backing storage for FIDL message via request and
// response buffers.
::fidl::Result OneWay(::fidl::BufferSpan _request_buffer, int64_t x);
private:
friend class ::fidl::Client<Transitional>;
explicit ClientImpl(AsyncEventHandlers handlers)
: handlers_(std::move(handlers)) {}
std::optional<::fidl::UnbindInfo> DispatchEvent(
fidl_incoming_msg_t* msg) override;
AsyncEventHandlers handlers_;
};
// |EventSender| owns a server endpoint of a channel speaking
// the Transitional protocol, and can send events in that protocol.
class Transitional::EventSender {
public:
// Constructs an event sender with an invalid channel.
EventSender() = default;
// TODO(fxbug.dev/65212): EventSender should take a ::fidl::ServerEnd.
explicit EventSender(::zx::channel server_end)
: server_end_(std::move(server_end)) {}
// The underlying server channel endpoint, which may be replaced at run-time.
const ::zx::channel& channel() const { return server_end_; }
::zx::channel& channel() { return server_end_; }
// Whether the underlying channel is valid.
bool is_valid() const { return server_end_.is_valid(); }
zx_status_t Event(int64_t x) const {
return SendEventEvent(::zx::unowned_channel(server_end_), std::move(x));
}
zx_status_t Event(::fidl::BufferSpan _buffer, int64_t x) const {
return SendEventEvent(::zx::unowned_channel(server_end_),
std::move(_buffer), std::move(x));
}
private:
::zx::channel server_end_;
};
class Transitional::WeakEventSender {
public:
zx_status_t Event(int64_t x) const {
if (auto _binding = binding_.lock()) {
return _binding->event_sender().Event(std::move(x));
}
return ZX_ERR_CANCELED;
}
zx_status_t Event(::fidl::BufferSpan _buffer, int64_t x) const {
if (auto _binding = binding_.lock()) {
return _binding->event_sender().Event(std::move(_buffer), std::move(x));
}
return ZX_ERR_CANCELED;
}
private:
friend class ::fidl::ServerBindingRef<Transitional>;
explicit WeakEventSender(
std::weak_ptr<::fidl::internal::AsyncServerBinding<Transitional>> binding)
: binding_(std::move(binding)) {}
std::weak_ptr<::fidl::internal::AsyncServerBinding<Transitional>> binding_;
};
struct ChannelProtocol::AsyncEventHandlers {
::fit::function<void(EventAResponse* msg)> event_a;
};
class ChannelProtocol::MethodBResponseContext
: public ::fidl::internal::ResponseContext {
public:
MethodBResponseContext();
virtual void OnReply(ChannelProtocol::MethodBResponse* message) = 0;
private:
void OnReply(uint8_t* reply) override;
};
class ChannelProtocol::TakeHandleResponseContext
: public ::fidl::internal::ResponseContext {
public:
TakeHandleResponseContext();
virtual void OnReply(ChannelProtocol::TakeHandleResponse* message) = 0;
private:
void OnReply(uint8_t* reply) override;
};
class ChannelProtocol::MutateSocketResponseContext
: public ::fidl::internal::ResponseContext {
public:
MutateSocketResponseContext();
virtual void OnReply(ChannelProtocol::MutateSocketResponse* message) = 0;
private:
void OnReply(uint8_t* reply) override;
};
class ChannelProtocol::ClientImpl final : private ::fidl::internal::ClientBase {
public:
// Allocates 32 bytes of message buffer on the stack. No heap allocation
// necessary.
::fidl::Result MethodA(int64_t a, int64_t b);
// Caller provides the backing storage for FIDL message via request and
// response buffers.
::fidl::Result MethodA(::fidl::BufferSpan _request_buffer, int64_t a,
int64_t b);
// Asynchronous variant of |ChannelProtocol.MethodB()|. Allocates 32 bytes of
// request buffer on the stack. The callback is stored on the heap.
::fidl::Result MethodB(int64_t a, int64_t b,
::fit::callback<void(MethodBResponse* response)> _cb);
// Asynchronous variant of |ChannelProtocol.MethodB()|. Caller provides the
// backing storage for FIDL message via request buffer. Ownership of _context
// is given unsafely to the binding until OnError() or OnReply() are called on
// it.
::fidl::Result MethodB(::fidl::BufferSpan _request_buffer, int64_t a,
int64_t b, MethodBResponseContext* _context);
// Synchronous variant of |ChannelProtocol.MethodB()|. Allocates 56 bytes of
// message buffer on the stack. No heap allocation necessary.
ResultOf::MethodB MethodB_Sync(int64_t a, int64_t b);
// Synchronous variant of |ChannelProtocol.MethodB()|. Caller provides the
// backing storage for FIDL message via request and response buffers.
UnownedResultOf::MethodB MethodB_Sync(::fidl::BufferSpan _request_buffer,
int64_t a, int64_t b,
::fidl::BufferSpan _response_buffer);
// Asynchronous variant of |ChannelProtocol.TakeHandle()|. Allocates 24 bytes
// of request buffer on the stack. The callback is stored on the heap.
::fidl::Result TakeHandle(
::zx::handle h, ::fit::callback<void(TakeHandleResponse* response)> _cb);
// Asynchronous variant of |ChannelProtocol.TakeHandle()|. Caller provides the
// backing storage for FIDL message via request buffer. Ownership of _context
// is given unsafely to the binding until OnError() or OnReply() are called on
// it.
::fidl::Result TakeHandle(::fidl::BufferSpan _request_buffer, ::zx::handle h,
TakeHandleResponseContext* _context);
// Synchronous variant of |ChannelProtocol.TakeHandle()|. Allocates 40 bytes
// of message buffer on the stack. No heap allocation necessary.
ResultOf::TakeHandle TakeHandle_Sync(::zx::handle h);
// Synchronous variant of |ChannelProtocol.TakeHandle()|. Caller provides the
// backing storage for FIDL message via request and response buffers.
UnownedResultOf::TakeHandle TakeHandle_Sync(
::fidl::BufferSpan _request_buffer, ::zx::handle h,
::fidl::BufferSpan _response_buffer);
// Asynchronous variant of |ChannelProtocol.MutateSocket()|. Allocates 24
// bytes of request buffer on the stack. The callback is stored on the heap.
::fidl::Result MutateSocket(
::zx::socket a,
::fit::callback<void(MutateSocketResponse* response)> _cb);
// Asynchronous variant of |ChannelProtocol.MutateSocket()|. Caller provides
// the backing storage for FIDL message via request buffer. Ownership of
// _context is given unsafely to the binding until OnError() or OnReply() are
// called on it.
::fidl::Result MutateSocket(::fidl::BufferSpan _request_buffer,
::zx::socket a,
MutateSocketResponseContext* _context);
// Synchronous variant of |ChannelProtocol.MutateSocket()|. Allocates 48 bytes
// of message buffer on the stack. No heap allocation necessary.
ResultOf::MutateSocket MutateSocket_Sync(::zx::socket a);
// Synchronous variant of |ChannelProtocol.MutateSocket()|. Caller provides
// the backing storage for FIDL message via request and response buffers.
UnownedResultOf::MutateSocket MutateSocket_Sync(
::fidl::BufferSpan _request_buffer, ::zx::socket a,
::fidl::BufferSpan _response_buffer);
private:
friend class ::fidl::Client<ChannelProtocol>;
explicit ClientImpl(AsyncEventHandlers handlers)
: handlers_(std::move(handlers)) {}
std::optional<::fidl::UnbindInfo> DispatchEvent(
fidl_incoming_msg_t* msg) override;
AsyncEventHandlers handlers_;
};
// |EventSender| owns a server endpoint of a channel speaking
// the ChannelProtocol protocol, and can send events in that protocol.
class ChannelProtocol::EventSender {
public:
// Constructs an event sender with an invalid channel.
EventSender() = default;
// TODO(fxbug.dev/65212): EventSender should take a ::fidl::ServerEnd.
explicit EventSender(::zx::channel server_end)
: server_end_(std::move(server_end)) {}
// The underlying server channel endpoint, which may be replaced at run-time.
const ::zx::channel& channel() const { return server_end_; }
::zx::channel& channel() { return server_end_; }
// Whether the underlying channel is valid.
bool is_valid() const { return server_end_.is_valid(); }
zx_status_t EventA(int64_t a, int64_t b) const {
return SendEventAEvent(::zx::unowned_channel(server_end_), std::move(a),
std::move(b));
}
zx_status_t EventA(::fidl::BufferSpan _buffer, int64_t a, int64_t b) const {
return SendEventAEvent(::zx::unowned_channel(server_end_),
std::move(_buffer), std::move(a), std::move(b));
}
private:
::zx::channel server_end_;
};
class ChannelProtocol::WeakEventSender {
public:
zx_status_t EventA(int64_t a, int64_t b) const {
if (auto _binding = binding_.lock()) {
return _binding->event_sender().EventA(std::move(a), std::move(b));
}
return ZX_ERR_CANCELED;
}
zx_status_t EventA(::fidl::BufferSpan _buffer, int64_t a, int64_t b) const {
if (auto _binding = binding_.lock()) {
return _binding->event_sender().EventA(std::move(_buffer), std::move(a),
std::move(b));
}
return ZX_ERR_CANCELED;
}
private:
friend class ::fidl::ServerBindingRef<ChannelProtocol>;
explicit WeakEventSender(
std::weak_ptr<::fidl::internal::AsyncServerBinding<ChannelProtocol>>
binding)
: binding_(std::move(binding)) {}
std::weak_ptr<::fidl::internal::AsyncServerBinding<ChannelProtocol>> binding_;
};
struct WithAndWithoutRequestResponse::AsyncEventHandlers {
::fit::function<void()> on_empty_response;
::fit::function<void(OnWithResponseResponse* msg)> on_with_response;
};
class WithAndWithoutRequestResponse::NoRequestEmptyResponseResponseContext
: public ::fidl::internal::ResponseContext {
public:
NoRequestEmptyResponseResponseContext();
virtual void OnReply(
WithAndWithoutRequestResponse::NoRequestEmptyResponseResponse*
message) = 0;
private:
void OnReply(uint8_t* reply) override;
};
class WithAndWithoutRequestResponse::NoRequestWithResponseResponseContext
: public ::fidl::internal::ResponseContext {
public:
NoRequestWithResponseResponseContext();
virtual void OnReply(
WithAndWithoutRequestResponse::NoRequestWithResponseResponse*
message) = 0;
private:
void OnReply(uint8_t* reply) override;
};
class WithAndWithoutRequestResponse::WithRequestEmptyResponseResponseContext
: public ::fidl::internal::ResponseContext {
public:
WithRequestEmptyResponseResponseContext();
virtual void OnReply(
WithAndWithoutRequestResponse::WithRequestEmptyResponseResponse*
message) = 0;
private:
void OnReply(uint8_t* reply) override;
};
class WithAndWithoutRequestResponse::WithRequestWithResponseResponseContext
: public ::fidl::internal::ResponseContext {
public:
WithRequestWithResponseResponseContext();
virtual void OnReply(
WithAndWithoutRequestResponse::WithRequestWithResponseResponse*
message) = 0;
private:
void OnReply(uint8_t* reply) override;
};
class WithAndWithoutRequestResponse::ClientImpl final
: private ::fidl::internal::ClientBase {
public:
// Allocates 16 bytes of message buffer on the stack. No heap allocation
// necessary.
::fidl::Result NoRequestNoResponse();
// Asynchronous variant of
// |WithAndWithoutRequestResponse.NoRequestEmptyResponse()|. Allocates 16
// bytes of request buffer on the stack. The callback is stored on the heap.
::fidl::Result NoRequestEmptyResponse(
::fit::callback<void(NoRequestEmptyResponseResponse* response)> _cb);
// Asynchronous variant of
// |WithAndWithoutRequestResponse.NoRequestEmptyResponse()|. Caller provides
// the backing storage for FIDL message via request buffer. Ownership of
// _context is given unsafely to the binding until OnError() or OnReply() are
// called on it.
::fidl::Result NoRequestEmptyResponse(
NoRequestEmptyResponseResponseContext* _context);
// Synchronous variant of
// |WithAndWithoutRequestResponse.NoRequestEmptyResponse()|. Allocates 32
// bytes of message buffer on the stack. No heap allocation necessary.
ResultOf::NoRequestEmptyResponse NoRequestEmptyResponse_Sync();
// Asynchronous variant of
// |WithAndWithoutRequestResponse.NoRequestWithResponse()|. Allocates 16 bytes
// of request buffer on the stack. The callback is stored on the heap.
::fidl::Result NoRequestWithResponse(
::fit::callback<void(NoRequestWithResponseResponse* response)> _cb);
// Asynchronous variant of
// |WithAndWithoutRequestResponse.NoRequestWithResponse()|. Caller provides
// the backing storage for FIDL message via request buffer. Ownership of
// _context is given unsafely to the binding until OnError() or OnReply() are
// called on it.
::fidl::Result NoRequestWithResponse(
NoRequestWithResponseResponseContext* _context);
// Synchronous variant of
// |WithAndWithoutRequestResponse.NoRequestWithResponse()|. Allocates 16 bytes
// of request buffer on the stack. Response is heap-allocated.
ResultOf::NoRequestWithResponse NoRequestWithResponse_Sync();
// Synchronous variant of
// |WithAndWithoutRequestResponse.NoRequestWithResponse()|. Caller provides
// the backing storage for FIDL message via request and response buffers.
UnownedResultOf::NoRequestWithResponse NoRequestWithResponse_Sync(
::fidl::BufferSpan _response_buffer);
// Request is heap-allocated.
::fidl::Result WithRequestNoResponse(::fidl::StringView arg);
// Caller provides the backing storage for FIDL message via request and
// response buffers.
::fidl::Result WithRequestNoResponse(::fidl::BufferSpan _request_buffer,
::fidl::StringView arg);
// Asynchronous variant of
// |WithAndWithoutRequestResponse.WithRequestEmptyResponse()|. The request and
// callback are allocated on the heap.
::fidl::Result WithRequestEmptyResponse(
::fidl::StringView arg,
::fit::callback<void(WithRequestEmptyResponseResponse* response)> _cb);
// Asynchronous variant of
// |WithAndWithoutRequestResponse.WithRequestEmptyResponse()|. Caller provides
// the backing storage for FIDL message via request buffer. Ownership of
// _context is given unsafely to the binding until OnError() or OnReply() are
// called on it.
::fidl::Result WithRequestEmptyResponse(
::fidl::BufferSpan _request_buffer, ::fidl::StringView arg,
WithRequestEmptyResponseResponseContext* _context);
// Synchronous variant of
// |WithAndWithoutRequestResponse.WithRequestEmptyResponse()|. Allocates 16
// bytes of response buffer on the stack. Request is heap-allocated.
ResultOf::WithRequestEmptyResponse WithRequestEmptyResponse_Sync(
::fidl::StringView arg);
// Synchronous variant of
// |WithAndWithoutRequestResponse.WithRequestEmptyResponse()|. Caller provides
// the backing storage for FIDL message via request and response buffers.
UnownedResultOf::WithRequestEmptyResponse WithRequestEmptyResponse_Sync(
::fidl::BufferSpan _request_buffer, ::fidl::StringView arg,
::fidl::BufferSpan _response_buffer);
// Asynchronous variant of
// |WithAndWithoutRequestResponse.WithRequestWithResponse()|. The request and
// callback are allocated on the heap.
::fidl::Result WithRequestWithResponse(
::fidl::StringView arg,
::fit::callback<void(WithRequestWithResponseResponse* response)> _cb);
// Asynchronous variant of
// |WithAndWithoutRequestResponse.WithRequestWithResponse()|. Caller provides
// the backing storage for FIDL message via request buffer. Ownership of
// _context is given unsafely to the binding until OnError() or OnReply() are
// called on it.
::fidl::Result WithRequestWithResponse(
::fidl::BufferSpan _request_buffer, ::fidl::StringView arg,
WithRequestWithResponseResponseContext* _context);
// Synchronous variant of
// |WithAndWithoutRequestResponse.WithRequestWithResponse()|. Request is
// heap-allocated. Response is heap-allocated.
ResultOf::WithRequestWithResponse WithRequestWithResponse_Sync(
::fidl::StringView arg);
// Synchronous variant of
// |WithAndWithoutRequestResponse.WithRequestWithResponse()|. Caller provides
// the backing storage for FIDL message via request and response buffers.
UnownedResultOf::WithRequestWithResponse WithRequestWithResponse_Sync(
::fidl::BufferSpan _request_buffer, ::fidl::StringView arg,
::fidl::BufferSpan _response_buffer);
private:
friend class ::fidl::Client<WithAndWithoutRequestResponse>;
explicit ClientImpl(AsyncEventHandlers handlers)
: handlers_(std::move(handlers)) {}
std::optional<::fidl::UnbindInfo> DispatchEvent(
fidl_incoming_msg_t* msg) override;
AsyncEventHandlers handlers_;
};
// |EventSender| owns a server endpoint of a channel speaking
// the WithAndWithoutRequestResponse protocol, and can send events in that
// protocol.
class WithAndWithoutRequestResponse::EventSender {
public:
// Constructs an event sender with an invalid channel.
EventSender() = default;
// TODO(fxbug.dev/65212): EventSender should take a ::fidl::ServerEnd.
explicit EventSender(::zx::channel server_end)
: server_end_(std::move(server_end)) {}
// The underlying server channel endpoint, which may be replaced at run-time.
const ::zx::channel& channel() const { return server_end_; }
::zx::channel& channel() { return server_end_; }
// Whether the underlying channel is valid.
bool is_valid() const { return server_end_.is_valid(); }
zx_status_t OnEmptyResponse() const {
return SendOnEmptyResponseEvent(::zx::unowned_channel(server_end_));
}
zx_status_t OnWithResponse(::fidl::StringView ret) const {
return SendOnWithResponseEvent(::zx::unowned_channel(server_end_),
std::move(ret));
}
zx_status_t OnWithResponse(::fidl::BufferSpan _buffer,
::fidl::StringView ret) const {
return SendOnWithResponseEvent(::zx::unowned_channel(server_end_),
std::move(_buffer), std::move(ret));
}
private:
::zx::channel server_end_;
};
class WithAndWithoutRequestResponse::WeakEventSender {
public:
zx_status_t OnEmptyResponse() const {
if (auto _binding = binding_.lock()) {
return _binding->event_sender().OnEmptyResponse();
}
return ZX_ERR_CANCELED;
}
zx_status_t OnWithResponse(::fidl::StringView ret) const {
if (auto _binding = binding_.lock()) {
return _binding->event_sender().OnWithResponse(std::move(ret));
}
return ZX_ERR_CANCELED;
}
zx_status_t OnWithResponse(::fidl::BufferSpan _buffer,
::fidl::StringView ret) const {
if (auto _binding = binding_.lock()) {
return _binding->event_sender().OnWithResponse(std::move(_buffer),
std::move(ret));
}
return ZX_ERR_CANCELED;
}
private:
friend class ::fidl::ServerBindingRef<WithAndWithoutRequestResponse>;
explicit WeakEventSender(
std::weak_ptr<
::fidl::internal::AsyncServerBinding<WithAndWithoutRequestResponse>>
binding)
: binding_(std::move(binding)) {}
std::weak_ptr<
::fidl::internal::AsyncServerBinding<WithAndWithoutRequestResponse>>
binding_;
};
struct WithErrorSyntax::AsyncEventHandlers {};
class WithErrorSyntax::ResponseAsStructResponseContext
: public ::fidl::internal::ResponseContext {
public:
ResponseAsStructResponseContext();
virtual void OnReply(WithErrorSyntax::ResponseAsStructResponse* message) = 0;
private:
void OnReply(uint8_t* reply) override;
};
class WithErrorSyntax::ErrorAsPrimitiveResponseContext
: public ::fidl::internal::ResponseContext {
public:
ErrorAsPrimitiveResponseContext();
virtual void OnReply(WithErrorSyntax::ErrorAsPrimitiveResponse* message) = 0;
private:
void OnReply(uint8_t* reply) override;
};
class WithErrorSyntax::ErrorAsEnumResponseContext
: public ::fidl::internal::ResponseContext {
public:
ErrorAsEnumResponseContext();
virtual void OnReply(WithErrorSyntax::ErrorAsEnumResponse* message) = 0;
private:
void OnReply(uint8_t* reply) override;
};
class WithErrorSyntax::ClientImpl final : private ::fidl::internal::ClientBase {
public:
// Asynchronous variant of |WithErrorSyntax.ResponseAsStruct()|. Allocates 16
// bytes of request buffer on the stack. The callback is stored on the heap.
::fidl::Result ResponseAsStruct(
::fit::callback<void(ResponseAsStructResponse* response)> _cb);
// Asynchronous variant of |WithErrorSyntax.ResponseAsStruct()|. Caller
// provides the backing storage for FIDL message via request buffer. Ownership
// of _context is given unsafely to the binding until OnError() or OnReply()
// are called on it.
::fidl::Result ResponseAsStruct(ResponseAsStructResponseContext* _context);
// Synchronous variant of |WithErrorSyntax.ResponseAsStruct()|. Allocates 80
// bytes of message buffer on the stack. No heap allocation necessary.
ResultOf::ResponseAsStruct ResponseAsStruct_Sync();
// Synchronous variant of |WithErrorSyntax.ResponseAsStruct()|. Caller
// provides the backing storage for FIDL message via request and response
// buffers.
UnownedResultOf::ResponseAsStruct ResponseAsStruct_Sync(
::fidl::BufferSpan _response_buffer);
// Asynchronous variant of |WithErrorSyntax.ErrorAsPrimitive()|. Allocates 16
// bytes of request buffer on the stack. The callback is stored on the heap.
::fidl::Result ErrorAsPrimitive(
::fit::callback<void(ErrorAsPrimitiveResponse* response)> _cb);
// Asynchronous variant of |WithErrorSyntax.ErrorAsPrimitive()|. Caller
// provides the backing storage for FIDL message via request buffer. Ownership
// of _context is given unsafely to the binding until OnError() or OnReply()
// are called on it.
::fidl::Result ErrorAsPrimitive(ErrorAsPrimitiveResponseContext* _context);
// Synchronous variant of |WithErrorSyntax.ErrorAsPrimitive()|. Allocates 64
// bytes of message buffer on the stack. No heap allocation necessary.
ResultOf::ErrorAsPrimitive ErrorAsPrimitive_Sync();
// Synchronous variant of |WithErrorSyntax.ErrorAsPrimitive()|. Caller
// provides the backing storage for FIDL message via request and response
// buffers.
UnownedResultOf::ErrorAsPrimitive ErrorAsPrimitive_Sync(
::fidl::BufferSpan _response_buffer);
// Asynchronous variant of |WithErrorSyntax.ErrorAsEnum()|. Allocates 16 bytes
// of request buffer on the stack. The callback is stored on the heap.
::fidl::Result ErrorAsEnum(
::fit::callback<void(ErrorAsEnumResponse* response)> _cb);
// Asynchronous variant of |WithErrorSyntax.ErrorAsEnum()|. Caller provides
// the backing storage for FIDL message via request buffer. Ownership of
// _context is given unsafely to the binding until OnError() or OnReply() are
// called on it.
::fidl::Result ErrorAsEnum(ErrorAsEnumResponseContext* _context);
// Synchronous variant of |WithErrorSyntax.ErrorAsEnum()|. Allocates 64 bytes
// of message buffer on the stack. No heap allocation necessary.
ResultOf::ErrorAsEnum ErrorAsEnum_Sync();
// Synchronous variant of |WithErrorSyntax.ErrorAsEnum()|. Caller provides the
// backing storage for FIDL message via request and response buffers.
UnownedResultOf::ErrorAsEnum ErrorAsEnum_Sync(
::fidl::BufferSpan _response_buffer);
private:
friend class ::fidl::Client<WithErrorSyntax>;
explicit ClientImpl(AsyncEventHandlers handlers)
: handlers_(std::move(handlers)) {}
std::optional<::fidl::UnbindInfo> DispatchEvent(
fidl_incoming_msg_t* msg) override;
AsyncEventHandlers handlers_;
};
// |EventSender| owns a server endpoint of a channel speaking
// the WithErrorSyntax protocol, and can send events in that protocol.
class WithErrorSyntax::EventSender {
public:
// Constructs an event sender with an invalid channel.
EventSender() = default;
// TODO(fxbug.dev/65212): EventSender should take a ::fidl::ServerEnd.
explicit EventSender(::zx::channel server_end)
: server_end_(std::move(server_end)) {}
// The underlying server channel endpoint, which may be replaced at run-time.
const ::zx::channel& channel() const { return server_end_; }
::zx::channel& channel() { return server_end_; }
// Whether the underlying channel is valid.
bool is_valid() const { return server_end_.is_valid(); }
private:
::zx::channel server_end_;
};
class WithErrorSyntax::WeakEventSender {
public:
private:
friend class ::fidl::ServerBindingRef<WithErrorSyntax>;
explicit WeakEventSender(
std::weak_ptr<::fidl::internal::AsyncServerBinding<WithErrorSyntax>>
binding)
: binding_(std::move(binding)) {}
std::weak_ptr<::fidl::internal::AsyncServerBinding<WithErrorSyntax>> binding_;
};
} // namespace protocols
} // namespace test
} // namespace fidl
} // namespace llcpp