diff options
author | Brad King <brad.king@kitware.com> | 2009-07-02 18:14:03 (GMT) |
---|---|---|
committer | Brad King <brad.king@kitware.com> | 2009-07-02 18:14:03 (GMT) |
commit | 2247153110406ce2a6a9baea39394167fa1f75c7 (patch) | |
tree | 330e39229d95dd6eb730237a57b6090459aa79b4 | |
parent | 6bd9d5ab8ac147bb4fd120317f478fe601e2266b (diff) | |
download | CMake-2247153110406ce2a6a9baea39394167fa1f75c7.zip CMake-2247153110406ce2a6a9baea39394167fa1f75c7.tar.gz CMake-2247153110406ce2a6a9baea39394167fa1f75c7.tar.bz2 |
BUG: Do not generate "global" Xcode config
Xcode 2.0 and below supported only one configuration, but 2.1 and above
support multiple configurations. In projects for the latter version we
have been generating a "global" set of buildSettings for each target in
addition to the per-configuration settings. These global settings are
not used by Xcode 2.1 and above, so we should not generate them.
-rw-r--r-- | Source/cmGlobalXCodeGenerator.cxx | 34 | ||||
-rw-r--r-- | Source/cmGlobalXCodeGenerator.h | 3 |
2 files changed, 19 insertions, 18 deletions
diff --git a/Source/cmGlobalXCodeGenerator.cxx b/Source/cmGlobalXCodeGenerator.cxx index 65bd2cf..01c587a 100644 --- a/Source/cmGlobalXCodeGenerator.cxx +++ b/Source/cmGlobalXCodeGenerator.cxx @@ -1839,19 +1839,19 @@ cmGlobalXCodeGenerator::CreateUtilityTarget(cmTarget& cmtarget) this->CreateCustomCommands(buildPhases, 0, 0, 0, emptyContentVector, 0, cmtarget); target->AddAttribute("buildPhases", buildPhases); - cmXCodeObject* buildSettings = - this->CreateObject(cmXCodeObject::ATTRIBUTE_GROUP); - const char* globalConfig = 0; if(this->XcodeVersion > 20) { this->AddConfigurations(target, cmtarget); } else { - globalConfig = this->CurrentMakefile->GetDefinition("CMAKE_BUILD_TYPE"); + const char* theConfig = + this->CurrentMakefile->GetDefinition("CMAKE_BUILD_TYPE"); + cmXCodeObject* buildSettings = + this->CreateObject(cmXCodeObject::ATTRIBUTE_GROUP); + this->CreateBuildSettings(cmtarget, buildSettings, theConfig); + target->AddAttribute("buildSettings", buildSettings); } - this->CreateBuildSettings(cmtarget, buildSettings, globalConfig); - target->AddAttribute("buildSettings", buildSettings); cmXCodeObject* dependencies = this->CreateObject(cmXCodeObject::OBJECT_LIST); target->AddAttribute("dependencies", dependencies); @@ -1877,8 +1877,8 @@ cmGlobalXCodeGenerator::CreateUtilityTarget(cmTarget& cmtarget) } //---------------------------------------------------------------------------- -void cmGlobalXCodeGenerator::AddConfigurations(cmXCodeObject* target, - cmTarget& cmtarget) +std::string cmGlobalXCodeGenerator::AddConfigurations(cmXCodeObject* target, + cmTarget& cmtarget) { std::string configTypes = this->CurrentMakefile->GetRequiredDefinition("CMAKE_CONFIGURATION_TYPES"); @@ -1918,7 +1918,9 @@ void cmGlobalXCodeGenerator::AddConfigurations(cmXCodeObject* target, this->CreateString(configVector[0].c_str())); configlist->AddAttribute("defaultConfigurationIsVisible", this->CreateString("0")); + return configVector[0]; } + return ""; } //---------------------------------------------------------------------------- @@ -1974,19 +1976,19 @@ cmGlobalXCodeGenerator::CreateXCodeTarget(cmTarget& cmtarget, target->AddAttribute("buildPhases", buildPhases); cmXCodeObject* buildRules = this->CreateObject(cmXCodeObject::OBJECT_LIST); target->AddAttribute("buildRules", buildRules); - cmXCodeObject* buildSettings = - this->CreateObject(cmXCodeObject::ATTRIBUTE_GROUP); - const char* globalConfig = 0; + std::string defConfig; if(this->XcodeVersion > 20) { - this->AddConfigurations(target, cmtarget); + defConfig = this->AddConfigurations(target, cmtarget); } else { - globalConfig = this->CurrentMakefile->GetDefinition("CMAKE_BUILD_TYPE"); + cmXCodeObject* buildSettings = + this->CreateObject(cmXCodeObject::ATTRIBUTE_GROUP); + defConfig = this->CurrentMakefile->GetSafeDefinition("CMAKE_BUILD_TYPE"); + this->CreateBuildSettings(cmtarget, buildSettings, defConfig.c_str()); + target->AddAttribute("buildSettings", buildSettings); } - this->CreateBuildSettings(cmtarget, buildSettings, globalConfig); - target->AddAttribute("buildSettings", buildSettings); cmXCodeObject* dependencies = this->CreateObject(cmXCodeObject::OBJECT_LIST); target->AddAttribute("dependencies", dependencies); @@ -1999,7 +2001,7 @@ cmGlobalXCodeGenerator::CreateXCodeTarget(cmTarget& cmtarget, { fileRef->AddAttribute("explicitFileType", this->CreateString(fileType)); } - std::string fullName = cmtarget.GetFullName(globalConfig); + std::string fullName = cmtarget.GetFullName(defConfig.c_str()); fileRef->AddAttribute("path", this->CreateString(fullName.c_str())); fileRef->AddAttribute("refType", this->CreateString("0")); fileRef->AddAttribute("sourceTree", diff --git a/Source/cmGlobalXCodeGenerator.h b/Source/cmGlobalXCodeGenerator.h index e3fc270..ba1529d 100644 --- a/Source/cmGlobalXCodeGenerator.h +++ b/Source/cmGlobalXCodeGenerator.h @@ -130,8 +130,7 @@ private: cmXCodeObject* buildPhases); const char* GetTargetFileType(cmTarget& cmtarget); const char* GetTargetProductType(cmTarget& cmtarget); - void AddConfigurations(cmXCodeObject* target, - cmTarget& cmtarget); + std::string AddConfigurations(cmXCodeObject* target, cmTarget& cmtarget); void AppendOrAddBuildSetting(cmXCodeObject* settings, const char* attr, const char* value); void AppendBuildSettingAttribute(cmXCodeObject* target, const char* attr, |