summaryrefslogtreecommitdiffstats
diff options
context:
space:
mode:
-rw-r--r--Source/cmGlobalGenerator.cxx10
-rw-r--r--Source/cmGlobalXCodeGenerator.cxx81
-rw-r--r--Source/cmGlobalXCodeGenerator.h1
-rw-r--r--Source/cmMakefile.cxx14
-rw-r--r--Source/cmMakefile.h1
5 files changed, 97 insertions, 10 deletions
diff --git a/Source/cmGlobalGenerator.cxx b/Source/cmGlobalGenerator.cxx
index 17cad1a..2f740d1 100644
--- a/Source/cmGlobalGenerator.cxx
+++ b/Source/cmGlobalGenerator.cxx
@@ -799,17 +799,15 @@ void cmGlobalGenerator::FillProjectMap()
}
+
cmTarget* cmGlobalGenerator::FindTarget(const char* name)
{
for(unsigned int i = 0; i < m_LocalGenerators.size(); ++i)
{
- cmTargets& tgts = m_LocalGenerators[i]->GetMakefile()->GetTargets();
- for(cmTargets::iterator l = tgts.begin(); l != tgts.end(); l++)
+ cmTarget* ret = m_LocalGenerators[i]->GetMakefile()->FindTarget(name);
+ if(ret)
{
- if(l->first == name)
- {
- return &l->second;
- }
+ return ret;
}
}
return 0;
diff --git a/Source/cmGlobalXCodeGenerator.cxx b/Source/cmGlobalXCodeGenerator.cxx
index b8086a5..714f441 100644
--- a/Source/cmGlobalXCodeGenerator.cxx
+++ b/Source/cmGlobalXCodeGenerator.cxx
@@ -187,9 +187,33 @@ cmLocalGenerator *cmGlobalXCodeGenerator::CreateLocalGenerator()
void cmGlobalXCodeGenerator::Generate()
{
this->cmGlobalGenerator::Generate();
+ std::vector<std::string> srcs;
std::map<cmStdString, std::vector<cmLocalGenerator*> >::iterator it;
for(it = m_ProjectMap.begin(); it!= m_ProjectMap.end(); ++it)
{
+ // add a ALL_BUILD target to the first makefile of each project
+ it->second[0]->GetMakefile()->
+ AddUtilityCommand("ALL_BUILD", "echo",
+ "\"Build all projects\"",false,srcs);
+ cmTarget* allbuild =
+ it->second[0]->GetMakefile()->FindTarget("ALL_BUILD");
+ // now make the allbuild depend on all the non-utility targets
+ // in the project
+ for(std::vector<cmLocalGenerator*>::iterator i = it->second.begin();
+ i != it->second.end(); ++i)
+ {
+ cmLocalGenerator* lg = *i;
+ cmTargets& tgts = lg->GetMakefile()->GetTargets();
+ for(cmTargets::iterator l = tgts.begin(); l != tgts.end(); l++)
+ {
+ cmTarget& target = l->second;
+ if(target.GetType() < cmTarget::UTILITY)
+ {
+ allbuild->AddUtility(target.GetName());
+ }
+ }
+ }
+ // now create the project
this->OutputXCodeProject(it->second[0], it->second);
}
}
@@ -294,6 +318,15 @@ cmGlobalXCodeGenerator::CreateXCodeTargets(cmLocalGenerator* gen,
for(cmTargets::iterator l = tgts.begin(); l != tgts.end(); l++)
{
cmTarget& cmtarget = l->second;
+ // make sure ALL_BUILD is only done once
+ if(l->first == "ALL_BUILD")
+ {
+ if(m_DoneAllBuild)
+ {
+ continue;
+ }
+ m_DoneAllBuild = true;
+ }
if(cmtarget.GetType() == cmTarget::UTILITY ||
cmtarget.GetType() == cmTarget::INSTALL_FILES ||
cmtarget.GetType() == cmTarget::INSTALL_PROGRAMS)
@@ -646,8 +679,13 @@ void cmGlobalXCodeGenerator::CreateBuildSettings(cmTarget& target,
this->CreateString
(m_LibraryOutputPath.c_str()));
}
+
+ buildSettings->AddAttribute("EXECUTABLE_PREFIX",
+ this->CreateString("lib"));
+ buildSettings->AddAttribute("EXECUTABLE_EXTENSION",
+ this->CreateString("so"));
buildSettings->AddAttribute("LIBRARY_STYLE",
- this->CreateString("DYNAMIC"));
+ this->CreateString("BUNDLE"));
productName += ".so";
std::string t = "lib";
t += productName;
@@ -745,7 +783,7 @@ void cmGlobalXCodeGenerator::CreateBuildSettings(cmTarget& target,
buildSettings->AddAttribute("GCC_OPTIMIZATION_LEVEL",
this->CreateString("0"));
buildSettings->AddAttribute("INSTALL_PATH",
- this->CreateString("/usr/local/bin"));
+ this->CreateString(""));
buildSettings->AddAttribute("OPTIMIZATION_CFLAGS",
this->CreateString(""));
buildSettings->AddAttribute("OTHER_CFLAGS",
@@ -760,8 +798,14 @@ void cmGlobalXCodeGenerator::CreateBuildSettings(cmTarget& target,
this->CreateString(
"-Wmost -Wno-four-char-constants"
" -Wno-unknown-pragmas"));
+ std::string pname;
+ if(target.GetType() == cmTarget::SHARED_LIBRARY)
+ {
+ pname = "lib";
+ }
+ pname += target.GetName();
buildSettings->AddAttribute("PRODUCT_NAME",
- this->CreateString(target.GetName()));
+ this->CreateString(pname.c_str()));
}
cmXCodeObject*
@@ -932,6 +976,33 @@ void cmGlobalXCodeGenerator::AddLinkLibrary(cmXCodeObject* target,
std::string libPath = library;
cmXCodeObject* fileRef =
this->CreateObject(cmXCodeObject::PBXFileReference);
+ // add the library path to the search path for the target
+ cmXCodeObject* bset = target->GetObject("buildSettings");
+ if(bset)
+ {
+ std::string dir;
+ std::string file;
+ cmSystemTools::SplitProgramPath(library, dir, file);
+ cmXCodeObject* spath = bset->GetObject("LIBRARY_SEARCH_PATHS");
+ if(spath)
+ {
+ std::string libs = spath->GetString();
+ // remove double quotes
+ libs = libs.substr(1, libs.size()-2);
+ libs += " ";
+ libs +=
+ m_CurrentLocalGenerator->ConvertToOutputForExisting(dir.c_str());
+ spath->SetString(libs.c_str());
+ }
+ else
+ {
+ std::string libs =
+ m_CurrentLocalGenerator->ConvertToOutputForExisting(dir.c_str());
+ bset->AddAttribute("LIBRARY_SEARCH_PATHS",
+ this->CreateString(libs.c_str()));
+ }
+ }
+
if(libPath[libPath.size()-1] == 'a')
{
fileRef->AddAttribute("lastKnownFileType",
@@ -973,9 +1044,10 @@ void cmGlobalXCodeGenerator::AddLinkLibrary(cmXCodeObject* target,
cmsys::RegularExpression reg("^([ \t]*\\-[lWRB])|([ \t]*\\-framework)|(\\${)|([ \t]*\\-pthread)|([ \t]*`)");
// if the library is not already in the form required by the compiler
// add a -l infront of the name
+ link += " ";
if(!reg.find(library))
{
- link += " -l";
+ link += "-l";
}
link += library;
ldflags->SetString(link.c_str());
@@ -1110,6 +1182,7 @@ void cmGlobalXCodeGenerator::CreateXCodeObjects(cmLocalGenerator* ,
m_RootObject->AddAttribute("hasScannedForEncodings",
this->CreateString("0"));
std::vector<cmXCodeObject*> targets;
+ m_DoneAllBuild = false;
for(std::vector<cmLocalGenerator*>::iterator i = generators.begin();
i != generators.end(); ++i)
{
diff --git a/Source/cmGlobalXCodeGenerator.h b/Source/cmGlobalXCodeGenerator.h
index ccf627a..a8f73d0 100644
--- a/Source/cmGlobalXCodeGenerator.h
+++ b/Source/cmGlobalXCodeGenerator.h
@@ -124,6 +124,7 @@ private:
std::string m_LibraryOutputPath;
std::string m_ExecutableOutputPath;
cmLocalGenerator* m_CurrentLocalGenerator;
+ bool m_DoneAllBuild;
};
#endif
diff --git a/Source/cmMakefile.cxx b/Source/cmMakefile.cxx
index c6c8541..cd3b4de 100644
--- a/Source/cmMakefile.cxx
+++ b/Source/cmMakefile.cxx
@@ -2538,3 +2538,17 @@ bool cmMakefile::GetPropertyAsBool(const char* prop) const
}
return false;
}
+
+
+cmTarget* cmMakefile::FindTarget(const char* name)
+{
+ cmTargets& tgts = this->GetTargets();
+ for(cmTargets::iterator l = tgts.begin(); l != tgts.end(); l++)
+ {
+ if(l->first == name)
+ {
+ return &l->second;
+ }
+ }
+ return 0;
+}
diff --git a/Source/cmMakefile.h b/Source/cmMakefile.h
index 6855819..4f99b5c 100644
--- a/Source/cmMakefile.h
+++ b/Source/cmMakefile.h
@@ -433,6 +433,7 @@ public:
cmTargets &GetTargets() { return m_Targets; }
const cmTargets &GetTargets() const { return m_Targets; }
+ cmTarget* FindTarget(const char* name);
/**
* Get a list of the build subdirectories.
*/