ENH: getting closer
This commit is contained in:
parent
d04a07e0c9
commit
34e7e36cae
|
@ -1879,6 +1879,23 @@ int cmCTest::RunCMakeAndTest(std::string* outstring)
|
||||||
makeCommand += "ALL_BUILD";
|
makeCommand += "ALL_BUILD";
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
else if (lowerCaseCommand.find("xcode") != std::string::npos)
|
||||||
|
{
|
||||||
|
makeCommand += " -project ";
|
||||||
|
makeCommand += m_BuildProject;
|
||||||
|
makeCommand += ".xcode";
|
||||||
|
makeCommand += " build ";
|
||||||
|
if (m_BuildTarget.size())
|
||||||
|
{
|
||||||
|
makeCommand += "-target ";
|
||||||
|
makeCommand += m_BuildTarget;
|
||||||
|
}
|
||||||
|
else
|
||||||
|
{
|
||||||
|
makeCommand += "-alltargets ";
|
||||||
|
}
|
||||||
|
makeCommand += " -buildstyle Development ";
|
||||||
|
}
|
||||||
else if (lowerCaseCommand.find("make") != std::string::npos)
|
else if (lowerCaseCommand.find("make") != std::string::npos)
|
||||||
{
|
{
|
||||||
// assume a make sytle program
|
// assume a make sytle program
|
||||||
|
|
|
@ -24,15 +24,14 @@
|
||||||
|
|
||||||
|
|
||||||
//TODO
|
//TODO
|
||||||
// EXECUTABLE_OUTPUT_PATH/LIBRARY_OUTPUT_PATH
|
|
||||||
// LinkDirectories
|
|
||||||
// correct placment of include paths
|
|
||||||
// custom commands
|
// custom commands
|
||||||
// custom targets
|
// custom targets
|
||||||
// ALL_BUILD
|
// ALL_BUILD
|
||||||
// RUN_TESTS
|
// RUN_TESTS
|
||||||
|
// add a group for Sources Headers, and other cmake group stuff
|
||||||
|
|
||||||
|
// for each target create a custom build phase that is run first
|
||||||
|
// it can have inputs and outputs should just be a makefile
|
||||||
|
|
||||||
// per file flags howto
|
// per file flags howto
|
||||||
// 115281011528101152810000 = {
|
// 115281011528101152810000 = {
|
||||||
|
@ -61,6 +60,8 @@ cmGlobalXCodeGenerator::cmGlobalXCodeGenerator()
|
||||||
m_FindMakeProgramFile = "CMakeFindXCode.cmake";
|
m_FindMakeProgramFile = "CMakeFindXCode.cmake";
|
||||||
m_RootObject = 0;
|
m_RootObject = 0;
|
||||||
m_MainGroupChildren = 0;
|
m_MainGroupChildren = 0;
|
||||||
|
m_SourcesGroupChildren = 0;
|
||||||
|
m_ExternalGroupChildren = 0;
|
||||||
}
|
}
|
||||||
|
|
||||||
//----------------------------------------------------------------------------
|
//----------------------------------------------------------------------------
|
||||||
|
@ -132,6 +133,47 @@ int cmGlobalXCodeGenerator::TryCompile(const char *,
|
||||||
return retVal;
|
return retVal;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
||||||
|
void cmGlobalXCodeGenerator::ConfigureOutputPaths()
|
||||||
|
{
|
||||||
|
// Format the library and executable output paths.
|
||||||
|
m_LibraryOutputPath =
|
||||||
|
m_CurrentMakefile->GetSafeDefinition("LIBRARY_OUTPUT_PATH");
|
||||||
|
if(m_LibraryOutputPath.size() == 0)
|
||||||
|
{
|
||||||
|
m_LibraryOutputPath = m_CurrentMakefile->GetCurrentOutputDirectory();
|
||||||
|
}
|
||||||
|
// make sure there is a trailing slash
|
||||||
|
if(m_LibraryOutputPath.size() &&
|
||||||
|
m_LibraryOutputPath[m_LibraryOutputPath.size()-1] != '/')
|
||||||
|
{
|
||||||
|
m_LibraryOutputPath += "/";
|
||||||
|
if(!cmSystemTools::MakeDirectory(m_LibraryOutputPath.c_str()))
|
||||||
|
{
|
||||||
|
cmSystemTools::Error("Error creating directory ",
|
||||||
|
m_LibraryOutputPath.c_str());
|
||||||
|
}
|
||||||
|
}
|
||||||
|
m_CurrentMakefile->AddLinkDirectory(m_LibraryOutputPath.c_str());
|
||||||
|
m_ExecutableOutputPath =
|
||||||
|
m_CurrentMakefile->GetSafeDefinition("EXECUTABLE_OUTPUT_PATH");
|
||||||
|
if(m_ExecutableOutputPath.size() == 0)
|
||||||
|
{
|
||||||
|
m_ExecutableOutputPath = m_CurrentMakefile->GetCurrentOutputDirectory();
|
||||||
|
}
|
||||||
|
// make sure there is a trailing slash
|
||||||
|
if(m_ExecutableOutputPath.size() &&
|
||||||
|
m_ExecutableOutputPath[m_ExecutableOutputPath.size()-1] != '/')
|
||||||
|
{
|
||||||
|
m_ExecutableOutputPath += "/";
|
||||||
|
if(!cmSystemTools::MakeDirectory(m_ExecutableOutputPath.c_str()))
|
||||||
|
{
|
||||||
|
cmSystemTools::Error("Error creating directory ",
|
||||||
|
m_ExecutableOutputPath.c_str());
|
||||||
|
}
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
//----------------------------------------------------------------------------
|
//----------------------------------------------------------------------------
|
||||||
///! Create a local generator appropriate to this Global Generator
|
///! Create a local generator appropriate to this Global Generator
|
||||||
cmLocalGenerator *cmGlobalXCodeGenerator::CreateLocalGenerator()
|
cmLocalGenerator *cmGlobalXCodeGenerator::CreateLocalGenerator()
|
||||||
|
@ -204,7 +246,7 @@ cmGlobalXCodeGenerator::CreateXCodeSourceFile(cmLocalGenerator* lg,
|
||||||
->AppendFlags(flags, sf->GetProperty("COMPILE_FLAGS"));
|
->AppendFlags(flags, sf->GetProperty("COMPILE_FLAGS"));
|
||||||
|
|
||||||
cmXCodeObject* fileRef = this->CreateObject(cmXCodeObject::PBXFileReference);
|
cmXCodeObject* fileRef = this->CreateObject(cmXCodeObject::PBXFileReference);
|
||||||
m_MainGroupChildren->AddObject(fileRef);
|
m_SourcesGroupChildren->AddObject(fileRef);
|
||||||
cmXCodeObject* buildFile = this->CreateObject(cmXCodeObject::PBXBuildFile);
|
cmXCodeObject* buildFile = this->CreateObject(cmXCodeObject::PBXBuildFile);
|
||||||
buildFile->AddAttribute("fileRef", this->CreateObjectReference(fileRef));
|
buildFile->AddAttribute("fileRef", this->CreateObjectReference(fileRef));
|
||||||
cmXCodeObject* settings = this->CreateObject(cmXCodeObject::ATTRIBUTE_GROUP);
|
cmXCodeObject* settings = this->CreateObject(cmXCodeObject::ATTRIBUTE_GROUP);
|
||||||
|
@ -256,7 +298,10 @@ cmGlobalXCodeGenerator::CreateXCodeTargets(cmLocalGenerator* gen,
|
||||||
cmtarget.GetType() == cmTarget::INSTALL_FILES ||
|
cmtarget.GetType() == cmTarget::INSTALL_FILES ||
|
||||||
cmtarget.GetType() == cmTarget::INSTALL_PROGRAMS)
|
cmtarget.GetType() == cmTarget::INSTALL_PROGRAMS)
|
||||||
{
|
{
|
||||||
targets.push_back(this->CreateUtilityTarget(cmtarget));
|
if(cmtarget.GetType() == cmTarget::UTILITY)
|
||||||
|
{
|
||||||
|
targets.push_back(this->CreateUtilityTarget(cmtarget));
|
||||||
|
}
|
||||||
continue;
|
continue;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@ -313,6 +358,7 @@ void cmGlobalXCodeGenerator::CreateBuildSettings(cmTarget& target,
|
||||||
std::string& productType,
|
std::string& productType,
|
||||||
std::string& productName)
|
std::string& productName)
|
||||||
{
|
{
|
||||||
|
this->ConfigureOutputPaths();
|
||||||
std::string flags;
|
std::string flags;
|
||||||
bool shared = ((target.GetType() == cmTarget::SHARED_LIBRARY) ||
|
bool shared = ((target.GetType() == cmTarget::SHARED_LIBRARY) ||
|
||||||
(target.GetType() == cmTarget::MODULE_LIBRARY));
|
(target.GetType() == cmTarget::MODULE_LIBRARY));
|
||||||
|
@ -340,23 +386,28 @@ void cmGlobalXCodeGenerator::CreateBuildSettings(cmTarget& target,
|
||||||
m_CurrentLocalGenerator->AddSharedFlags(flags, lang, shared);
|
m_CurrentLocalGenerator->AddSharedFlags(flags, lang, shared);
|
||||||
}
|
}
|
||||||
|
|
||||||
// Add include directory flags.
|
// Add define flags
|
||||||
m_CurrentLocalGenerator->
|
|
||||||
AppendFlags(flags, m_CurrentLocalGenerator->GetIncludeFlags(lang));
|
|
||||||
|
|
||||||
// Add include directory flags.
|
|
||||||
m_CurrentLocalGenerator->AppendFlags(flags,
|
m_CurrentLocalGenerator->AppendFlags(flags,
|
||||||
m_CurrentMakefile->GetDefineFlags());
|
m_CurrentMakefile->GetDefineFlags());
|
||||||
cmSystemTools::ReplaceString(flags, "\"", "\\\"");
|
cmSystemTools::ReplaceString(flags, "\"", "\\\"");
|
||||||
productName = target.GetName();
|
productName = target.GetName();
|
||||||
|
bool needLinkDirs = true;
|
||||||
|
|
||||||
switch(target.GetType())
|
switch(target.GetType())
|
||||||
{
|
{
|
||||||
case cmTarget::STATIC_LIBRARY:
|
case cmTarget::STATIC_LIBRARY:
|
||||||
{
|
{
|
||||||
|
needLinkDirs = false;
|
||||||
|
if(m_LibraryOutputPath.size())
|
||||||
|
{
|
||||||
|
buildSettings->AddAttribute("SYMROOT",
|
||||||
|
this->CreateString
|
||||||
|
(m_LibraryOutputPath.c_str()));
|
||||||
|
}
|
||||||
productName += ".a";
|
productName += ".a";
|
||||||
std::string t = "lib";
|
std::string t = "lib";
|
||||||
t += productName;
|
t += productName;
|
||||||
productName = t;
|
productName = t;
|
||||||
productType = "com.apple.product-type.library.static";
|
productType = "com.apple.product-type.library.static";
|
||||||
fileType = "archive.ar";
|
fileType = "archive.ar";
|
||||||
buildSettings->AddAttribute("LIBRARY_STYLE",
|
buildSettings->AddAttribute("LIBRARY_STYLE",
|
||||||
|
@ -365,18 +416,39 @@ void cmGlobalXCodeGenerator::CreateBuildSettings(cmTarget& target,
|
||||||
}
|
}
|
||||||
|
|
||||||
case cmTarget::MODULE_LIBRARY:
|
case cmTarget::MODULE_LIBRARY:
|
||||||
|
{
|
||||||
|
if(m_LibraryOutputPath.size())
|
||||||
|
{
|
||||||
|
buildSettings->AddAttribute("SYMROOT",
|
||||||
|
this->CreateString
|
||||||
|
(m_LibraryOutputPath.c_str()));
|
||||||
|
}
|
||||||
buildSettings->AddAttribute("LIBRARY_STYLE",
|
buildSettings->AddAttribute("LIBRARY_STYLE",
|
||||||
this->CreateString("DYNAMIC"));
|
this->CreateString("DYNAMIC"));
|
||||||
productName += ".so";
|
productName += ".so";
|
||||||
|
std::string t = "lib";
|
||||||
|
t += productName;
|
||||||
|
productName = t;
|
||||||
buildSettings->AddAttribute("OTHER_LDFLAGS",
|
buildSettings->AddAttribute("OTHER_LDFLAGS",
|
||||||
this->CreateString("-bundle"));
|
this->CreateString("-bundle"));
|
||||||
productType = "com.apple.product-type.library.dynamic";
|
productType = "com.apple.product-type.library.dynamic";
|
||||||
fileType = "compiled.mach-o.dylib";
|
fileType = "compiled.mach-o.dylib";
|
||||||
break;
|
break;
|
||||||
|
}
|
||||||
case cmTarget::SHARED_LIBRARY:
|
case cmTarget::SHARED_LIBRARY:
|
||||||
|
{
|
||||||
|
if(m_LibraryOutputPath.size())
|
||||||
|
{
|
||||||
|
buildSettings->AddAttribute("SYMROOT",
|
||||||
|
this->CreateString
|
||||||
|
(m_LibraryOutputPath.c_str()));
|
||||||
|
}
|
||||||
buildSettings->AddAttribute("LIBRARY_STYLE",
|
buildSettings->AddAttribute("LIBRARY_STYLE",
|
||||||
this->CreateString("DYNAMIC"));
|
this->CreateString("DYNAMIC"));
|
||||||
productName += ".dylib";
|
productName += ".dylib";
|
||||||
|
std::string t = "lib";
|
||||||
|
t += productName;
|
||||||
|
productName = t;
|
||||||
buildSettings->AddAttribute("DYLIB_COMPATIBILITY_VERSION",
|
buildSettings->AddAttribute("DYLIB_COMPATIBILITY_VERSION",
|
||||||
this->CreateString("1"));
|
this->CreateString("1"));
|
||||||
buildSettings->AddAttribute("DYLIB_CURRENT_VERSION",
|
buildSettings->AddAttribute("DYLIB_CURRENT_VERSION",
|
||||||
|
@ -386,7 +458,14 @@ void cmGlobalXCodeGenerator::CreateBuildSettings(cmTarget& target,
|
||||||
productType = "com.apple.product-type.library.dynamic";
|
productType = "com.apple.product-type.library.dynamic";
|
||||||
fileType = "compiled.mach-o.dylib";
|
fileType = "compiled.mach-o.dylib";
|
||||||
break;
|
break;
|
||||||
|
}
|
||||||
case cmTarget::EXECUTABLE:
|
case cmTarget::EXECUTABLE:
|
||||||
|
if(m_ExecutableOutputPath.size())
|
||||||
|
{
|
||||||
|
buildSettings->AddAttribute("SYMROOT",
|
||||||
|
this->CreateString
|
||||||
|
(m_ExecutableOutputPath.c_str()));
|
||||||
|
}
|
||||||
fileType = "compiled.mach-o.executable";
|
fileType = "compiled.mach-o.executable";
|
||||||
productType = "com.apple.product-type.tool";
|
productType = "com.apple.product-type.tool";
|
||||||
break;
|
break;
|
||||||
|
@ -398,6 +477,48 @@ void cmGlobalXCodeGenerator::CreateBuildSettings(cmTarget& target,
|
||||||
case cmTarget::INSTALL_PROGRAMS:
|
case cmTarget::INSTALL_PROGRAMS:
|
||||||
break;
|
break;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
std::string dirs;
|
||||||
|
if(needLinkDirs)
|
||||||
|
{
|
||||||
|
// Try to emit each search path once
|
||||||
|
std::set<cmStdString> emitted;
|
||||||
|
// Some search paths should never be emitted
|
||||||
|
emitted.insert("");
|
||||||
|
emitted.insert("/usr/lib");
|
||||||
|
std::vector<std::string> const& linkdirs =
|
||||||
|
target.GetLinkDirectories();
|
||||||
|
for(std::vector<std::string>::const_iterator l = linkdirs.begin();
|
||||||
|
l != linkdirs.end(); ++l)
|
||||||
|
{
|
||||||
|
std::string libpath =
|
||||||
|
m_CurrentLocalGenerator->ConvertToOutputForExisting(l->c_str());
|
||||||
|
if(emitted.insert(libpath).second)
|
||||||
|
{
|
||||||
|
dirs += libpath + " ";
|
||||||
|
}
|
||||||
|
}
|
||||||
|
if(dirs.size())
|
||||||
|
{
|
||||||
|
buildSettings->AddAttribute("LIBRARY_SEARCH_PATHS",
|
||||||
|
this->CreateString(dirs.c_str()));
|
||||||
|
}
|
||||||
|
}
|
||||||
|
dirs = "";
|
||||||
|
std::vector<std::string>& includes =
|
||||||
|
m_CurrentMakefile->GetIncludeDirectories();
|
||||||
|
std::vector<std::string>::iterator i = includes.begin();
|
||||||
|
for(;i != includes.end(); ++i)
|
||||||
|
{
|
||||||
|
std::string incpath =
|
||||||
|
m_CurrentLocalGenerator->ConvertToOutputForExisting(i->c_str());
|
||||||
|
dirs += incpath + " ";
|
||||||
|
}
|
||||||
|
if(dirs.size())
|
||||||
|
{
|
||||||
|
buildSettings->AddAttribute("HEADER_SEARCH_PATHS",
|
||||||
|
this->CreateString(dirs.c_str()));
|
||||||
|
}
|
||||||
buildSettings->AddAttribute("GCC_OPTIMIZATION_LEVEL",
|
buildSettings->AddAttribute("GCC_OPTIMIZATION_LEVEL",
|
||||||
this->CreateString("0"));
|
this->CreateString("0"));
|
||||||
buildSettings->AddAttribute("INSTALL_PATH",
|
buildSettings->AddAttribute("INSTALL_PATH",
|
||||||
|
@ -492,7 +613,7 @@ cmGlobalXCodeGenerator::CreateXCodeTarget(cmTarget& cmtarget,
|
||||||
fileRef->AddAttribute("explicitFileType",
|
fileRef->AddAttribute("explicitFileType",
|
||||||
this->CreateString(fileTypeString.c_str()));
|
this->CreateString(fileTypeString.c_str()));
|
||||||
fileRef->AddAttribute("path", this->CreateString(productName.c_str()));
|
fileRef->AddAttribute("path", this->CreateString(productName.c_str()));
|
||||||
fileRef->AddAttribute("refType", this->CreateString("3"));
|
fileRef->AddAttribute("refType", this->CreateString("0"));
|
||||||
fileRef->AddAttribute("sourceTree",
|
fileRef->AddAttribute("sourceTree",
|
||||||
this->CreateString("BUILT_PRODUCTS_DIR"));
|
this->CreateString("BUILT_PRODUCTS_DIR"));
|
||||||
|
|
||||||
|
@ -616,7 +737,7 @@ void cmGlobalXCodeGenerator::AddLinkLibrary(cmXCodeObject* target,
|
||||||
buildPhases->GetObject(cmXCodeObject::PBXFrameworksBuildPhase);
|
buildPhases->GetObject(cmXCodeObject::PBXFrameworksBuildPhase);
|
||||||
cmXCodeObject* files = frameworkBuildPhase->GetObject("files");
|
cmXCodeObject* files = frameworkBuildPhase->GetObject("files");
|
||||||
files->AddObject(buildfile);
|
files->AddObject(buildfile);
|
||||||
m_MainGroupChildren->AddObject(fileRef);
|
m_ExternalGroupChildren->AddObject(fileRef);
|
||||||
}
|
}
|
||||||
else
|
else
|
||||||
{
|
{
|
||||||
|
@ -690,14 +811,7 @@ void cmGlobalXCodeGenerator::AddDependAndLinkInformation(cmXCodeObject* target)
|
||||||
}
|
}
|
||||||
|
|
||||||
// to force the location of a target
|
// to force the location of a target
|
||||||
//6FE4372B07AAF276004FB461 = {
|
// add this to build settings of target SYMROOT = /tmp/;
|
||||||
//buildSettings = {
|
|
||||||
//COPY_PHASE_STRIP = NO;
|
|
||||||
//SYMROOT = "/Users/kitware/Bill/CMake-build/test/build/bin";
|
|
||||||
//};
|
|
||||||
//isa = PBXBuildStyle;
|
|
||||||
//name = Development;
|
|
||||||
//};
|
|
||||||
|
|
||||||
//----------------------------------------------------------------------------
|
//----------------------------------------------------------------------------
|
||||||
void cmGlobalXCodeGenerator::CreateXCodeObjects(cmLocalGenerator* ,
|
void cmGlobalXCodeGenerator::CreateXCodeObjects(cmLocalGenerator* ,
|
||||||
|
@ -707,6 +821,8 @@ void cmGlobalXCodeGenerator::CreateXCodeObjects(cmLocalGenerator* ,
|
||||||
{
|
{
|
||||||
this->ClearXCodeObjects();
|
this->ClearXCodeObjects();
|
||||||
m_RootObject = 0;
|
m_RootObject = 0;
|
||||||
|
m_ExternalGroupChildren = 0;
|
||||||
|
m_SourcesGroupChildren = 0;
|
||||||
m_MainGroupChildren = 0;
|
m_MainGroupChildren = 0;
|
||||||
cmXCodeObject* group = this->CreateObject(cmXCodeObject::ATTRIBUTE_GROUP);
|
cmXCodeObject* group = this->CreateObject(cmXCodeObject::ATTRIBUTE_GROUP);
|
||||||
group->AddAttribute("COPY_PHASE_STRIP", this->CreateString("NO"));
|
group->AddAttribute("COPY_PHASE_STRIP", this->CreateString("NO"));
|
||||||
|
@ -733,6 +849,25 @@ void cmGlobalXCodeGenerator::CreateXCodeObjects(cmLocalGenerator* ,
|
||||||
mainGroup->AddAttribute("refType", this->CreateString("4"));
|
mainGroup->AddAttribute("refType", this->CreateString("4"));
|
||||||
mainGroup->AddAttribute("sourceTree", this->CreateString("<group>"));
|
mainGroup->AddAttribute("sourceTree", this->CreateString("<group>"));
|
||||||
|
|
||||||
|
cmXCodeObject* sourcesGroup = this->CreateObject(cmXCodeObject::PBXGroup);
|
||||||
|
m_SourcesGroupChildren =
|
||||||
|
this->CreateObject(cmXCodeObject::OBJECT_LIST);
|
||||||
|
sourcesGroup->AddAttribute("name", this->CreateString("Sources"));
|
||||||
|
sourcesGroup->AddAttribute("children", m_SourcesGroupChildren);
|
||||||
|
sourcesGroup->AddAttribute("refType", this->CreateString("4"));
|
||||||
|
sourcesGroup->AddAttribute("sourceTree", this->CreateString("<group>"));
|
||||||
|
m_MainGroupChildren->AddObject(sourcesGroup);
|
||||||
|
|
||||||
|
cmXCodeObject* externalGroup = this->CreateObject(cmXCodeObject::PBXGroup);
|
||||||
|
m_ExternalGroupChildren =
|
||||||
|
this->CreateObject(cmXCodeObject::OBJECT_LIST);
|
||||||
|
externalGroup->AddAttribute("name",
|
||||||
|
this->CreateString("External Libraries and Frameworks"));
|
||||||
|
externalGroup->AddAttribute("children", m_ExternalGroupChildren);
|
||||||
|
externalGroup->AddAttribute("refType", this->CreateString("4"));
|
||||||
|
externalGroup->AddAttribute("sourceTree", this->CreateString("<group>"));
|
||||||
|
m_MainGroupChildren->AddObject(externalGroup);
|
||||||
|
|
||||||
cmXCodeObject* productGroup = this->CreateObject(cmXCodeObject::PBXGroup);
|
cmXCodeObject* productGroup = this->CreateObject(cmXCodeObject::PBXGroup);
|
||||||
productGroup->AddAttribute("name", this->CreateString("Products"));
|
productGroup->AddAttribute("name", this->CreateString("Products"));
|
||||||
productGroup->AddAttribute("refType", this->CreateString("4"));
|
productGroup->AddAttribute("refType", this->CreateString("4"));
|
||||||
|
|
|
@ -101,11 +101,16 @@ private:
|
||||||
cmXCodeObject* dependTarget);
|
cmXCodeObject* dependTarget);
|
||||||
void AddLinkLibrary(cmXCodeObject* target,
|
void AddLinkLibrary(cmXCodeObject* target,
|
||||||
const char*);
|
const char*);
|
||||||
|
void ConfigureOutputPaths();
|
||||||
private:
|
private:
|
||||||
std::vector<cmXCodeObject*> m_XCodeObjects;
|
std::vector<cmXCodeObject*> m_XCodeObjects;
|
||||||
cmXCodeObject* m_RootObject;
|
cmXCodeObject* m_RootObject;
|
||||||
cmXCodeObject* m_MainGroupChildren;
|
cmXCodeObject* m_MainGroupChildren;
|
||||||
|
cmXCodeObject* m_SourcesGroupChildren;
|
||||||
|
cmXCodeObject* m_ExternalGroupChildren;
|
||||||
cmMakefile* m_CurrentMakefile;
|
cmMakefile* m_CurrentMakefile;
|
||||||
|
std::string m_LibraryOutputPath;
|
||||||
|
std::string m_ExecutableOutputPath;
|
||||||
cmLocalGenerator* m_CurrentLocalGenerator;
|
cmLocalGenerator* m_CurrentLocalGenerator;
|
||||||
};
|
};
|
||||||
|
|
||||||
|
|
|
@ -100,6 +100,10 @@ public:
|
||||||
///! Get the include flags for the current makefile and language
|
///! Get the include flags for the current makefile and language
|
||||||
const char* GetIncludeFlags(const char* lang);
|
const char* GetIncludeFlags(const char* lang);
|
||||||
|
|
||||||
|
///! for existing files convert to output path and short path if spaces
|
||||||
|
std::string ConvertToOutputForExisting(const char* p);
|
||||||
|
|
||||||
|
|
||||||
protected:
|
protected:
|
||||||
|
|
||||||
///! Fill out these strings for the given target. Libraries to link, flags, and linkflags.
|
///! Fill out these strings for the given target. Libraries to link, flags, and linkflags.
|
||||||
|
@ -115,9 +119,6 @@ protected:
|
||||||
/** Get the include flags for the current makefile and language. */
|
/** Get the include flags for the current makefile and language. */
|
||||||
void GetIncludeDirectories(std::vector<std::string>& dirs);
|
void GetIncludeDirectories(std::vector<std::string>& dirs);
|
||||||
|
|
||||||
///! for existing files convert to output path and short path if spaces
|
|
||||||
std::string ConvertToOutputForExisting(const char* p);
|
|
||||||
|
|
||||||
// Expand rule variables in CMake of the type found in language rules
|
// Expand rule variables in CMake of the type found in language rules
|
||||||
void ExpandRuleVariables(std::string& string,
|
void ExpandRuleVariables(std::string& string,
|
||||||
const char* language,
|
const char* language,
|
||||||
|
|
Loading…
Reference in New Issue