From 52f9353c45cecb237feb30b3dbde7d4c33e4a0c3 Mon Sep 17 00:00:00 2001 From: Ken Martin Date: Mon, 8 Aug 2005 15:23:45 -0400 Subject: ENH: have the build.make file include flags.make and use the language flags --- Source/cmLocalUnixMakefileGenerator3.cxx | 39 +++++++++++--------------------- 1 file 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(); -- cgit v0.12