From edf67dd039f40a4222e41cc15a197cb6395bf885 Mon Sep 17 00:00:00 2001 From: Marc Chevrier Date: Tue, 21 Sep 2021 17:13:14 +0200 Subject: cmValue: add IsInternallyOn methods --- Source/cmStringAlgorithms.cxx | 9 --------- Source/cmStringAlgorithms.h | 15 ++++++--------- Source/cmValue.cxx | 10 ++++++++++ Source/cmValue.h | 22 ++++++++++++++++++++++ 4 files changed, 38 insertions(+), 18 deletions(-) diff --git a/Source/cmStringAlgorithms.cxx b/Source/cmStringAlgorithms.cxx index acb5e5b..1bb6808 100644 --- a/Source/cmStringAlgorithms.cxx +++ b/Source/cmStringAlgorithms.cxx @@ -218,15 +218,6 @@ std::string cmCatViews(std::initializer_list views) return result; } -bool cmIsInternallyOn(cm::string_view val) -{ - return (val.size() == 4) && // - (val[0] == 'I' || val[0] == 'i') && // - (val[1] == '_') && // - (val[2] == 'O' || val[2] == 'o') && // - (val[3] == 'N' || val[3] == 'n'); -} - bool cmStrToLong(const char* str, long* value) { errno = 0; diff --git a/Source/cmStringAlgorithms.h b/Source/cmStringAlgorithms.h index a9edcdf..fd5febf 100644 --- a/Source/cmStringAlgorithms.h +++ b/Source/cmStringAlgorithms.h @@ -224,20 +224,17 @@ std::string cmWrap(char prefix, Range const& rng, char suffix, * forced this value. This is not the same as On, but this * may be considered as "internally switched on". */ -bool cmIsInternallyOn(cm::string_view val); +inline bool cmIsInternallyOn(cm::string_view val) +{ + return cmValue::IsInternallyOn(val); +} inline bool cmIsInternallyOn(const char* val) { - if (!val) { - return false; - } - return cmIsInternallyOn(cm::string_view(val)); + return cmValue::IsInternallyOn(val); } inline bool cmIsInternallyOn(cmValue val) { - if (!val) { - return false; - } - return cmIsInternallyOn(*val); + return val.IsInternallyOn(); } /** Check for non-empty Property/Variable value. */ diff --git a/Source/cmValue.cxx b/Source/cmValue.cxx index 59bf201..044db29 100644 --- a/Source/cmValue.cxx +++ b/Source/cmValue.cxx @@ -73,11 +73,21 @@ bool cmValue::IsOff(cm::string_view value) noexcept return IsNOTFOUND(value); } + bool cmValue::IsNOTFOUND(cm::string_view value) noexcept { return (value == "NOTFOUND"_s) || cmHasSuffix(value, "-NOTFOUND"_s); } +bool cmValue::IsInternallyOn(cm::string_view value) noexcept +{ + return (value.size() == 4) && // + (value[0] == 'I' || value[0] == 'i') && // + (value[1] == '_') && // + (value[2] == 'O' || value[2] == 'o') && // + (value[3] == 'N' || value[3] == 'n'); +} + int cmValue::Compare(cmValue value) const noexcept { if (this->Value == nullptr && !value) { diff --git a/Source/cmValue.h b/Source/cmValue.h index 43a5e0d..c79b997 100644 --- a/Source/cmValue.h +++ b/Source/cmValue.h @@ -85,6 +85,17 @@ public: return this->Value == nullptr || this->Value->empty(); } + /** + * Does a string indicates that CMake/CPack/CTest internally + * forced this value. This is not the same as On, but this + * may be considered as "internally switched on". + */ + bool IsInternallyOn() const noexcept + { + return this->Value != nullptr && + cmValue::IsInternallyOn(cm::string_view(*this->Value)); + } + bool IsSet() const noexcept { return !this->IsEmpty() && !this->IsNOTFOUND(); @@ -131,6 +142,17 @@ public: } static bool IsEmpty(cm::string_view value) noexcept { return value.empty(); } + /** + * Does a string indicates that CMake/CPack/CTest internally + * forced this value. This is not the same as On, but this + * may be considered as "internally switched on". + */ + static bool IsInternallyOn(const char* value) noexcept + { + return value != nullptr && IsInternallyOn(cm::string_view(value)); + } + static bool IsInternallyOn(cm::string_view) noexcept; + private: static std::string Empty; const std::string* Value = nullptr; -- cgit v0.12