summaryrefslogtreecommitdiffstats
diff options
context:
space:
mode:
authorKen Martin <ken.martin@kitware.com>2005-08-08 19:23:45 (GMT)
committerKen Martin <ken.martin@kitware.com>2005-08-08 19:23:45 (GMT)
commit52f9353c45cecb237feb30b3dbde7d4c33e4a0c3 (patch)
treebc77957b0ce0a3ccf4ff7817f962a0a64f28c4a9
parentfd05925bdae87299d167261c5d4cc6e5eef0271e (diff)
downloadCMake-52f9353c45cecb237feb30b3dbde7d4c33e4a0c3.zip
CMake-52f9353c45cecb237feb30b3dbde7d4c33e4a0c3.tar.gz
CMake-52f9353c45cecb237feb30b3dbde7d4c33e4a0c3.tar.bz2
ENH: have the build.make file include flags.make and use the language flags
-rw-r--r--Source/cmLocalUnixMakefileGenerator3.cxx39
1 files changed, 13 insertions, 26 deletions
diff --git a/Source/cmLocalUnixMakefileGenerator3.cxx b/Source/cmLocalUnixMakefileGenerator3.cxx
index a6e5391..63c79d4 100644
--- a/Source/cmLocalUnixMakefileGenerator3.cxx
+++ b/Source/cmLocalUnixMakefileGenerator3.cxx
@@ -329,6 +329,14 @@ cmLocalUnixMakefileGenerator3
<< depPath
<< "\n\n";
+ // Include the flags for the target.
+ flagFileName = this->Convert(flagFileName.c_str(), FULL, MAKEFILE);
+ ruleFileStream
+ << "# Include the compile flags for this target's objects.\n"
+ << m_IncludeDirective << " "
+ << flagFileName
+ << "\n\n";
+
// make sure the depend file exists
depPath = dir;
depPath += "/depend.make";
@@ -515,39 +523,18 @@ cmLocalUnixMakefileGenerator3
if (source.GetProperty("COMPILE_FLAGS"))
{
this->AppendFlags(flags, source.GetProperty("COMPILE_FLAGS"));
- flagFileStream << "# Custom flags.\n"
+ flagFileStream << "# Custom flags: "
<< relativeObj << "_FLAGS = "
<< source.GetProperty("COMPILE_FLAGS")
<< "\n"
<< "\n";
}
- // Add the export symbol definition for shared library objects.
- bool shared = ((target.GetType() == cmTarget::SHARED_LIBRARY) ||
- (target.GetType() == cmTarget::MODULE_LIBRARY));
- if(shared)
- {
- flags += " -D";
- if(const char* custom_export_name = target.GetProperty("DEFINE_SYMBOL"))
- {
- flags += custom_export_name;
- }
- else
- {
- std::string in = target.GetName();
- in += "_EXPORTS";
- flags += cmSystemTools::MakeCindentifier(in.c_str());
- }
- }
-
// Add language-specific flags.
- this->AddLanguageFlags(flags, lang);
-
- // Add shared-library flags if needed.
- this->AddSharedFlags(flags, lang, shared);
-
- // Add include directory flags.
- this->AppendFlags(flags, this->GetIncludeFlags(lang));
+ std::string langFlags = "$(";
+ langFlags += lang;
+ langFlags += "_FLAGS)";
+ this->AppendFlags(flags, langFlags.c_str());
// Get the output paths for source and object files.
std::string sourceFile = source.GetFullPath();