diff options
author | hor911 <hor911@ydb.tech> | 2023-02-09 12:40:11 +0300 |
---|---|---|
committer | hor911 <hor911@ydb.tech> | 2023-02-09 12:40:11 +0300 |
commit | 24689527cd888aa8a640ecb5077e656b3520d373 (patch) | |
tree | a613ff4cd9567b7113e8376a17f8b85897a42790 /library/cpp/unified_agent_client/enum.h | |
parent | 8642d3642932f03663ba7d2d9670707c192207fd (diff) | |
download | ydb-24689527cd888aa8a640ecb5077e656b3520d373.tar.gz |
Log backend move
Diffstat (limited to 'library/cpp/unified_agent_client/enum.h')
-rw-r--r-- | library/cpp/unified_agent_client/enum.h | 30 |
1 files changed, 30 insertions, 0 deletions
diff --git a/library/cpp/unified_agent_client/enum.h b/library/cpp/unified_agent_client/enum.h new file mode 100644 index 0000000000..b21e21acb0 --- /dev/null +++ b/library/cpp/unified_agent_client/enum.h @@ -0,0 +1,30 @@ +#pragma once + +#include <util/generic/serialized_enum.h> +#include <util/generic/vector.h> + +namespace NUnifiedAgent { + namespace NPrivate { + using TEnumNames = TVector<const TString*>; + + template <typename TEnum> + TEnumNames BuildEnumNames() { + const auto names = GetEnumNames<TEnum>(); + auto result = TEnumNames(names.size()); + size_t index = 0; + for (const auto& p: names) { + Y_VERIFY(static_cast<size_t>(p.first) == index); + result[index++] = &p.second; + } + return result; + } + + template <typename TEnum> + inline const auto EnumNames = BuildEnumNames<TEnum>(); + } + + template <typename TEnum, typename = std::enable_if_t<std::is_enum_v<TEnum>>> + inline const TString& NameOf(TEnum val) noexcept { + return *NPrivate::EnumNames<TEnum>[static_cast<size_t>(val)]; + } +} |