blob: c97edf1f778e37b3e7ef78b73511663944b36ee6 [file] [log] [blame]
#pragma once
#include <android/binder_to_string.h>
#include <array>
#include <binder/Enums.h>
#include <binder/Parcel.h>
#include <binder/ParcelFileDescriptor.h>
#include <binder/Status.h>
#include <cassert>
#include <cstdint>
#include <string>
#include <type_traits>
#include <utility>
#include <utils/String16.h>
#include <variant>
#ifndef __BIONIC__
#define __assert2(a,b,c,d) ((void)0)
#endif
namespace android {
namespace aidl {
namespace tests {
class UnionWithFd : public ::android::Parcelable {
public:
enum class Tag : int32_t {
num = 0,
pfd = 1,
};
// Expose tag symbols for legacy code
static const inline Tag num = Tag::num;
static const inline Tag pfd = Tag::pfd;
template<typename _Tp>
static constexpr bool _not_self = !std::is_same_v<std::remove_cv_t<std::remove_reference_t<_Tp>>, UnionWithFd>;
UnionWithFd() : _value(std::in_place_index<static_cast<size_t>(num)>, int32_t(0)) { }
template <typename _Tp, typename = std::enable_if_t<_not_self<_Tp>>>
// NOLINTNEXTLINE(google-explicit-constructor)
constexpr UnionWithFd(_Tp&& _arg)
: _value(std::forward<_Tp>(_arg)) {}
template <size_t _Np, typename... _Tp>
constexpr explicit UnionWithFd(std::in_place_index_t<_Np>, _Tp&&... _args)
: _value(std::in_place_index<_Np>, std::forward<_Tp>(_args)...) {}
template <Tag _tag, typename... _Tp>
static UnionWithFd make(_Tp&&... _args) {
return UnionWithFd(std::in_place_index<static_cast<size_t>(_tag)>, std::forward<_Tp>(_args)...);
}
template <Tag _tag, typename _Tp, typename... _Up>
static UnionWithFd make(std::initializer_list<_Tp> _il, _Up&&... _args) {
return UnionWithFd(std::in_place_index<static_cast<size_t>(_tag)>, std::move(_il), std::forward<_Up>(_args)...);
}
Tag getTag() const {
return static_cast<Tag>(_value.index());
}
template <Tag _tag>
const auto& get() const {
if (getTag() != _tag) { __assert2(__FILE__, __LINE__, __PRETTY_FUNCTION__, "bad access: a wrong tag"); }
return std::get<static_cast<size_t>(_tag)>(_value);
}
template <Tag _tag>
auto& get() {
if (getTag() != _tag) { __assert2(__FILE__, __LINE__, __PRETTY_FUNCTION__, "bad access: a wrong tag"); }
return std::get<static_cast<size_t>(_tag)>(_value);
}
template <Tag _tag, typename... _Tp>
void set(_Tp&&... _args) {
_value.emplace<static_cast<size_t>(_tag)>(std::forward<_Tp>(_args)...);
}
inline bool operator!=(const UnionWithFd& rhs) const {
return _value != rhs._value;
}
inline bool operator<(const UnionWithFd& rhs) const {
return _value < rhs._value;
}
inline bool operator<=(const UnionWithFd& rhs) const {
return _value <= rhs._value;
}
inline bool operator==(const UnionWithFd& rhs) const {
return _value == rhs._value;
}
inline bool operator>(const UnionWithFd& rhs) const {
return _value > rhs._value;
}
inline bool operator>=(const UnionWithFd& rhs) const {
return _value >= rhs._value;
}
::android::status_t readFromParcel(const ::android::Parcel* _aidl_parcel) final;
::android::status_t writeToParcel(::android::Parcel* _aidl_parcel) const final;
static const ::android::String16& getParcelableDescriptor() {
static const ::android::StaticString16 DESCIPTOR (u"android.aidl.tests.UnionWithFd");
return DESCIPTOR;
}
inline std::string toString() const {
std::ostringstream os;
os << "UnionWithFd{";
switch (getTag()) {
case num: os << "num: " << ::android::internal::ToString(get<num>()); break;
case pfd: os << "pfd: " << ::android::internal::ToString(get<pfd>()); break;
}
os << "}";
return os.str();
}
private:
std::variant<int32_t, ::android::os::ParcelFileDescriptor> _value;
}; // class UnionWithFd
} // namespace tests
} // namespace aidl
} // namespace android
namespace android {
namespace aidl {
namespace tests {
[[nodiscard]] static inline std::string toString(UnionWithFd::Tag val) {
switch(val) {
case UnionWithFd::Tag::num:
return "num";
case UnionWithFd::Tag::pfd:
return "pfd";
default:
return std::to_string(static_cast<int32_t>(val));
}
}
} // namespace tests
} // namespace aidl
} // namespace android
namespace android {
namespace internal {
#pragma clang diagnostic push
#pragma clang diagnostic ignored "-Wc++17-extensions"
template <>
constexpr inline std::array<::android::aidl::tests::UnionWithFd::Tag, 2> enum_values<::android::aidl::tests::UnionWithFd::Tag> = {
::android::aidl::tests::UnionWithFd::Tag::num,
::android::aidl::tests::UnionWithFd::Tag::pfd,
};
#pragma clang diagnostic pop
} // namespace internal
} // namespace android