summaryrefslogtreecommitdiffstats
diff options
context:
space:
mode:
-rw-r--r--Source/cmMakefile.cxx58
-rw-r--r--Source/cmMakefile.h4
2 files changed, 41 insertions, 21 deletions
diff --git a/Source/cmMakefile.cxx b/Source/cmMakefile.cxx
index 62d4c66..32767a3 100644
--- a/Source/cmMakefile.cxx
+++ b/Source/cmMakefile.cxx
@@ -533,39 +533,52 @@ bool cmMakefile::ProcessBuildsystemFile(const char* filename)
{
this->AddDefinition("CMAKE_PARENT_LIST_FILE", filename);
std::string curSrc = this->GetCurrentSourceDirectory();
+ std::string filenametoread =
+ cmSystemTools::CollapseFullPath(filename,
+ this->GetCurrentSourceDirectory());
+
+ this->ListFileStack.push_back(filenametoread);
+
+ cmListFile listFile;
+ if (!listFile.ParseFile(filenametoread.c_str(),
+ curSrc == this->GetHomeDirectory(), this))
+ {
+ return false;
+ }
+
this->PushPolicyBarrier();
- bool result = this->ReadListFile(filename,
- curSrc == this->GetHomeDirectory());
+ this->ReadListFile(listFile, filenametoread);
this->PopPolicyBarrier(!cmSystemTools::GetFatalErrorOccured());
this->EnforceDirectoryLevelRules();
- return result;
+ return true;
}
bool cmMakefile::ReadDependentFile(const char* filename, bool noPolicyScope)
{
this->AddDefinition("CMAKE_PARENT_LIST_FILE",
this->GetDefinition("CMAKE_CURRENT_LIST_FILE"));
+ std::string filenametoread =
+ cmSystemTools::CollapseFullPath(filename,
+ this->GetCurrentSourceDirectory());
+
+ this->ListFileStack.push_back(filenametoread);
+
+ cmListFile listFile;
+ if (!listFile.ParseFile(filenametoread.c_str(), false, this))
+ {
+ return false;
+ }
IncludeScope incScope(this, noPolicyScope);
- bool result = this->ReadListFile(filename, false);
+ this->ReadListFile(listFile, filenametoread);
if(cmSystemTools::GetFatalErrorOccured())
{
incScope.Quiet();
}
- return result;
+ return true;
}
bool cmMakefile::ReadListFile(const char* filename)
{
- this->PushPolicyBarrier();
- bool result = this->ReadListFile(filename, false);
- this->PopPolicyBarrier(!cmSystemTools::GetFatalErrorOccured());
- this->ListFileStack.pop_back();
- return result;
-}
-
-bool cmMakefile::ReadListFile(const char* filename,
- bool requireProjectCommand)
-{
std::string filenametoread =
cmSystemTools::CollapseFullPath(filename,
this->GetCurrentSourceDirectory());
@@ -573,12 +586,21 @@ bool cmMakefile::ReadListFile(const char* filename,
this->ListFileStack.push_back(filenametoread);
cmListFile listFile;
- if (!listFile.ParseFile(filenametoread.c_str(),
- requireProjectCommand, this))
+ if (!listFile.ParseFile(filenametoread.c_str(), false, this))
{
return false;
}
+ this->PushPolicyBarrier();
+ this->ReadListFile(listFile, filenametoread);
+ this->PopPolicyBarrier(!cmSystemTools::GetFatalErrorOccured());
+ this->ListFileStack.pop_back();
+ return true;
+}
+
+void cmMakefile::ReadListFile(cmListFile const& listFile,
+ std::string const& filenametoread)
+{
// add this list file to the list of dependencies
this->ListFiles.push_back(filenametoread);
@@ -625,8 +647,6 @@ bool cmMakefile::ReadListFile(const char* filename,
this->MarkVariableAsUsed("CMAKE_PARENT_LIST_FILE");
this->MarkVariableAsUsed("CMAKE_CURRENT_LIST_FILE");
this->MarkVariableAsUsed("CMAKE_CURRENT_LIST_DIR");
-
- return true;
}
//----------------------------------------------------------------------------
diff --git a/Source/cmMakefile.h b/Source/cmMakefile.h
index 24b4bd0..271cfd6 100644
--- a/Source/cmMakefile.h
+++ b/Source/cmMakefile.h
@@ -914,8 +914,8 @@ private:
cmState::Snapshot StateSnapshot;
- bool ReadListFile(const char* filename,
- bool requireProjectCommand);
+ void ReadListFile(cmListFile const& listFile,
+ const std::string& filenametoread);
bool ParseDefineFlag(std::string const& definition, bool remove);