summaryrefslogtreecommitdiffstats
diff options
context:
space:
mode:
-rw-r--r--Source/cmGlobalXCodeGenerator.cxx69
-rw-r--r--Source/cmGlobalXCodeGenerator.h3
2 files changed, 70 insertions, 2 deletions
diff --git a/Source/cmGlobalXCodeGenerator.cxx b/Source/cmGlobalXCodeGenerator.cxx
index a796bae..e6e431a 100644
--- a/Source/cmGlobalXCodeGenerator.cxx
+++ b/Source/cmGlobalXCodeGenerator.cxx
@@ -729,6 +729,51 @@ cmGlobalXCodeGenerator::CreateXCodeTargets(cmLocalGenerator* gen,
buildFiles->AddObject(xsf);
}
}
+ if(cmtarget.GetPropertyAsBool("FRAMEWORK"))
+ {
+ this->AddFrameworkPhases(&cmtarget, buildPhases);
+ }
+ }
+}
+
+//----------------------------------------------------------------------------
+void cmGlobalXCodeGenerator::AddFrameworkPhases(cmTarget* target,
+ cmXCodeObject* buildPhases)
+{
+ const char* headers = target->GetProperty("FRAMEWORK_PUBLIC_HEADERS");
+ if(!headers)
+ {
+ return;
+ }
+
+ cmXCodeObject* copyHeaders =
+ this->CreateObject(cmXCodeObject::PBXCopyFilesBuildPhase);
+ copyHeaders->SetComment("Copy files");
+ copyHeaders->AddAttribute("buildActionMask",
+ this->CreateString("2147483647"));
+ copyHeaders->AddAttribute("dstSubfolderSpec",
+ this->CreateString("6"));
+ copyHeaders->AddAttribute("dstPath",
+ this->CreateString("Headers"));
+ buildPhases->AddObject(copyHeaders);
+ cmXCodeObject* headersToCopy =
+ this->CreateObject(cmXCodeObject::OBJECT_LIST);
+ copyHeaders->AddAttribute("files", headersToCopy);
+ std::vector<std::string> headersVec;
+ cmSystemTools::ExpandListArgument(headers,
+ headersVec);
+ cmCustomCommandLines commandLines;
+ std::vector<std::string> depends;
+ for(std::vector<std::string>::iterator i = headersVec.begin();
+ i != headersVec.end(); ++i)
+ {
+ cmCustomCommandLine line;
+ cmSourceFile* sf = this->CurrentMakefile->GetOrCreateSource(i->c_str());
+ cmXCodeObject* xsf =
+ this->CreateXCodeSourceFile(this->CurrentLocalGenerator,
+ sf, *target);
+ std::cerr << "copy header " << sf->GetFullPath() << "\n";
+ headersToCopy->AddObject(xsf);
}
}
@@ -2008,8 +2053,28 @@ void cmGlobalXCodeGenerator::CreateGroups(cmLocalGenerator* root,
cmtarget.GetSourceFiles().push_back
(this->CurrentMakefile->AddSource(file));
}
-
- std::vector<cmSourceFile*> & classes = cmtarget.GetSourceFiles();
+ std::vector<cmSourceFile*> classes = cmtarget.GetSourceFiles();
+ // add framework copy headers
+ if(cmtarget.GetPropertyAsBool("FRAMEWORK"))
+ {
+ const char* headers = cmtarget.GetProperty("FRAMEWORK_PUBLIC_HEADERS");
+ if(!headers)
+ {
+ return;
+ }
+ std::vector<std::string> headersVec;
+ cmSystemTools::ExpandListArgument(headers,
+ headersVec);
+ cmCustomCommandLines commandLines;
+ std::vector<std::string> depends;
+ for(std::vector<std::string>::iterator i = headersVec.begin();
+ i != headersVec.end(); ++i)
+ {
+ cmSourceFile* sf
+ = this->CurrentMakefile->GetOrCreateSource(i->c_str());
+ classes.push_back(sf);
+ }
+ }
for(std::vector<cmSourceFile*>::const_iterator s = classes.begin();
s != classes.end(); s++)
{
diff --git a/Source/cmGlobalXCodeGenerator.h b/Source/cmGlobalXCodeGenerator.h
index 5c8caa5..9bfc62d 100644
--- a/Source/cmGlobalXCodeGenerator.h
+++ b/Source/cmGlobalXCodeGenerator.h
@@ -65,6 +65,9 @@ public:
const char* config,
bool ignoreErrors,
bool fast);
+
+ // add extra build phases for a framework target
+ void AddFrameworkPhases(cmTarget*, cmXCodeObject* buildPhases);
/**
* Generate the all required files for building this project/tree. This