blob: 2a8de283726bd5464b6304ea9793260f3a3bdbde [file] [log] [blame]
// WARNING: This file is machine generated by fidlgen.
// fidl_experiment = output_index_json
#pragma once
#include <fidl/test.enum/cpp/common_types.h>
#include <fidl/test.enum/cpp/markers.h>
#include <lib/fidl/cpp/natural_coding_traits.h>
#include <lib/fidl/cpp/natural_types.h>
#include <cinttypes>
#include <string>
#ifdef __Fuchsia__
#endif // __Fuchsia__
#pragma clang diagnostic push
#pragma clang diagnostic ignored "-Wshadow"
namespace test_enum {
} // namespace test_enum
namespace fidl {
template <>
struct internal::NaturalCodingTraits<::test_enum::MyStrictEnum, ::fidl::internal::NaturalCodingConstraintEmpty> {
static constexpr size_t kInlineSize = sizeof(uint32_t);
static constexpr bool kIsMemcpyCompatible = false;
static void Encode(internal::NaturalEncoder* encoder, ::test_enum::MyStrictEnum* value, size_t offset, size_t recursion_depth) {
switch (*value) {
case ::test_enum::MyStrictEnum::kFoo:
case ::test_enum::MyStrictEnum::kBar:
break;
default:
encoder->SetError(::fidl::internal::kCodingErrorUnknownEnumValue);
return;
}
*encoder->template GetPtr<::test_enum::MyStrictEnum>(offset) = *value;
}
static void Decode(internal::NaturalDecoder* decoder, ::test_enum::MyStrictEnum* value, size_t offset, size_t recursion_depth) {
*value = *decoder->template GetPtr<::test_enum::MyStrictEnum>(offset);
switch (*value) {
case ::test_enum::MyStrictEnum::kFoo:
case ::test_enum::MyStrictEnum::kBar:
break;
default:
decoder->SetError(::fidl::internal::kCodingErrorUnknownEnumValue);
return;
}
}
};
template <>
struct internal::NaturalCodingTraits<::test_enum::MyFlexibleEnum, ::fidl::internal::NaturalCodingConstraintEmpty> {
static constexpr size_t kInlineSize = sizeof(uint32_t);
static constexpr bool kIsMemcpyCompatible = true;
static void Encode(internal::NaturalEncoder* encoder, ::test_enum::MyFlexibleEnum* value, size_t offset, size_t recursion_depth) {
*encoder->template GetPtr<::test_enum::MyFlexibleEnum>(offset) = *value;
}
static void Decode(internal::NaturalDecoder* decoder, ::test_enum::MyFlexibleEnum* value, size_t offset, size_t recursion_depth) {
*value = *decoder->template GetPtr<::test_enum::MyFlexibleEnum>(offset);
}
};
template <>
struct internal::NaturalCodingTraits<::test_enum::MyFlexibleEnumWithCustomUnknown, ::fidl::internal::NaturalCodingConstraintEmpty> {
static constexpr size_t kInlineSize = sizeof(uint32_t);
static constexpr bool kIsMemcpyCompatible = true;
static void Encode(internal::NaturalEncoder* encoder, ::test_enum::MyFlexibleEnumWithCustomUnknown* value, size_t offset, size_t recursion_depth) {
*encoder->template GetPtr<::test_enum::MyFlexibleEnumWithCustomUnknown>(offset) = *value;
}
static void Decode(internal::NaturalDecoder* decoder, ::test_enum::MyFlexibleEnumWithCustomUnknown* value, size_t offset, size_t recursion_depth) {
*value = *decoder->template GetPtr<::test_enum::MyFlexibleEnumWithCustomUnknown>(offset);
}
};
template <>
struct internal::NaturalCodingTraits<::test_enum::MyEmptyFlexibleEnum, ::fidl::internal::NaturalCodingConstraintEmpty> {
static constexpr size_t kInlineSize = sizeof(uint32_t);
static constexpr bool kIsMemcpyCompatible = true;
static void Encode(internal::NaturalEncoder* encoder, ::test_enum::MyEmptyFlexibleEnum* value, size_t offset, size_t recursion_depth) {
*encoder->template GetPtr<::test_enum::MyEmptyFlexibleEnum>(offset) = *value;
}
static void Decode(internal::NaturalDecoder* decoder, ::test_enum::MyEmptyFlexibleEnum* value, size_t offset, size_t recursion_depth) {
*value = *decoder->template GetPtr<::test_enum::MyEmptyFlexibleEnum>(offset);
}
};
#pragma clang diagnostic pop
} // namespace fidl