diff options
Diffstat (limited to 'Source/cmGlobalXCodeGenerator.cxx')
-rw-r--r-- | Source/cmGlobalXCodeGenerator.cxx | 96 |
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(); |