From c8560955622048d645f61ecd21837094b5fc8695 Mon Sep 17 00:00:00 2001 From: =?UTF-8?q?=CE=B6eh=20Matt?= <3397065-ZehMatt@users.noreply.gitlab.com> Date: Thu, 8 Sep 2022 00:31:29 +0300 Subject: [PATCH] Use compile time generated indices for tuples types --- apps/openmw/mwworld/esmstore.cpp | 7 ------- apps/openmw/mwworld/esmstore.hpp | 7 ++----- components/misc/meta.hpp | 16 ++++++++++++++++ 3 files changed, 18 insertions(+), 12 deletions(-) diff --git a/apps/openmw/mwworld/esmstore.cpp b/apps/openmw/mwworld/esmstore.cpp index 6c784aade0..9316dd6c40 100644 --- a/apps/openmw/mwworld/esmstore.cpp +++ b/apps/openmw/mwworld/esmstore.cpp @@ -316,13 +316,6 @@ void ESMStore::setIdType(const std::string& id, ESM::RecNameInts type) mStoreImp->mIds[id] = type; } -static std::size_t sTypeIndexCounter = 0; - -std::size_t ESMStore::geNextTypeIndex() -{ - return sTypeIndexCounter++; -} - ESM::LuaScriptsCfg ESMStore::getLuaScriptsCfg() const { ESM::LuaScriptsCfg cfg; diff --git a/apps/openmw/mwworld/esmstore.hpp b/apps/openmw/mwworld/esmstore.hpp index 8a7547fb96..03d580d28e 100644 --- a/apps/openmw/mwworld/esmstore.hpp +++ b/apps/openmw/mwworld/esmstore.hpp @@ -126,14 +126,11 @@ namespace MWWorld // Special entry which is hardcoded and not loaded from an ESM Store>; - static std::size_t geNextTypeIndex(); - template - static std::size_t getTypeIndex() + static constexpr std::size_t getTypeIndex() { static_assert(Misc::TupleHasType, StoreTuple>::value); - static std::size_t sIndex = geNextTypeIndex(); - return sIndex; + return Misc::TupleTypeIndex, StoreTuple>::value; } std::unique_ptr mStoreImp; diff --git a/components/misc/meta.hpp b/components/misc/meta.hpp index d0b49476fa..fda6fb32e3 100644 --- a/components/misc/meta.hpp +++ b/components/misc/meta.hpp @@ -1,6 +1,7 @@ #ifndef OPENMW_COMPONENTS_MISC_META_H #define OPENMW_COMPONENTS_MISC_META_H +#include #include #include @@ -14,6 +15,21 @@ namespace Misc { static constexpr bool value = (std::is_same_v || ...); }; + + template + struct TupleTypeIndex; + + template + struct TupleTypeIndex> + { + static constexpr std::size_t value = 0; + }; + + template + struct TupleTypeIndex> + { + static constexpr std::size_t value = 1 + TupleTypeIndex>::value; + }; } #endif