diff --git a/Source/cmCMakeMinimumRequired.cxx b/Source/cmCMakeMinimumRequired.cxx index 9a96093614..e618c1b3d8 100644 --- a/Source/cmCMakeMinimumRequired.cxx +++ b/Source/cmCMakeMinimumRequired.cxx @@ -30,8 +30,18 @@ bool cmCMakeMinimumRequired::InitialPass(std::vector const& args) } float version = float(m_Makefile->GetMajorVersion()); version += (float(m_Makefile->GetMinorVersion()) * (float).1); + version += (float(m_Makefile->GetPatchVersion()) * (float).01); float reqVersion = 0; - sscanf(args[1].c_str(), "%f", &reqVersion); + int major=0; + int minor=0; + int patch=0; + + int res=sscanf(args[1].c_str(), "%d.%d.%d", &major, &minor, &patch); + if (res==3) + reqVersion=float(major)+0.1*float(minor)+0.01*float(patch); + else if (res==2) + reqVersion=float(major)+0.1*float(minor); + if(reqVersion > version) { cmOStringStream str; diff --git a/Source/cmMakefile.h b/Source/cmMakefile.h index 5d00c9330b..e8b159c56b 100644 --- a/Source/cmMakefile.h +++ b/Source/cmMakefile.h @@ -50,6 +50,7 @@ public: */ static unsigned int GetMajorVersion() { return CMake_VERSION_MAJOR; } static unsigned int GetMinorVersion() { return CMake_VERSION_MINOR; } + static unsigned int GetPatchVersion() { return CMake_VERSION_PATCH; } static const char* GetReleaseVersion(); /** diff --git a/Source/cmVersion.h b/Source/cmVersion.h index 92ed9882d0..29eb9d19bc 100644 --- a/Source/cmVersion.h +++ b/Source/cmVersion.h @@ -32,6 +32,7 @@ public: */ static unsigned int GetMajorVersion() { return CMake_VERSION_MAJOR; } static unsigned int GetMinorVersion() { return CMake_VERSION_MINOR; } + static unsigned int GetPatchVersion() { return CMake_VERSION_PATCH; } static std::string GetReleaseVersion(); static std::string GetCMakeVersion(); };