diff options
author | Brad King <brad.king@kitware.com> | 2009-06-17 17:40:09 (GMT) |
---|---|---|
committer | Brad King <brad.king@kitware.com> | 2009-06-17 17:40:09 (GMT) |
commit | c790b1fabbc7b160bd67e1654a34964fd897a36c (patch) | |
tree | 35af1a3c2f59d02c85f3fd1908b9fbde32b0e75c /Source/cmMakefile.cxx | |
parent | f61f8e538383ee632aafc7ac74cd1d118288b310 (diff) | |
download | CMake-c790b1fabbc7b160bd67e1654a34964fd897a36c.zip CMake-c790b1fabbc7b160bd67e1654a34964fd897a36c.tar.gz CMake-c790b1fabbc7b160bd67e1654a34964fd897a36c.tar.bz2 |
ENH: Create CMP0013 to disallow duplicate dirs
In CMake 2.6.3 and below we silently accepted duplicate build
directories whose build files would then conflict. At first this was
considured purely a bug that confused beginners but would not be used in
a real project. In CMake 2.6.4 we explicitly made it an error.
However, some real projects took advantage of this as a "feature" and
got lucky that the subtle build errors it can cause did not occur.
Therefore we need a policy to deal with the case more gracefully.
See issue #9173.
Diffstat (limited to 'Source/cmMakefile.cxx')
-rw-r--r-- | Source/cmMakefile.cxx | 59 |
1 files changed, 49 insertions, 10 deletions
diff --git a/Source/cmMakefile.cxx b/Source/cmMakefile.cxx index fc57276..57904b4 100644 --- a/Source/cmMakefile.cxx +++ b/Source/cmMakefile.cxx @@ -1545,17 +1545,8 @@ void cmMakefile::AddSubDirectory(const char* srcPath, const char *binPath, } // Make sure the binary directory is unique. - cmGlobalGenerator* gg = this->LocalGenerator->GetGlobalGenerator(); - if(!gg->BinaryDirectoryIsNew(binPath)) + if(!this->EnforceUniqueDir(srcPath, binPath)) { - cmOStringStream e; - e << "The binary directory\n" - << " " << binPath << "\n" - << "is already used to build another source directory, so it cannot " - << "be used to build source directory\n" - << " " << srcPath << "\n" - << "Specify a unique binary directory name."; - this->IssueMessage(cmake::FATAL_ERROR, e.str()); return; } @@ -3720,6 +3711,54 @@ bool cmMakefile::EnforceUniqueName(std::string const& name, std::string& msg, } //---------------------------------------------------------------------------- +bool cmMakefile::EnforceUniqueDir(const char* srcPath, const char* binPath) +{ + // Make sure the binary directory is unique. + cmGlobalGenerator* gg = this->LocalGenerator->GetGlobalGenerator(); + if(gg->BinaryDirectoryIsNew(binPath)) + { + return true; + } + cmOStringStream e; + switch (this->GetPolicyStatus(cmPolicies::CMP0013)) + { + case cmPolicies::WARN: + // Print the warning. + e << this->GetPolicies()->GetPolicyWarning(cmPolicies::CMP0013) + << "\n" + << "The binary directory\n" + << " " << binPath << "\n" + << "is already used to build a source directory. " + << "This command uses it to build source directory\n" + << " " << srcPath << "\n" + << "which can generate conflicting build files. " + << "CMake does not support this use case but it used " + << "to work accidentally and is being allowed for " + << "compatibility."; + this->IssueMessage(cmake::AUTHOR_WARNING, e.str()); + case cmPolicies::OLD: + // OLD behavior does not warn. + return true; + case cmPolicies::REQUIRED_IF_USED: + case cmPolicies::REQUIRED_ALWAYS: + e << this->GetPolicies()->GetRequiredPolicyError(cmPolicies::CMP0013) + << "\n"; + case cmPolicies::NEW: + // NEW behavior prints the error. + e << "The binary directory\n" + << " " << binPath << "\n" + << "is already used to build a source directory. " + << "It cannot be used to build source directory\n" + << " " << srcPath << "\n" + << "Specify a unique binary directory name."; + this->IssueMessage(cmake::FATAL_ERROR, e.str()); + break; + } + + return false; +} + +//---------------------------------------------------------------------------- cmPolicies::PolicyStatus cmMakefile::GetPolicyStatus(cmPolicies::PolicyID id) { |