1 /*
2 * This file is auto-generated. DO NOT MODIFY.
3 * Using: out/host/linux-x86/bin/aidl --lang=ndk -Weverything -Wno-missing-permission-annotation -t --min_sdk_version 31 --ninja -d out/soong/.intermediates/art/artd/binder/artd-aidl-ndk-source/gen/staging/com/android/server/art/VdexPath.cpp.d -h out/soong/.intermediates/art/artd/binder/artd-aidl-ndk-source/gen/include/staging -o out/soong/.intermediates/art/artd/binder/artd-aidl-ndk-source/gen/staging -Nart/artd/binder art/artd/binder/com/android/server/art/VdexPath.aidl
4 *
5 * DO NOT CHECK THIS FILE INTO A CODE TREE (e.g. git, etc..).
6 * ALWAYS GENERATE THIS FILE FROM UPDATED AIDL COMPILER
7 * AS A BUILD INTERMEDIATE ONLY. THIS IS NOT SOURCE CODE.
8 */
9 #pragma once
10
11 #include <array>
12 #include <cassert>
13 #include <cstdint>
14 #include <memory>
15 #include <optional>
16 #include <string>
17 #include <type_traits>
18 #include <utility>
19 #include <variant>
20 #include <vector>
21 #include <android/binder_enums.h>
22 #include <android/binder_interface_utils.h>
23 #include <android/binder_parcelable_utils.h>
24 #include <android/binder_to_string.h>
25 #include <aidl/com/android/server/art/ArtifactsPath.h>
26 #ifdef BINDER_STABILITY_SUPPORT
27 #include <android/binder_stability.h>
28 #endif // BINDER_STABILITY_SUPPORT
29
30 #ifndef __BIONIC__
31 #define __assert2(a,b,c,d) ((void)0)
32 #endif
33
34 namespace aidl::com::android::server::art {
35 class ArtifactsPath;
36 } // namespace aidl::com::android::server::art
37 namespace aidl {
38 namespace com {
39 namespace android {
40 namespace server {
41 namespace art {
42 class VdexPath {
43 public:
44 typedef std::false_type fixed_size;
45 static const char* descriptor;
46
47 enum class Tag : int32_t {
48 artifactsPath = 0,
49 };
50
51 // Expose tag symbols for legacy code
52 static const inline Tag artifactsPath = Tag::artifactsPath;
53
54 template<typename _Tp>
55 static constexpr bool _not_self = !std::is_same_v<std::remove_cv_t<std::remove_reference_t<_Tp>>, VdexPath>;
56
VdexPath()57 VdexPath() : _value(std::in_place_index<static_cast<size_t>(artifactsPath)>, ::aidl::com::android::server::art::ArtifactsPath()) { }
58
59 template <typename _Tp, typename = std::enable_if_t<_not_self<_Tp>>>
60 // NOLINTNEXTLINE(google-explicit-constructor)
VdexPath(_Tp && _arg)61 constexpr VdexPath(_Tp&& _arg)
62 : _value(std::forward<_Tp>(_arg)) {}
63
64 template <size_t _Np, typename... _Tp>
VdexPath(std::in_place_index_t<_Np>,_Tp &&..._args)65 constexpr explicit VdexPath(std::in_place_index_t<_Np>, _Tp&&... _args)
66 : _value(std::in_place_index<_Np>, std::forward<_Tp>(_args)...) {}
67
68 template <Tag _tag, typename... _Tp>
make(_Tp &&..._args)69 static VdexPath make(_Tp&&... _args) {
70 return VdexPath(std::in_place_index<static_cast<size_t>(_tag)>, std::forward<_Tp>(_args)...);
71 }
72
73 template <Tag _tag, typename _Tp, typename... _Up>
make(std::initializer_list<_Tp> _il,_Up &&..._args)74 static VdexPath make(std::initializer_list<_Tp> _il, _Up&&... _args) {
75 return VdexPath(std::in_place_index<static_cast<size_t>(_tag)>, std::move(_il), std::forward<_Up>(_args)...);
76 }
77
getTag()78 Tag getTag() const {
79 return static_cast<Tag>(_value.index());
80 }
81
82 template <Tag _tag>
get()83 const auto& get() const {
84 if (getTag() != _tag) { __assert2(__FILE__, __LINE__, __PRETTY_FUNCTION__, "bad access: a wrong tag"); }
85 return std::get<static_cast<size_t>(_tag)>(_value);
86 }
87
88 template <Tag _tag>
get()89 auto& get() {
90 if (getTag() != _tag) { __assert2(__FILE__, __LINE__, __PRETTY_FUNCTION__, "bad access: a wrong tag"); }
91 return std::get<static_cast<size_t>(_tag)>(_value);
92 }
93
94 template <Tag _tag, typename... _Tp>
set(_Tp &&..._args)95 void set(_Tp&&... _args) {
96 _value.emplace<static_cast<size_t>(_tag)>(std::forward<_Tp>(_args)...);
97 }
98
99 binder_status_t readFromParcel(const AParcel* _parcel);
100 binder_status_t writeToParcel(AParcel* _parcel) const;
101
102 inline bool operator==(const VdexPath& _rhs) const {
103 return _value == _rhs._value;
104 }
105 inline bool operator<(const VdexPath& _rhs) const {
106 return _value < _rhs._value;
107 }
108 inline bool operator!=(const VdexPath& _rhs) const {
109 return !(*this == _rhs);
110 }
111 inline bool operator>(const VdexPath& _rhs) const {
112 return _rhs < *this;
113 }
114 inline bool operator>=(const VdexPath& _rhs) const {
115 return !(*this < _rhs);
116 }
117 inline bool operator<=(const VdexPath& _rhs) const {
118 return !(_rhs < *this);
119 }
120
121 static const ::ndk::parcelable_stability_t _aidl_stability = ::ndk::STABILITY_LOCAL;
toString()122 inline std::string toString() const {
123 std::ostringstream os;
124 os << "VdexPath{";
125 switch (getTag()) {
126 case artifactsPath: os << "artifactsPath: " << ::android::internal::ToString(get<artifactsPath>()); break;
127 }
128 os << "}";
129 return os.str();
130 }
131 private:
132 std::variant<::aidl::com::android::server::art::ArtifactsPath> _value;
133 };
134 } // namespace art
135 } // namespace server
136 } // namespace android
137 } // namespace com
138 } // namespace aidl
139 namespace aidl {
140 namespace com {
141 namespace android {
142 namespace server {
143 namespace art {
toString(VdexPath::Tag val)144 [[nodiscard]] static inline std::string toString(VdexPath::Tag val) {
145 switch(val) {
146 case VdexPath::Tag::artifactsPath:
147 return "artifactsPath";
148 default:
149 return std::to_string(static_cast<int32_t>(val));
150 }
151 }
152 } // namespace art
153 } // namespace server
154 } // namespace android
155 } // namespace com
156 } // namespace aidl
157 namespace ndk {
158 namespace internal {
159 #pragma clang diagnostic push
160 #pragma clang diagnostic ignored "-Wc++17-extensions"
161 template <>
162 constexpr inline std::array<aidl::com::android::server::art::VdexPath::Tag, 1> enum_values<aidl::com::android::server::art::VdexPath::Tag> = {
163 aidl::com::android::server::art::VdexPath::Tag::artifactsPath,
164 };
165 #pragma clang diagnostic pop
166 } // namespace internal
167 } // namespace ndk
168