Compute Graph Framework SDK Reference  5.16
EnumDescriptor.hpp
Go to the documentation of this file.
1
2//
3// Notice
4// ALL NVIDIA DESIGN SPECIFICATIONS AND CODE ("MATERIALS") ARE PROVIDED "AS IS" NVIDIA MAKES
5// NO REPRESENTATIONS, WARRANTIES, EXPRESSED, IMPLIED, STATUTORY, OR OTHERWISE WITH RESPECT TO
6// THE MATERIALS, AND EXPRESSLY DISCLAIMS ANY IMPLIED WARRANTIES OF NONINFRINGEMENT,
7// MERCHANTABILITY, OR FITNESS FOR A PARTICULAR PURPOSE.
8//
9// NVIDIA CORPORATION & AFFILIATES assumes no responsibility for the consequences of use of such
10// information or for any infringement of patents or other rights of third parties that may
11// result from its use. No license is granted by implication or otherwise under any patent
12// or patent rights of NVIDIA CORPORATION & AFFILIATES. No third party distribution is allowed unless
13// expressly authorized by NVIDIA. Details are subject to change without notice.
14// This code supersedes and replaces all information previously supplied.
15// NVIDIA CORPORATION & AFFILIATES products are not authorized for use as critical
16// components in life support devices or systems without express written approval of
17// NVIDIA CORPORATION & AFFILIATES.
18//
19// SPDX-FileCopyrightText: Copyright (c) 2021-2023 NVIDIA CORPORATION & AFFILIATES. All rights reserved.
20// SPDX-License-Identifier: LicenseRef-NvidiaProprietary
21//
22// NVIDIA CORPORATION, its affiliates and licensors retain all intellectual
23// property and proprietary rights in and to this material, related
24// documentation and any modifications thereto. Any use, reproduction,
25// disclosure or distribution of this material and related documentation
26// without an express license agreement from NVIDIA CORPORATION or
27// its affiliates is strictly prohibited.
28//
30
31#ifndef DW_FRAMEWORK_ENUMDESCRIPTOR_HPP_
32#define DW_FRAMEWORK_ENUMDESCRIPTOR_HPP_
33
34#include <dw/core/base/Status.h>
35#include <dwshared/dwfoundation/dw/core/container/StringView.hpp>
36
37#include <dwcgf/Exception.hpp>
38
39#include <array>
40#include <utility>
41#include <type_traits>
42
43#define DW_ENUMERATOR_NAME_STRING_VIEW(NAME_STR) \
44 dw::core::StringView { NAME_STR }
54#define DW_DESCRIBE_ENUMERATOR(NAME) describeEnumerator(DW_ENUMERATOR_NAME_STRING_VIEW(#NAME), EnumT::NAME)
62#define DW_DESCRIBE_C_ENUMERATOR(NAME) describeEnumerator(DW_ENUMERATOR_NAME_STRING_VIEW(#NAME), (NAME))
63
64namespace dw
65{
66namespace framework
67{
68
69// API to declare the mapping of a concrete enum.
70
71template <typename EnumT>
73{
74 static_assert(std::is_enum<EnumT>::value, "EnumT must be an enumeration type");
75
84 // coverity[autosar_cpp14_a2_10_5_violation] RFD Pending: TID-2053
85 static constexpr auto get()
86 {
87 static_assert(sizeof(EnumT) == 0, "Needs specialization for specific enum type");
88 constexpr const size_t numberOfEnumerators = 0;
89 std::array<std::pair<dw::core::StringView, EnumT>, numberOfEnumerators> ret;
90 return ret;
91 }
92};
93
94// API needed to declare the enumerators of an enum.
95
106template <typename EnumT, typename... Args>
107// coverity[autosar_cpp14_a2_10_5_violation] FP: nvbugs/3907242
108constexpr auto describeEnumeratorCollection(Args const&&... args) -> std::array<std::pair<dw::core::StringView, EnumT>, sizeof...(Args)>
109{
110 return std::array<std::pair<dw::core::StringView, EnumT>, sizeof...(Args)>{std::forward<const Args>(args)...};
111}
112
125template <typename EnumT>
126// coverity[autosar_cpp14_a2_10_5_violation] FP: nvbugs/3907242
127constexpr auto describeEnumerator(dw::core::StringView&& name, EnumT value) -> std::pair<dw::core::StringView, EnumT>
128{
129 return std::make_pair(std::move(name), value);
130}
131
139template <typename EnumT>
140// coverity[autosar_cpp14_a2_10_5_violation] FP: nvbugs/3907242
141auto mapEnumNameToValue(dw::core::StringView const& name) -> EnumT
142{
143 // coverity[autosar_cpp14_a8_5_2_violation]
144 const auto pairs = EnumDescription<EnumT>::get();
145 for (const auto& pair : pairs)
146 {
147 if (pair.first == name)
148 {
149 return pair.second;
150 }
151 }
152 // coverity[autosar_cpp14_a18_5_8_violation] FP: nvbugs/3498833
153 FixedString<4096> validNames{};
154 for (const auto& pair : pairs)
155 {
156 validNames << dw::core::StringView{" "} << pair.first;
157 }
158 throw ExceptionWithStatus(DW_INVALID_ARGUMENT, "Invalid enumerator name '", name, "' for enum type ", typeid(EnumT).name(), ", valid names:", validNames);
159}
160
168template <typename EnumT>
169// coverity[autosar_cpp14_a2_10_5_violation] FP: nvbugs/3907242
170dw::core::StringView mapEnumValueToName(EnumT value)
171{
172 // coverity[autosar_cpp14_a8_5_2_violation]
173 const auto pairs = EnumDescription<EnumT>::get();
174 for (const auto& pair : pairs)
175 {
176 if (pair.second == value)
177 {
178 return pair.first;
179 }
180 }
181 throw ExceptionWithStatus(DW_INVALID_ARGUMENT, "The enumerator value is invalid: ", typeid(EnumT).name(), " ", static_cast<std::underlying_type_t<EnumT>>(value));
182}
183
184} // namespace framework
185} // namespace dw
186
187#endif // DW_FRAMEWORK_ENUMDESCRIPTOR_HPP_
dw::core::StringView mapEnumValueToName(EnumT value)
Get the enumerator name based on the value.
constexpr auto describeEnumeratorCollection(Args const &&... args) -> std::array< std::pair< dw::core::StringView, EnumT >, sizeof...(Args)>
Describe the enumerators.
constexpr auto describeEnumerator(dw::core::StringView &&name, EnumT value) -> std::pair< dw::core::StringView, EnumT >
Describe an enumerator.
auto mapEnumNameToValue(dw::core::StringView const &name) -> EnumT
Get the enumerator value based on the name.
Definition: Buffer.hpp:40
static constexpr auto get()
Describe the enumerators.