summaryrefslogtreecommitdiffstats
diff options
context:
space:
mode:
-rw-r--r--Source/cmLocalGenerator.cxx66
-rw-r--r--Source/cmLocalGenerator.h2
2 files changed, 37 insertions, 31 deletions
diff --git a/Source/cmLocalGenerator.cxx b/Source/cmLocalGenerator.cxx
index 3b6e93c..fed8ea6 100644
--- a/Source/cmLocalGenerator.cxx
+++ b/Source/cmLocalGenerator.cxx
@@ -2084,54 +2084,58 @@ std::string cmLocalGenerator::Convert(const char* source,
}
//----------------------------------------------------------------------------
-void cmLocalGenerator::ConfigureRelativePaths()
+std::string cmLocalGenerator::FindRelativePathTopSource()
{
- // Find the highest parent source directory containing the local
- // source directory. This is the top of safe relative path
- // conversion.
- cmLocalGenerator* srcTop = this;
- while(cmLocalGenerator* next = srcTop->GetParent())
+ // Relative path conversion within a single tree managed by CMake is
+ // safe. We can use our parent relative path top if and only if
+ // this is a subdirectory of that top.
+ if(cmLocalGenerator* parent = this->GetParent())
{
+ std::string parentTop = parent->FindRelativePathTopSource();
if(cmSystemTools::IsSubDirectory(
- this->Makefile->GetStartDirectory(),
- next->Makefile->GetStartDirectory()))
+ this->Makefile->GetStartDirectory(), parentTop.c_str()))
{
- srcTop = next;
- }
- else
- {
- break;
+ return parentTop;
}
}
- // Relative path conversion inside the source tree is not used to
- // construct relative paths passed to build tools so it is safe to
- // even when the source is a network path.
- std::string source = srcTop->Makefile->GetStartDirectory();
- this->RelativePathTopSource = source;
+ // Otherwise this directory itself is the new top.
+ return this->Makefile->GetStartDirectory();
+}
- // Find the highest parent binary directory containing the local
- // binary directory. This is the top of safe relative path
- // conversion.
- cmLocalGenerator* binTop = this;
- while(cmLocalGenerator* next = binTop->GetParent())
+//----------------------------------------------------------------------------
+std::string cmLocalGenerator::FindRelativePathTopBinary()
+{
+ // Relative path conversion within a single tree managed by CMake is
+ // safe. We can use our parent relative path top if and only if
+ // this is a subdirectory of that top.
+ if(cmLocalGenerator* parent = this->GetParent())
{
+ std::string parentTop = parent->FindRelativePathTopBinary();
if(cmSystemTools::IsSubDirectory(
- this->Makefile->GetStartOutputDirectory(),
- next->Makefile->GetStartOutputDirectory()))
- {
- binTop = next;
- }
- else
+ this->Makefile->GetStartOutputDirectory(), parentTop.c_str()))
{
- break;
+ return parentTop;
}
}
+ // Otherwise this directory itself is the new top.
+ return this->Makefile->GetStartOutputDirectory();
+}
+
+//----------------------------------------------------------------------------
+void cmLocalGenerator::ConfigureRelativePaths()
+{
+ // Relative path conversion inside the source tree is not used to
+ // construct relative paths passed to build tools so it is safe to
+ // even when the source is a network path.
+ std::string source = this->FindRelativePathTopSource();
+ this->RelativePathTopSource = source;
+
// The current working directory on Windows cannot be a network
// path. Therefore relative paths cannot work when the binary tree
// is a network path.
- std::string binary = binTop->Makefile->GetStartOutputDirectory();
+ std::string binary = this->FindRelativePathTopBinary();
if(binary.size() < 2 || binary.substr(0, 2) != "//")
{
this->RelativePathTopBinary = binary;
diff --git a/Source/cmLocalGenerator.h b/Source/cmLocalGenerator.h
index 53a53d4..fbeb056 100644
--- a/Source/cmLocalGenerator.h
+++ b/Source/cmLocalGenerator.h
@@ -277,6 +277,8 @@ protected:
std::string& CreateSafeUniqueObjectFileName(const char* sin);
void ConfigureRelativePaths();
+ std::string FindRelativePathTopSource();
+ std::string FindRelativePathTopBinary();
cmMakefile *Makefile;
cmGlobalGenerator *GlobalGenerator;