Compute Graph Framework SDK Reference  5.14
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) NAME_STR##_sv
53#define DW_DESCRIBE_ENUMERATOR(NAME) describeEnumerator(DW_ENUMERATOR_NAME_STRING_VIEW(#NAME), EnumT::NAME)
61#define DW_DESCRIBE_C_ENUMERATOR(NAME) describeEnumerator(DW_ENUMERATOR_NAME_STRING_VIEW(#NAME), (NAME))
62
63namespace dw
64{
65namespace framework
66{
67
68// API to declare the mapping of a concrete enum.
69
70template <typename EnumT>
72{
73 static_assert(std::is_enum<EnumT>::value, "EnumT must be an enumeration type");
74
83 // coverity[autosar_cpp14_a2_10_5_violation] RFD Pending: TID-2053
84 static constexpr auto get()
85 {
86 static_assert(sizeof(EnumT) == 0, "Needs specialization for specific enum type");
87 constexpr const size_t numberOfEnumerators = 0;
88 std::array<std::pair<dw::core::StringView, EnumT>, numberOfEnumerators> ret;
89 return ret;
90 }
91};
92
93// API needed to declare the enumerators of an enum.
94
105template <typename EnumT, typename... Args>
106// coverity[autosar_cpp14_a2_10_5_violation] FP: nvbugs/3907242
107constexpr auto describeEnumeratorCollection(Args const&&... args) -> std::array<std::pair<dw::core::StringView, EnumT>, sizeof...(Args)>
108{
109 return std::array<std::pair<dw::core::StringView, EnumT>, sizeof...(Args)>{std::forward<const Args>(args)...};
110}
111
124template <typename EnumT>
125// coverity[autosar_cpp14_a2_10_5_violation] FP: nvbugs/3907242
126constexpr auto describeEnumerator(dw::core::StringView const&& name, EnumT value) -> std::pair<dw::core::StringView, EnumT>
127{
128 return std::make_pair(std::move(name), value);
129}
130
138template <typename EnumT>
139// coverity[autosar_cpp14_a2_10_5_violation] FP: nvbugs/3907242
140auto mapEnumNameToValue(dw::core::StringView const& name) -> EnumT
141{
142 // coverity[autosar_cpp14_a8_5_2_violation]
143 const auto pairs = EnumDescription<EnumT>::get();
144 for (const auto& pair : pairs)
145 {
146 if (pair.first == name)
147 {
148 return pair.second;
149 }
150 }
151 // coverity[autosar_cpp14_a18_5_8_violation]
152 FixedString<4096> validNames{};
153 for (const auto& pair : pairs)
154 {
155 // coverity[autosar_cpp14_a5_1_1_violation]
156 validNames << " " << 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 const &&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.