summaryrefslogtreecommitdiffstats
path: root/Source
diff options
context:
space:
mode:
authorKen Martin <ken.martin@kitware.com>2005-06-07 14:47:28 (GMT)
committerKen Martin <ken.martin@kitware.com>2005-06-07 14:47:28 (GMT)
commit749fe2639429cd2d3944c01ba70515c2d9d6fbcc (patch)
tree3c9e16f28dddd01bee9b7800c983a6a0d5f83574 /Source
parent6af66e8b200dfabd44aae9a0247c146313822db7 (diff)
downloadCMake-749fe2639429cd2d3944c01ba70515c2d9d6fbcc.zip
CMake-749fe2639429cd2d3944c01ba70515c2d9d6fbcc.tar.gz
CMake-749fe2639429cd2d3944c01ba70515c2d9d6fbcc.tar.bz2
ENH: fix problem with dependency scanning
Diffstat (limited to 'Source')
-rw-r--r--Source/cmLocalUnixMakefileGenerator3.cxx30
-rw-r--r--Source/cmake.cxx4
2 files changed, 24 insertions, 10 deletions
diff --git a/Source/cmLocalUnixMakefileGenerator3.cxx b/Source/cmLocalUnixMakefileGenerator3.cxx
index b012783..bf70240 100644
--- a/Source/cmLocalUnixMakefileGenerator3.cxx
+++ b/Source/cmLocalUnixMakefileGenerator3.cxx
@@ -214,7 +214,7 @@ void cmLocalUnixMakefileGenerator3::WriteDirectoryInformationFile()
i != includeDirs.end(); ++i)
{
infoFileStream
- << " \"" << this->Convert(i->c_str(),START_OUTPUT).c_str() << "\"\n";
+ << " \"" << this->Convert(i->c_str(),HOME_OUTPUT).c_str() << "\"\n";
}
infoFileStream
<< " )\n";
@@ -453,8 +453,13 @@ cmLocalUnixMakefileGenerator3
cmOStringStream depCmd;
// TODO: Account for source file properties and directory-level
// definitions when scanning for dependencies.
- depCmd << "$(CMAKE_COMMAND) -E cmake_depends \""
+ depCmd << "$(CMAKE_COMMAND) -E cmake_depends "
+ << " \""
<< m_GlobalGenerator->GetName() << "\" "
+ << this->Convert(m_Makefile->GetHomeOutputDirectory(),FULL,SHELL)
+ << " "
+ << this->Convert(m_Makefile->GetStartOutputDirectory(),FULL,SHELL)
+ << " "
<< lang << " "
<< relativeObj.c_str() << " "
<< this->Convert(source.GetFullPath().c_str(),HOME_OUTPUT,SHELL);
@@ -2601,17 +2606,17 @@ cmLocalUnixMakefileGenerator3
::ScanDependencies(std::vector<std::string> const& args)
{
// Format of arguments is:
- // $(CMAKE_COMMAND), cmake_depends, GeneratorName, <lang>, <obj>, <src>
+ // $(CMAKE_COMMAND), cmake_depends, home_output_dir, start_output_dir, GeneratorName, <lang>, <obj>, <src>
// The caller has ensured that all required arguments exist.
// The language for which we are scanning dependencies.
- std::string const& lang = args[3];
+ std::string const& lang = args[5];
// The file to which to write dependencies.
- const char* objFile = args[4].c_str();
+ const char* objFile = args[6].c_str();
// The source file at which to start the scan.
- const char* srcFile = args[5].c_str();
+ const char* srcFile = args[7].c_str();
// Read the directory information file.
cmake cm;
@@ -2620,13 +2625,17 @@ cmLocalUnixMakefileGenerator3
std::auto_ptr<cmLocalGenerator> lg(gg.CreateLocalGenerator());
lg->SetGlobalGenerator(&gg);
cmMakefile* mf = lg->GetMakefile();
+ mf->SetHomeOutputDirectory(args[3].c_str());
+ mf->SetStartOutputDirectory(args[4].c_str());
bool haveDirectoryInfo = false;
- if(mf->ReadListFile(0, "CMakeDirectoryInformation.cmake") &&
+ std::string dirInfoFile = args[4];
+ dirInfoFile += "/CMakeDirectoryInformation.cmake";
+ if(mf->ReadListFile(0, dirInfoFile.c_str()) &&
!cmSystemTools::GetErrorOccuredFlag())
{
haveDirectoryInfo = true;
}
-
+
// Test whether we need to force Unix paths.
if(haveDirectoryInfo)
{
@@ -2638,6 +2647,11 @@ cmLocalUnixMakefileGenerator3
}
}
}
+ else
+ {
+ cmSystemTools::Error("Directory Information file not found");
+ }
+
// Get the set of include directories.
std::vector<std::string> includes;
diff --git a/Source/cmake.cxx b/Source/cmake.cxx
index f022df7..f27f010 100644
--- a/Source/cmake.cxx
+++ b/Source/cmake.cxx
@@ -826,7 +826,7 @@ int cmake::CMakeCommand(std::vector<std::string>& args)
}
// Internal CMake dependency scanning support.
- else if (args[1] == "cmake_depends" && args.size() >= 6)
+ else if (args[1] == "cmake_depends" && args.size() >= 8)
{
cmake cm;
cmGlobalGenerator *ggd = cm.CreateGlobalGenerator(args[2].c_str());
@@ -835,7 +835,7 @@ int cmake::CMakeCommand(std::vector<std::string>& args)
{
std::auto_ptr<cmLocalGenerator> lgd(ggd->CreateLocalGenerator());
lgd->SetGlobalGenerator(ggd);
- return lgd->ScanDependencies(args)? 0 : 1;
+ return lgd->ScanDependencies(args)? 0 : 2;
}
return 1;
}