From 99fa01d3faa70f1e214acd56ce25002ae310c51d Mon Sep 17 00:00:00 2001 From: Brad King Date: Wed, 4 Oct 2023 13:38:01 -0400 Subject: cmStandardLevelResolver: Factor out public representation of level --- Source/CMakeLists.txt | 1 + Source/cmStandardLevel.h | 21 +++++++++++++++++++++ Source/cmStandardLevelResolver.cxx | 32 +++++++++++++++----------------- 3 files changed, 37 insertions(+), 17 deletions(-) create mode 100644 Source/cmStandardLevel.h diff --git a/Source/CMakeLists.txt b/Source/CMakeLists.txt index 37d407b..1bc855e 100644 --- a/Source/CMakeLists.txt +++ b/Source/CMakeLists.txt @@ -417,6 +417,7 @@ add_library( cmSourceFileLocationKind.h cmSourceGroup.cxx cmSourceGroup.h + cmStandardLevel.h cmStandardLevelResolver.cxx cmStandardLevelResolver.h cmState.cxx diff --git a/Source/cmStandardLevel.h b/Source/cmStandardLevel.h new file mode 100644 index 0000000..86d178b --- /dev/null +++ b/Source/cmStandardLevel.h @@ -0,0 +1,21 @@ +/* Distributed under the OSI-approved BSD 3-Clause License. See accompanying + file Copyright.txt or https://cmake.org/licensing for details. */ +#pragma once + +#include "cmConfigure.h" // IWYU pragma: keep + +class cmStandardLevel +{ + size_t index_; + +public: + cmStandardLevel(size_t index) + : index_(index) + { + } + size_t Index() const { return index_; } + friend bool operator<(cmStandardLevel const& l, cmStandardLevel const& r) + { + return l.index_ < r.index_; + } +}; diff --git a/Source/cmStandardLevelResolver.cxx b/Source/cmStandardLevelResolver.cxx index 469bef8..41dd316 100644 --- a/Source/cmStandardLevelResolver.cxx +++ b/Source/cmStandardLevelResolver.cxx @@ -13,6 +13,7 @@ #include #include +#include #include #include #include @@ -25,6 +26,7 @@ #include "cmMakefile.h" #include "cmMessageType.h" #include "cmPolicies.h" +#include "cmStandardLevel.h" #include "cmStringAlgorithms.h" #include "cmTarget.h" #include "cmValue.h" @@ -46,12 +48,6 @@ const char* const HIP_FEATURES[] = { nullptr FOR_EACH_HIP_FEATURE( FEATURE_STRING) }; #undef FEATURE_STRING -struct StandardNeeded -{ - int index; - int value; -}; - int ParseStd(std::string const& level) { try { @@ -352,7 +348,8 @@ struct StandardLevelComputer newRequiredStandard.clear(); } - auto needed = this->HighestStandardNeeded(makefile, feature); + cm::optional needed = + this->HighestStandardNeeded(makefile, feature); cmValue existingStandard = currentLangStandardValue; if (!existingStandard) { @@ -382,12 +379,12 @@ struct StandardLevelComputer } } - if (needed.index != -1) { + if (needed) { // Ensure the C++ language level is high enough to support // the needed C++ features. if (existingLevelIter == cm::cend(this->Levels) || - existingLevelIter < this->Levels.begin() + needed.index) { - newRequiredStandard = this->LevelsAsStrings[needed.index]; + existingLevelIter < this->Levels.begin() + needed->Index()) { + newRequiredStandard = this->LevelsAsStrings[needed->Index()]; } } @@ -439,23 +436,24 @@ struct StandardLevelComputer return false; } - auto needed = this->HighestStandardNeeded(makefile, feature); + cm::optional needed = + this->HighestStandardNeeded(makefile, feature); - return (needed.index == -1) || - (this->Levels.begin() + needed.index) <= existingLevelIter; + return !needed || + (this->Levels.begin() + needed->Index()) <= existingLevelIter; } - StandardNeeded HighestStandardNeeded(cmMakefile* makefile, - std::string const& feature) const + cm::optional HighestStandardNeeded( + cmMakefile* makefile, std::string const& feature) const { std::string prefix = cmStrCat("CMAKE_", this->Language); - StandardNeeded maxLevel = { -1, -1 }; + cm::optional maxLevel; for (size_t i = 0; i < this->Levels.size(); ++i) { if (cmValue prop = makefile->GetDefinition( cmStrCat(prefix, this->LevelsAsStrings[i], "_COMPILE_FEATURES"))) { cmList props{ *prop }; if (cm::contains(props, feature)) { - maxLevel = { static_cast(i), this->Levels[i] }; + maxLevel = cmStandardLevel(i); } } } -- cgit v0.12