summaryrefslogtreecommitdiffstats
diff options
context:
space:
mode:
authorSebastien Barre <sebastien.barre@kitware.com>2002-01-17 20:46:04 (GMT)
committerSebastien Barre <sebastien.barre@kitware.com>2002-01-17 20:46:04 (GMT)
commit201764e166b26acfceef983c026b8aae452ed466 (patch)
treeadbca47b7c476497e4322f79659d313548dd5614
parente77515c2da3fcbc52809de9f148b6807459e1f28 (diff)
downloadCMake-201764e166b26acfceef983c026b8aae452ed466.zip
CMake-201764e166b26acfceef983c026b8aae452ed466.tar.gz
CMake-201764e166b26acfceef983c026b8aae452ed466.tar.bz2
Fix so that ADD_DEPENDENCIES work (the Utilities dependencies were not output)
-rw-r--r--Source/cmUnixMakefileGenerator.cxx67
-rw-r--r--Source/cmUnixMakefileGenerator.h1
2 files changed, 63 insertions, 5 deletions
diff --git a/Source/cmUnixMakefileGenerator.cxx b/Source/cmUnixMakefileGenerator.cxx
index cdaaff9..ed947b6 100644
--- a/Source/cmUnixMakefileGenerator.cxx
+++ b/Source/cmUnixMakefileGenerator.cxx
@@ -829,6 +829,22 @@ void cmUnixMakefileGenerator::OutputDependLibs(std::ostream& fout)
this->OutputLibDepend(fout, lib->first.c_str());
}
}
+
+ // Now, look at all utilities specific to this target.
+ const std::set<std::string>& tutils = l->second.GetUtilities();
+ for(std::set<std::string>::const_iterator util = tutils.begin();
+ util != tutils.end(); ++util)
+ {
+ // Record that this utility was used.
+ used.insert(*util);
+
+ // Don't emit the same utility twice for this target.
+ if(emitted.insert(*util).second)
+ {
+ // Output this dependency.
+ this->OutputExeDepend(fout, util->c_str());
+ }
+ }
fout << "\n";
}
@@ -926,7 +942,6 @@ void cmUnixMakefileGenerator::OutputLibDepend(std::ostream& fout,
{
// if the library is not in the current directory, then get the full
// path to it
- libpath = cacheValue;
if(m_LibraryOutputPath.size())
{
libpath = m_LibraryOutputPath;
@@ -934,6 +949,7 @@ void cmUnixMakefileGenerator::OutputLibDepend(std::ostream& fout,
}
else
{
+ libpath = cacheValue;
libpath += "/";
libpath += m_LibraryPrefix;
}
@@ -955,10 +971,10 @@ void cmUnixMakefileGenerator::OutputLibDepend(std::ostream& fout,
libpath += m_Makefile->GetDefinition("CMAKE_SHLIB_SUFFIX");
}
else if (libType && std::string(libType) == "MODULE")
- {
- libpath += m_Makefile->GetDefinition("CMAKE_MODULE_SUFFIX");
- }
- else
+ {
+ libpath += m_Makefile->GetDefinition("CMAKE_MODULE_SUFFIX");
+ }
+ else if (libType && std::string(libType) == "STATIC")
{
libpath += m_StaticLibraryExtension;
}
@@ -968,6 +984,47 @@ void cmUnixMakefileGenerator::OutputLibDepend(std::ostream& fout,
}
+void cmUnixMakefileGenerator::OutputExeDepend(std::ostream& fout,
+ const char* name)
+{
+ const char* cacheValue = m_Makefile->GetDefinition(name);
+ if(cacheValue )
+ {
+ // if there is a cache value, then this is a executable/utility that cmake
+ // knows how to build, so we can depend on it
+ std::string exepath;
+ if (!this->SamePath(m_Makefile->GetCurrentOutputDirectory(), cacheValue))
+ {
+ // if the exe/utility is not in the current directory, then get the full
+ // path to it
+ if(m_ExecutableOutputPath.size())
+ {
+ exepath = m_ExecutableOutputPath;
+ }
+ else
+ {
+ exepath = cacheValue;
+ exepath += "/";
+ }
+ }
+ else
+ {
+ // library is in current Makefile
+ exepath = m_ExecutableOutputPath;
+ }
+ // add the library name
+ exepath += name;
+ // add the correct extension
+ if (m_Makefile->GetDefinition("CMAKE_EXECUTABLE_SUFFIX"))
+ {
+ exepath += m_Makefile->GetDefinition("CMAKE_EXECUTABLE_SUFFIX");
+ }
+ fout << this->ConvertToNativePath(cmSystemTools::EscapeSpaces(exepath.c_str()).c_str())
+ << " ";
+ }
+}
+
+
// fix up names of directories so they can be used
// as targets in makefiles.
diff --git a/Source/cmUnixMakefileGenerator.h b/Source/cmUnixMakefileGenerator.h
index f30c535..0e257af 100644
--- a/Source/cmUnixMakefileGenerator.h
+++ b/Source/cmUnixMakefileGenerator.h
@@ -127,6 +127,7 @@ protected:
virtual void OutputSubDirectoryRules(std::ostream&);
virtual void OutputDependLibs(std::ostream&);
virtual void OutputLibDepend(std::ostream&, const char*);
+ virtual void OutputExeDepend(std::ostream&, const char*);
virtual void OutputCustomRules(std::ostream&);
virtual void OutputMakeVariables(std::ostream&);
virtual void OutputMakeRules(std::ostream&);