summaryrefslogtreecommitdiffstats
path: root/Source/cmUnixMakefileGenerator.cxx
diff options
context:
space:
mode:
authorBill Hoffman <bill.hoffman@kitware.com>2001-12-21 20:39:43 (GMT)
committerBill Hoffman <bill.hoffman@kitware.com>2001-12-21 20:39:43 (GMT)
commit2c7bb2bf343f7c2614706c012ba4f751231802c3 (patch)
treed3af198e66b956f52725af9412232557169641f1 /Source/cmUnixMakefileGenerator.cxx
parent65339be84a3e271ee0c2c4340e03f448d62a97f0 (diff)
downloadCMake-2c7bb2bf343f7c2614706c012ba4f751231802c3.zip
CMake-2c7bb2bf343f7c2614706c012ba4f751231802c3.tar.gz
CMake-2c7bb2bf343f7c2614706c012ba4f751231802c3.tar.bz2
BUG: fix so you can remove a directory in the source tree, and clean up echo of commands
Diffstat (limited to 'Source/cmUnixMakefileGenerator.cxx')
-rw-r--r--Source/cmUnixMakefileGenerator.cxx36
1 files changed, 30 insertions, 6 deletions
diff --git a/Source/cmUnixMakefileGenerator.cxx b/Source/cmUnixMakefileGenerator.cxx
index 11e1ec6..4e77293 100644
--- a/Source/cmUnixMakefileGenerator.cxx
+++ b/Source/cmUnixMakefileGenerator.cxx
@@ -1511,15 +1511,27 @@ void cmUnixMakefileGenerator::OutputMakeRules(std::ostream& fout)
this->BuildInSubDirectory(fout,
m_Makefile->GetHomeOutputDirectory(),
"depend", 0);
+ const char* depend_subdirs = 0;
+ if(!m_Makefile->GetSubDirectories().empty())
+ {
+ this->OutputMakeRule(fout,
+ "Rule to force build of cmake.depend in subdirectories",
+ "depend_subdirs",
+ "$(SUBDIR_DEPEND)",
+ 0
+ );
+ depend_subdirs = "$(MAKE) -$(MAKEFLAGS) $(MAKESILENT) depend_subdirs";
+ }
this->OutputMakeRule(fout,
"Rule to force the build of cmake.depends",
"depend",
- "$(SUBDIR_DEPEND)",
+ 0,
"$(CMAKE_COMMAND) "
"-S$(CMAKE_CURRENT_SOURCE) -O$(CMAKE_CURRENT_BINARY) "
"-H$(CMAKE_SOURCE_DIR) -B$(CMAKE_BINARY_DIR)",
"-$(RM) cmake.depends_mark",
- "echo mark > cmake.depends_mark"
+ "echo mark > cmake.depends_mark",
+ depend_subdirs
);
this->OutputMakeRule(fout,
"Rebuild CMakeCache.txt file",
@@ -1739,28 +1751,40 @@ void cmUnixMakefileGenerator::OutputMakeRule(std::ostream& fout,
{
replace = command;
m_Makefile->ExpandVariablesInString(replace);
- fout << "\t" << "echo " << replace.c_str() << "\n";
+ if(replace[0] != '-' || replace.find("echo") != 0)
+ {
+ fout << "\t" << "echo " << replace.c_str() << "\n";
+ }
fout << "\t" << replace.c_str() << "\n";
}
if(command2)
{
replace = command2;
m_Makefile->ExpandVariablesInString(replace);
- fout << "\t" << "echo " << replace.c_str() << "\n";
+ if(replace[0] != '-' && replace.find("echo") != 0)
+ {
+ fout << "\t" << "echo " << replace.c_str() << "\n";
+ }
fout << "\t" << replace.c_str() << "\n";
}
if(command3)
{
replace = command3;
m_Makefile->ExpandVariablesInString(replace);
- fout << "\t" << "echo " << replace.c_str() << "\n";
+ if(replace[0] != '-' && replace.find("echo") != 0)
+ {
+ fout << "\t" << "echo " << replace.c_str() << "\n";
+ }
fout << "\t" << replace.c_str() << "\n";
}
if(command4)
{
replace = command4;
m_Makefile->ExpandVariablesInString(replace);
- fout << "\t" << "echo " << replace.c_str() << "\n";
+ if(replace[0] != '-' && replace.find("echo") != 0)
+ {
+ fout << "\t" << "echo " << replace.c_str() << "\n";
+ }
fout << "\t" << replace.c_str() << "\n";
}
fout << "\n";