CMake/Source/cmCMakeMinimumRequired.cxx
Brad King 96afb12087 Convert CMake to OSI-approved BSD License
This converts the CMake license to a pure 3-clause OSI-approved BSD
License.  We drop the previous license clause requiring modified
versions to be plainly marked.  We also update the CMake copyright to
cover the full development time range.
2009-09-28 11:43:28 -04:00

133 lines
3.7 KiB
C++

/*============================================================================
CMake - Cross Platform Makefile Generator
Copyright 2000-2009 Kitware, Inc., Insight Software Consortium
Distributed under the OSI-approved BSD License (the "License");
see accompanying file Copyright.txt for details.
This software is distributed WITHOUT ANY WARRANTY; without even the
implied warranty of MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.
See the License for more information.
============================================================================*/
#include "cmCMakeMinimumRequired.h"
#include "cmVersion.h"
// cmCMakeMinimumRequired
bool cmCMakeMinimumRequired
::InitialPass(std::vector<std::string> const& args, cmExecutionStatus &)
{
// Process arguments.
std::string version_string;
bool doing_version = false;
for(unsigned int i=0; i < args.size(); ++i)
{
if(args[i] == "VERSION")
{
doing_version = true;
}
else if(args[i] == "FATAL_ERROR")
{
if(doing_version)
{
this->SetError("called with no value for VERSION.");
return false;
}
doing_version = false;
}
else if(doing_version)
{
doing_version = false;
version_string = args[i];
}
else
{
this->UnknownArguments.push_back(args[i]);
}
}
if(doing_version)
{
this->SetError("called with no value for VERSION.");
return false;
}
// Make sure there was a version to check.
if(version_string.empty())
{
return this->EnforceUnknownArguments();
}
// Save the required version string.
this->Makefile->AddDefinition("CMAKE_MINIMUM_REQUIRED_VERSION",
version_string.c_str());
// Get the current version number.
int current_major = cmVersion::GetMajorVersion();
int current_minor = cmVersion::GetMinorVersion();
int current_patch = cmVersion::GetPatchVersion();
// Parse the required version number. If no patch-level is given
// use zero.
int required_major = 0;
int required_minor = 0;
int required_patch = 0;
if(sscanf(version_string.c_str(), "%d.%d.%d",
&required_major, &required_minor, &required_patch) < 2)
{
cmOStringStream e;
e << "could not parse VERSION \"" << version_string.c_str() << "\".";
this->SetError(e.str().c_str());
return false;
}
// Compare the version numbers.
if((current_major < required_major) ||
(current_major == required_major &&
current_minor < required_minor) ||
(current_major == required_major &&
current_minor == required_minor &&
current_patch < required_patch))
{
// The current version is too low.
cmOStringStream e;
e << "CMake " << version_string.c_str()
<< " or higher is required. You are running version "
<< current_major << "." << current_minor << "." << current_patch;
this->Makefile->IssueMessage(cmake::FATAL_ERROR, e.str());
cmSystemTools::SetFatalErrorOccured();
return true;
}
// The version is not from the future, so enforce unknown arguments.
if(!this->EnforceUnknownArguments())
{
return false;
}
if (required_major < 2 || (required_major == 2 && required_minor < 4))
{
this->Makefile->SetPolicyVersion("2.4");
}
else
{
this->Makefile->SetPolicyVersion(version_string.c_str());
}
return true;
}
//----------------------------------------------------------------------------
bool cmCMakeMinimumRequired::EnforceUnknownArguments()
{
if(!this->UnknownArguments.empty())
{
cmOStringStream e;
e << "called with unknown argument \""
<< this->UnknownArguments[0] << "\".";
this->SetError(e.str().c_str());
return false;
}
return true;
}