summaryrefslogtreecommitdiffstats
diff options
context:
space:
mode:
-rw-r--r--Source/cmGlobalXCodeGenerator.cxx87
-rw-r--r--Source/cmGlobalXCodeGenerator.h3
2 files changed, 34 insertions, 56 deletions
diff --git a/Source/cmGlobalXCodeGenerator.cxx b/Source/cmGlobalXCodeGenerator.cxx
index bacc8c3..225d271 100644
--- a/Source/cmGlobalXCodeGenerator.cxx
+++ b/Source/cmGlobalXCodeGenerator.cxx
@@ -302,9 +302,9 @@ void cmGlobalXCodeGenerator::SetGenerationRoot(cmLocalGenerator* root)
{
this->CurrentProject = root->GetMakefile()->GetProjectName();
this->SetCurrentLocalGenerator(root);
- std::string outDir = this->CurrentMakefile->GetHomeOutputDirectory();
- outDir =cmSystemTools::CollapseFullPath(outDir.c_str());
- cmSystemTools::SplitPath(outDir.c_str(),
+ cmSystemTools::SplitPath(this->CurrentMakefile->GetCurrentDirectory(),
+ this->ProjectSourceDirectoryComponents);
+ cmSystemTools::SplitPath(this->CurrentMakefile->GetCurrentOutputDirectory(),
this->ProjectOutputDirectoryComponents);
this->CurrentXCodeHackMakefile =
@@ -670,49 +670,18 @@ cmGlobalXCodeGenerator::CreateXCodeFileReference(cmSourceFile* sf,
fileRef->AddAttribute("lastKnownFileType",
this->CreateString(sourcecode.c_str()));
- std::string path =
- this->ConvertToRelativeForXCode(sf->GetFullPath().c_str());
- std::string dir;
- std::string file;
- cmSystemTools::SplitProgramPath(sf->GetFullPath().c_str(),
- dir, file);
-
- // Try to make the path relative to the project root.
- bool Absolute = true;
- if (this->XcodeVersion >= 30)
- {
- std::string relative =
- this->CurrentLocalGenerator->Convert(sf->GetFullPath().c_str(),
- cmLocalGenerator::HOME,
- cmLocalGenerator::MAKEFILE,
- false);
- relative = cmSystemTools::ConvertToOutputPath(relative.c_str());
- if (!relative.empty() && relative[0] != '/')
- {
- Absolute = false;
- path = relative;
- }
- }
-
- fileRef->AddAttribute("name", this->CreateString(file.c_str()));
+ // Store the file path relative to the top of the source tree.
+ std::string path = this->RelativeToSource(sf->GetFullPath().c_str());
+ std::string name = cmSystemTools::GetFilenameName(path.c_str());
+ const char* sourceTree = (cmSystemTools::FileIsFullPath(path.c_str())?
+ "<absolute>" : "SOURCE_ROOT");
+ fileRef->AddAttribute("name", this->CreateString(name.c_str()));
fileRef->AddAttribute("path", this->CreateString(path.c_str()));
+ fileRef->AddAttribute("sourceTree", this->CreateString(sourceTree));
if(this->XcodeVersion == 15)
{
fileRef->AddAttribute("refType", this->CreateString("4"));
}
- if(path.size() > 1 && path[0] == '.' && path[1] == '.')
- {
- fileRef->AddAttribute("sourceTree", this->CreateString("<group>"));
- }
- else if (Absolute)
- {
- fileRef->AddAttribute("sourceTree", this->CreateString("<absolute>"));
- }
- else
- {
- fileRef->AddAttribute("sourceTree", this->CreateString("SOURCE_ROOT"));
- }
-
return fileRef;
}
@@ -2610,24 +2579,14 @@ void cmGlobalXCodeGenerator
else
this->RootObject->AddAttribute("compatibilityVersion",
this->CreateString("Xcode 3.0"));
- this->RootObject->AddAttribute("projectDirPath", this->CreateString(""));
}
// Point Xcode at the top of the source tree.
{
- std::string proot = root->GetMakefile()->GetCurrentDirectory();
- proot = this->ConvertToRelativeForXCode(proot.c_str());
- if (this->XcodeVersion >= 30)
- {
- this->RootObject->AddAttribute("projectRoot",
- this->CreateString(""));
- this->RootObject->AddAttribute("projectDirPath",
- this->CreateString(proot.c_str()));
- }
- else
- {
- this->RootObject->AddAttribute("projectRoot",
- this->CreateString(proot.c_str()));
- }
+ std::string pdir =
+ this->RelativeToBinary(root->GetMakefile()->GetCurrentDirectory());
+ this->RootObject->AddAttribute("projectDirPath",
+ this->CreateString(pdir.c_str()));
+ this->RootObject->AddAttribute("projectRoot", this->CreateString(""));
}
cmXCodeObject* configlist =
this->CreateObject(cmXCodeObject::XCConfigurationList);
@@ -3067,6 +3026,22 @@ std::string cmGlobalXCodeGenerator::ConvertToRelativeForXCode(const char* p)
}
//----------------------------------------------------------------------------
+std::string cmGlobalXCodeGenerator::RelativeToSource(const char* p)
+{
+ // We force conversion because Xcode breakpoints do not work unless
+ // they are in a file named relative to the source tree.
+ return this->CurrentLocalGenerator->
+ ConvertToRelativePath(this->ProjectSourceDirectoryComponents, p, true);
+}
+
+//----------------------------------------------------------------------------
+std::string cmGlobalXCodeGenerator::RelativeToBinary(const char* p)
+{
+ return this->CurrentLocalGenerator->
+ ConvertToRelativePath(this->ProjectOutputDirectoryComponents, p);
+}
+
+//----------------------------------------------------------------------------
std::string cmGlobalXCodeGenerator::XCodeEscapePath(const char* p)
{
std::string ret = p;
diff --git a/Source/cmGlobalXCodeGenerator.h b/Source/cmGlobalXCodeGenerator.h
index 3dd105c..189d7fb 100644
--- a/Source/cmGlobalXCodeGenerator.h
+++ b/Source/cmGlobalXCodeGenerator.h
@@ -93,6 +93,8 @@ private:
std::vector<cmLocalGenerator*>&
generators);
std::string XCodeEscapePath(const char* p);
+ std::string RelativeToSource(const char* p);
+ std::string RelativeToBinary(const char* p);
std::string ConvertToRelativeForXCode(const char* p);
std::string ConvertToRelativeForMake(const char* p);
void CreateCustomCommands(cmXCodeObject* buildPhases,
@@ -206,6 +208,7 @@ private:
std::string CurrentProject;
std::set<cmStdString> TargetDoneSet;
std::vector<std::string> CurrentOutputDirectoryComponents;
+ std::vector<std::string> ProjectSourceDirectoryComponents;
std::vector<std::string> ProjectOutputDirectoryComponents;
std::map<cmStdString, cmXCodeObject* > GroupMap;
std::map<cmStdString, cmXCodeObject* > GroupNameMap;