summaryrefslogtreecommitdiffstats
path: root/Source/cmGlobalXCodeGenerator.cxx
diff options
context:
space:
mode:
Diffstat (limited to 'Source/cmGlobalXCodeGenerator.cxx')
-rw-r--r--Source/cmGlobalXCodeGenerator.cxx96
1 files changed, 78 insertions, 18 deletions
diff --git a/Source/cmGlobalXCodeGenerator.cxx b/Source/cmGlobalXCodeGenerator.cxx
index d587f89..3408209 100644
--- a/Source/cmGlobalXCodeGenerator.cxx
+++ b/Source/cmGlobalXCodeGenerator.cxx
@@ -25,17 +25,32 @@
//TODO
// per file flags
+// 115281011528101152810000 = {
+// fileEncoding = 4;
+// isa = PBXFileReference;
+// lastKnownFileType = sourcecode.cpp.cpp;
+// path = /Users/kitware/Bill/CMake/Source/cmakemain.cxx;
+// refType = 0;
+// sourceTree = "<absolute>";
+// };
+// 115285011528501152850000 = {
+// fileRef = 115281011528101152810000;
+// isa = PBXBuildFile;
+// settings = {
+// COMPILER_FLAGS = "-Dcmakemakeindefflag";
+// };
+// };
+
// custom commands and clean up custom targets
-// do I need an ALL_BUILD
-// link libraries stuff
+// do I need an ALL_BUILD yes
// exe/lib output paths
-// PBXBuildFile can not be reused, or error occurs
//----------------------------------------------------------------------------
cmGlobalXCodeGenerator::cmGlobalXCodeGenerator()
{
m_FindMakeProgramFile = "CMakeFindXCode.cmake";
m_RootObject = 0;
+ m_MainGroupChildren = 0;
}
//----------------------------------------------------------------------------
@@ -171,11 +186,10 @@ cmXCodeObject* cmGlobalXCodeGenerator::CreateObjectReference(cmXCodeObject* ref)
cmXCodeObject*
cmGlobalXCodeGenerator::CreateXCodeSourceFile(cmLocalGenerator* lg,
- cmSourceFile* sf,
- cmXCodeObject* mainGroupChildren)
+ cmSourceFile* sf)
{
cmXCodeObject* fileRef = this->CreateObject(cmXCodeObject::PBXFileReference);
- mainGroupChildren->AddObject(fileRef);
+ m_MainGroupChildren->AddObject(fileRef);
cmXCodeObject* buildFile = this->CreateObject(cmXCodeObject::PBXBuildFile);
buildFile->AddAttribute("fileRef", this->CreateObjectReference(fileRef));
cmXCodeObject* settings = this->CreateObject(cmXCodeObject::ATTRIBUTE_GROUP);
@@ -214,8 +228,7 @@ cmGlobalXCodeGenerator::CreateXCodeSourceFile(cmLocalGenerator* lg,
void
cmGlobalXCodeGenerator::CreateXCodeTargets(cmLocalGenerator* gen,
std::vector<cmXCodeObject*>&
- targets,
- cmXCodeObject* mainGroupChildren)
+ targets)
{
m_CurrentLocalGenerator = gen;
m_CurrentMakefile = gen->GetMakefile();
@@ -245,8 +258,7 @@ cmGlobalXCodeGenerator::CreateXCodeTargets(cmLocalGenerator* gen,
for(std::vector<cmSourceFile*>::iterator i = classes.begin();
i != classes.end(); ++i)
{
- buildFiles->AddObject(this->CreateXCodeSourceFile(gen, *i,
- mainGroupChildren));
+ buildFiles->AddObject(this->CreateXCodeSourceFile(gen, *i));
}
// create header build phase
cmXCodeObject* headerBuildPhase =
@@ -448,7 +460,6 @@ cmGlobalXCodeGenerator::CreateXCodeTarget(cmTarget& cmtarget,
cmXCodeObject* fileRef = this->CreateObject(cmXCodeObject::PBXFileReference);
fileRef->AddAttribute("explicitFileType",
this->CreateString(fileTypeString.c_str()));
-// fileRef->AddAttribute("includedInIndex", this->CreateString("0"));
fileRef->AddAttribute("path", this->CreateString(productName.c_str()));
fileRef->AddAttribute("refType", this->CreateString("3"));
fileRef->AddAttribute("sourceTree",
@@ -535,9 +546,54 @@ void cmGlobalXCodeGenerator::AddLinkTarget(cmXCodeObject* target ,
files->AddObject(buildfile);
}
-void cmGlobalXCodeGenerator::AddLinkFlag(cmXCodeObject* ,
- const char*)
+void cmGlobalXCodeGenerator::AddLinkFlag(cmXCodeObject* target,
+ const char* flag)
{
+ if(cmSystemTools::FileIsFullPath(flag))
+ {
+ std::string libPath = flag;
+ cmXCodeObject* fileRef =
+ this->CreateObject(cmXCodeObject::PBXFileReference);
+ if(libPath[libPath.size()-1] == 'a')
+ {
+ fileRef->AddAttribute("lastKnownFileType",
+ this->CreateString("archive.ar"));
+ }
+ else
+ {
+ fileRef->AddAttribute("lastKnownFileType",
+ this->CreateString("compiled.mach-o.dylib"));
+ }
+ fileRef->AddAttribute("name",
+ this->CreateString(
+ cmSystemTools::GetFilenameName(libPath).c_str()));
+
+ fileRef->AddAttribute("path", this->CreateString(libPath.c_str()));
+ fileRef->AddAttribute("refType", this->CreateString("0"));
+ fileRef->AddAttribute("sourceTree", this->CreateString("<absolute>"));
+ cmXCodeObject* buildfile = this->CreateObject(cmXCodeObject::PBXBuildFile);
+ buildfile->AddAttribute("fileRef", this->CreateObjectReference(fileRef));
+ cmXCodeObject* settings =
+ this->CreateObject(cmXCodeObject::ATTRIBUTE_GROUP);
+ buildfile->AddAttribute("settings", settings);
+ // get the framework build phase from the target
+ cmXCodeObject* buildPhases = target->GetObject("buildPhases");
+ cmXCodeObject* frameworkBuildPhase =
+ buildPhases->GetObject(cmXCodeObject::PBXFrameworksBuildPhase);
+ cmXCodeObject* files = frameworkBuildPhase->GetObject("files");
+ files->AddObject(buildfile);
+ m_MainGroupChildren->AddObject(fileRef);
+ }
+ else
+ {
+ cmXCodeObject* settings = target->GetObject("buildSettings");
+ cmXCodeObject* ldflags = settings->GetObject("OTHER_LDFLAGS");
+ std::string link = ldflags->GetString();
+ cmSystemTools::ReplaceString(link, "\"", "");
+ link += " -l";
+ link += flag;
+ ldflags->SetString(link.c_str());
+ }
}
void cmGlobalXCodeGenerator::AddDependAndLinkInformation(cmXCodeObject* target)
@@ -566,7 +622,10 @@ void cmGlobalXCodeGenerator::AddDependAndLinkInformation(cmXCodeObject* target)
}
else
{
- this->AddLinkFlag(target, j->first.c_str());
+ if(cmtarget->GetType() != cmTarget::STATIC_LIBRARY)
+ {
+ this->AddLinkFlag(target, j->first.c_str());
+ }
}
}
std::set<cmStdString>::const_iterator i, end;
@@ -606,6 +665,7 @@ void cmGlobalXCodeGenerator::CreateXCodeObjects(cmLocalGenerator* ,
{
this->ClearXCodeObjects();
m_RootObject = 0;
+ m_MainGroupChildren = 0;
cmXCodeObject* group = this->CreateObject(cmXCodeObject::ATTRIBUTE_GROUP);
group->AddAttribute("COPY_PHASE_STRIP", this->CreateString("NO"));
cmXCodeObject* developBuildStyle = this->CreateObject(cmXCodeObject::PBXBuildStyle);
@@ -623,9 +683,9 @@ void cmGlobalXCodeGenerator::CreateXCodeObjects(cmLocalGenerator* ,
listObjs->AddObject(deployBuildStyle);
cmXCodeObject* mainGroup = this->CreateObject(cmXCodeObject::PBXGroup);
- cmXCodeObject* mainGroupChildren =
+ m_MainGroupChildren =
this->CreateObject(cmXCodeObject::OBJECT_LIST);
- mainGroup->AddAttribute("children", mainGroupChildren);
+ mainGroup->AddAttribute("children", m_MainGroupChildren);
mainGroup->AddAttribute("refType", this->CreateString("4"));
mainGroup->AddAttribute("sourceTree", this->CreateString("<group>"));
@@ -636,7 +696,7 @@ void cmGlobalXCodeGenerator::CreateXCodeObjects(cmLocalGenerator* ,
cmXCodeObject* productGroupChildren =
this->CreateObject(cmXCodeObject::OBJECT_LIST);
productGroup->AddAttribute("children", productGroupChildren);
- mainGroupChildren->AddObject(productGroup);
+ m_MainGroupChildren->AddObject(productGroup);
m_RootObject = this->CreateObject(cmXCodeObject::PBXProject);
@@ -651,7 +711,7 @@ void cmGlobalXCodeGenerator::CreateXCodeObjects(cmLocalGenerator* ,
for(std::vector<cmLocalGenerator*>::iterator i = generators.begin();
i != generators.end(); ++i)
{
- this->CreateXCodeTargets(*i, targets, mainGroupChildren);
+ this->CreateXCodeTargets(*i, targets);
}
cmXCodeObject* allTargets = this->CreateObject(cmXCodeObject::OBJECT_LIST);
for(std::vector<cmXCodeObject*>::iterator i = targets.begin();