From 2649962d65a73307541b48e3da258ed96aa2bcb9 Mon Sep 17 00:00:00 2001 From: Sebastien Barre Date: Mon, 25 Feb 2002 15:06:18 -0500 Subject: FIX: although a CMakeLists.txt file could be searched up 'n' level in the directory tree, ReadListFile() always implied a CMakeLists.txt file was up *one* level. --- Source/cmMakefile.cxx | 25 +++++++++++++------------ 1 file changed, 13 insertions(+), 12 deletions(-) diff --git a/Source/cmMakefile.cxx b/Source/cmMakefile.cxx index deead3e..d863ca3 100644 --- a/Source/cmMakefile.cxx +++ b/Source/cmMakefile.cxx @@ -270,21 +270,22 @@ bool cmMakefile::ReadListFile(const char* filename, const char* external) std::string parentList = this->GetParentListFileName(filename); if (parentList != "") { - // save the current directory std::string srcdir = m_cmCurrentDirectory; - std::string bindir = m_CurrentOutputDirectory; - // compute the new current directories - std::string::size_type pos = m_cmCurrentDirectory.rfind('/'); - if(pos != std::string::npos) - { - m_cmCurrentDirectory = m_cmCurrentDirectory.substr(0, pos); - } - pos = m_CurrentOutputDirectory.rfind('/'); - if(pos != std::string::npos) + std::string bindir = m_CurrentOutputDirectory; + + std::string::size_type pos = parentList.rfind('/'); + + m_cmCurrentDirectory = parentList.substr(0, pos); + m_CurrentOutputDirectory = m_HomeOutputDirectory + parentList.substr(m_cmHomeDirectory.size(), pos - m_cmHomeDirectory.size()); + + // if not found, oops + if(pos == std::string::npos) { - m_CurrentOutputDirectory = m_CurrentOutputDirectory.substr(0, pos); + cmSystemTools::Error("Trailing slash not found"); } + this->ReadListFile(parentList.c_str()); + // restore the current directory m_cmCurrentDirectory = srcdir; m_CurrentOutputDirectory = bindir; @@ -803,7 +804,7 @@ std::string cmMakefile::GetParentListFileName(const char *currentFileName) parentFile = listsDir; parentFile += "/CMakeLists.txt"; } - + return parentFile; } -- cgit v0.12