cmState: Extract a Directory class.
Move Directory-scoped state accessors to it. This will be expanded with directory property state soon.
This commit is contained in:
parent
27ec21dbb2
commit
9ebc7502b2
|
@ -70,7 +70,7 @@ void cmLocalGenerator::IssueMessage(cmake::MessageType t,
|
||||||
std::string const& text) const
|
std::string const& text) const
|
||||||
{
|
{
|
||||||
cmListFileContext lfc;
|
cmListFileContext lfc;
|
||||||
lfc.FilePath = this->StateSnapshot.GetCurrentSourceDirectory();
|
lfc.FilePath = this->StateSnapshot.GetDirectory().GetCurrentSource();
|
||||||
lfc.FilePath += "/CMakeLists.txt";
|
lfc.FilePath += "/CMakeLists.txt";
|
||||||
|
|
||||||
if(!this->GlobalGenerator->GetCMakeInstance()->GetIsInTryCompile())
|
if(!this->GlobalGenerator->GetCMakeInstance()->GetIsInTryCompile())
|
||||||
|
@ -161,7 +161,8 @@ void cmLocalGenerator::GenerateTestFiles()
|
||||||
const std::string& config =
|
const std::string& config =
|
||||||
this->Makefile->GetConfigurations(configurationTypes, false);
|
this->Makefile->GetConfigurations(configurationTypes, false);
|
||||||
|
|
||||||
std::string file = this->StateSnapshot.GetCurrentBinaryDirectory();
|
std::string file =
|
||||||
|
this->StateSnapshot.GetDirectory().GetCurrentBinary();
|
||||||
file += "/";
|
file += "/";
|
||||||
file += "CTestTestfile.cmake";
|
file += "CTestTestfile.cmake";
|
||||||
|
|
||||||
|
@ -170,9 +171,11 @@ void cmLocalGenerator::GenerateTestFiles()
|
||||||
|
|
||||||
fout << "# CMake generated Testfile for " << std::endl
|
fout << "# CMake generated Testfile for " << std::endl
|
||||||
<< "# Source directory: "
|
<< "# Source directory: "
|
||||||
<< this->StateSnapshot.GetCurrentSourceDirectory() << std::endl
|
<< this->StateSnapshot.GetDirectory().GetCurrentSource()
|
||||||
|
<< std::endl
|
||||||
<< "# Build directory: "
|
<< "# Build directory: "
|
||||||
<< this->StateSnapshot.GetCurrentBinaryDirectory() << std::endl
|
<< this->StateSnapshot.GetDirectory().GetCurrentBinary()
|
||||||
|
<< std::endl
|
||||||
<< "# " << std::endl
|
<< "# " << std::endl
|
||||||
<< "# This file includes the relevant testing commands "
|
<< "# This file includes the relevant testing commands "
|
||||||
<< "required for " << std::endl
|
<< "required for " << std::endl
|
||||||
|
@ -286,7 +289,8 @@ void cmLocalGenerator::GenerateInstallRules()
|
||||||
}
|
}
|
||||||
|
|
||||||
// Create the install script file.
|
// Create the install script file.
|
||||||
std::string file = this->StateSnapshot.GetCurrentBinaryDirectory();
|
std::string file =
|
||||||
|
this->StateSnapshot.GetDirectory().GetCurrentBinary();
|
||||||
std::string homedir = this->GetState()->GetBinaryDirectory();
|
std::string homedir = this->GetState()->GetBinaryDirectory();
|
||||||
int toplevel_install = 0;
|
int toplevel_install = 0;
|
||||||
if (file == homedir)
|
if (file == homedir)
|
||||||
|
@ -299,7 +303,7 @@ void cmLocalGenerator::GenerateInstallRules()
|
||||||
|
|
||||||
// Write the header.
|
// Write the header.
|
||||||
fout << "# Install script for directory: "
|
fout << "# Install script for directory: "
|
||||||
<< this->StateSnapshot.GetCurrentSourceDirectory()
|
<< this->StateSnapshot.GetDirectory().GetCurrentSource()
|
||||||
<< std::endl << std::endl;
|
<< std::endl << std::endl;
|
||||||
fout << "# Set the install prefix" << std::endl
|
fout << "# Set the install prefix" << std::endl
|
||||||
<< "if(NOT DEFINED CMAKE_INSTALL_PREFIX)" << std::endl
|
<< "if(NOT DEFINED CMAKE_INSTALL_PREFIX)" << std::endl
|
||||||
|
@ -518,7 +522,7 @@ void cmLocalGenerator::AddCustomCommandToCreateObject(const char* ofname,
|
||||||
source.GetFullPath(),
|
source.GetFullPath(),
|
||||||
commandLines,
|
commandLines,
|
||||||
comment.c_str(),
|
comment.c_str(),
|
||||||
this->StateSnapshot.GetCurrentBinaryDirectory()
|
this->StateSnapshot.GetDirectory().GetCurrentBinary()
|
||||||
);
|
);
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@ -540,12 +544,13 @@ void cmLocalGenerator::AddBuildTargetRule(const std::string& llang,
|
||||||
!sf->GetPropertyAsBool("EXTERNAL_OBJECT"))
|
!sf->GetPropertyAsBool("EXTERNAL_OBJECT"))
|
||||||
{
|
{
|
||||||
std::string dir_max;
|
std::string dir_max;
|
||||||
dir_max += this->StateSnapshot.GetCurrentBinaryDirectory();
|
dir_max += this->StateSnapshot.GetDirectory().GetCurrentBinary();
|
||||||
dir_max += "/";
|
dir_max += "/";
|
||||||
std::string obj = this->GetObjectFileNameWithoutTarget(*sf, dir_max);
|
std::string obj = this->GetObjectFileNameWithoutTarget(*sf, dir_max);
|
||||||
if(!obj.empty())
|
if(!obj.empty())
|
||||||
{
|
{
|
||||||
std::string ofname = this->StateSnapshot.GetCurrentBinaryDirectory();
|
std::string ofname =
|
||||||
|
this->StateSnapshot.GetDirectory().GetCurrentBinary();
|
||||||
ofname += "/";
|
ofname += "/";
|
||||||
ofname += obj;
|
ofname += obj;
|
||||||
objVector.push_back(ofname);
|
objVector.push_back(ofname);
|
||||||
|
@ -615,7 +620,7 @@ void cmLocalGenerator::AddBuildTargetRule(const std::string& llang,
|
||||||
"",
|
"",
|
||||||
commandLines,
|
commandLines,
|
||||||
comment.c_str(),
|
comment.c_str(),
|
||||||
this->StateSnapshot.GetCurrentBinaryDirectory()
|
this->StateSnapshot.GetDirectory().GetCurrentBinary()
|
||||||
);
|
);
|
||||||
this->Makefile->GetSource(targetFullPath);
|
this->Makefile->GetSource(targetFullPath);
|
||||||
target.Target->AddSource(targetFullPath);
|
target.Target->AddSource(targetFullPath);
|
||||||
|
@ -1369,20 +1374,20 @@ void cmLocalGenerator::GetIncludeDirectories(std::vector<std::string>& dirs,
|
||||||
// Store the automatic include paths.
|
// Store the automatic include paths.
|
||||||
if(includeBinaryDir)
|
if(includeBinaryDir)
|
||||||
{
|
{
|
||||||
if(emitted.find(
|
std::string binDir = this->StateSnapshot.GetDirectory().GetCurrentBinary();
|
||||||
this->StateSnapshot.GetCurrentBinaryDirectory()) == emitted.end())
|
if(emitted.find(binDir) == emitted.end())
|
||||||
{
|
{
|
||||||
dirs.push_back(this->StateSnapshot.GetCurrentBinaryDirectory());
|
dirs.push_back(binDir);
|
||||||
emitted.insert(this->StateSnapshot.GetCurrentBinaryDirectory());
|
emitted.insert(binDir);
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
if(includeSourceDir)
|
if(includeSourceDir)
|
||||||
{
|
{
|
||||||
if(emitted.find(
|
std::string srcDir = this->StateSnapshot.GetDirectory().GetCurrentSource();
|
||||||
this->StateSnapshot.GetCurrentSourceDirectory()) == emitted.end())
|
if(emitted.find(srcDir) == emitted.end())
|
||||||
{
|
{
|
||||||
dirs.push_back(this->StateSnapshot.GetCurrentSourceDirectory());
|
dirs.push_back(srcDir);
|
||||||
emitted.insert(this->StateSnapshot.GetCurrentSourceDirectory());
|
emitted.insert(srcDir);
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@ -1983,7 +1988,7 @@ bool cmLocalGenerator::GetRealDependency(const std::string& inName,
|
||||||
|
|
||||||
// Treat the name as relative to the source directory in which it
|
// Treat the name as relative to the source directory in which it
|
||||||
// was given.
|
// was given.
|
||||||
dep = this->StateSnapshot.GetCurrentSourceDirectory();
|
dep = this->StateSnapshot.GetDirectory().GetCurrentSource();
|
||||||
dep += "/";
|
dep += "/";
|
||||||
dep += inName;
|
dep += inName;
|
||||||
return true;
|
return true;
|
||||||
|
|
|
@ -530,10 +530,10 @@ void cmLocalUnixMakefileGenerator3::WriteDirectoryInformationFile()
|
||||||
infoFileStream
|
infoFileStream
|
||||||
<< "# Relative path conversion top directories.\n"
|
<< "# Relative path conversion top directories.\n"
|
||||||
<< "set(CMAKE_RELATIVE_PATH_TOP_SOURCE \""
|
<< "set(CMAKE_RELATIVE_PATH_TOP_SOURCE \""
|
||||||
<< this->StateSnapshot.GetRelativePathTopSource()
|
<< this->StateSnapshot.GetDirectory().GetRelativePathTopSource()
|
||||||
<< "\")\n"
|
<< "\")\n"
|
||||||
<< "set(CMAKE_RELATIVE_PATH_TOP_BINARY \""
|
<< "set(CMAKE_RELATIVE_PATH_TOP_BINARY \""
|
||||||
<< this->StateSnapshot.GetRelativePathTopBinary()
|
<< this->StateSnapshot.GetDirectory().GetRelativePathTopBinary()
|
||||||
<< "\")\n"
|
<< "\")\n"
|
||||||
<< "\n";
|
<< "\n";
|
||||||
|
|
||||||
|
@ -1602,12 +1602,14 @@ cmLocalUnixMakefileGenerator3
|
||||||
if(const char* relativePathTopSource =
|
if(const char* relativePathTopSource =
|
||||||
mf->GetDefinition("CMAKE_RELATIVE_PATH_TOP_SOURCE"))
|
mf->GetDefinition("CMAKE_RELATIVE_PATH_TOP_SOURCE"))
|
||||||
{
|
{
|
||||||
this->StateSnapshot.SetRelativePathTopSource(relativePathTopSource);
|
this->StateSnapshot.GetDirectory()
|
||||||
|
.SetRelativePathTopSource(relativePathTopSource);
|
||||||
}
|
}
|
||||||
if(const char* relativePathTopBinary =
|
if(const char* relativePathTopBinary =
|
||||||
mf->GetDefinition("CMAKE_RELATIVE_PATH_TOP_BINARY"))
|
mf->GetDefinition("CMAKE_RELATIVE_PATH_TOP_BINARY"))
|
||||||
{
|
{
|
||||||
this->StateSnapshot.SetRelativePathTopBinary(relativePathTopBinary);
|
this->StateSnapshot.GetDirectory()
|
||||||
|
.SetRelativePathTopBinary(relativePathTopBinary);
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
else
|
else
|
||||||
|
|
|
@ -1704,7 +1704,7 @@ public:
|
||||||
: Makefile(mf), ReportError(true)
|
: Makefile(mf), ReportError(true)
|
||||||
{
|
{
|
||||||
std::string currentStart =
|
std::string currentStart =
|
||||||
this->Makefile->StateSnapshot.GetCurrentSourceDirectory();
|
this->Makefile->StateSnapshot.GetDirectory().GetCurrentSource();
|
||||||
currentStart += "/CMakeLists.txt";
|
currentStart += "/CMakeLists.txt";
|
||||||
this->Makefile->StateSnapshot.SetListFile(currentStart);
|
this->Makefile->StateSnapshot.SetListFile(currentStart);
|
||||||
this->Makefile->ListFileStack.push_back(currentStart);
|
this->Makefile->ListFileStack.push_back(currentStart);
|
||||||
|
@ -1748,11 +1748,12 @@ void cmMakefile::Configure()
|
||||||
BuildsystemFileScope scope(this);
|
BuildsystemFileScope scope(this);
|
||||||
|
|
||||||
// make sure the CMakeFiles dir is there
|
// make sure the CMakeFiles dir is there
|
||||||
std::string filesDir = this->StateSnapshot.GetCurrentBinaryDirectory();
|
std::string filesDir = this->StateSnapshot.GetDirectory().GetCurrentBinary();
|
||||||
filesDir += cmake::GetCMakeFilesDirectory();
|
filesDir += cmake::GetCMakeFilesDirectory();
|
||||||
cmSystemTools::MakeDirectory(filesDir.c_str());
|
cmSystemTools::MakeDirectory(filesDir.c_str());
|
||||||
|
|
||||||
std::string currentStart = this->StateSnapshot.GetCurrentSourceDirectory();
|
std::string currentStart =
|
||||||
|
this->StateSnapshot.GetDirectory().GetCurrentSource();
|
||||||
currentStart += "/CMakeLists.txt";
|
currentStart += "/CMakeLists.txt";
|
||||||
assert(cmSystemTools::FileExists(currentStart.c_str(), true));
|
assert(cmSystemTools::FileExists(currentStart.c_str(), true));
|
||||||
this->AddDefinition("CMAKE_PARENT_LIST_FILE", currentStart.c_str());
|
this->AddDefinition("CMAKE_PARENT_LIST_FILE", currentStart.c_str());
|
||||||
|
@ -1884,27 +1885,27 @@ void cmMakefile::AddSubDirectory(const std::string& srcPath,
|
||||||
|
|
||||||
void cmMakefile::SetCurrentSourceDirectory(const std::string& dir)
|
void cmMakefile::SetCurrentSourceDirectory(const std::string& dir)
|
||||||
{
|
{
|
||||||
this->StateSnapshot.SetCurrentSourceDirectory(dir);
|
this->StateSnapshot.GetDirectory().SetCurrentSource(dir);
|
||||||
this->AddDefinition("CMAKE_CURRENT_SOURCE_DIR",
|
this->AddDefinition("CMAKE_CURRENT_SOURCE_DIR",
|
||||||
this->StateSnapshot.GetCurrentSourceDirectory());
|
this->StateSnapshot.GetDirectory().GetCurrentSource());
|
||||||
}
|
}
|
||||||
|
|
||||||
const char* cmMakefile::GetCurrentSourceDirectory() const
|
const char* cmMakefile::GetCurrentSourceDirectory() const
|
||||||
{
|
{
|
||||||
return this->StateSnapshot.GetCurrentSourceDirectory();
|
return this->StateSnapshot.GetDirectory().GetCurrentSource();
|
||||||
}
|
}
|
||||||
|
|
||||||
void cmMakefile::SetCurrentBinaryDirectory(const std::string& dir)
|
void cmMakefile::SetCurrentBinaryDirectory(const std::string& dir)
|
||||||
{
|
{
|
||||||
this->StateSnapshot.SetCurrentBinaryDirectory(dir);
|
this->StateSnapshot.GetDirectory().SetCurrentBinary(dir);
|
||||||
const char* binDir = this->StateSnapshot.GetCurrentBinaryDirectory();
|
const char* binDir = this->StateSnapshot.GetDirectory().GetCurrentBinary();
|
||||||
cmSystemTools::MakeDirectory(binDir);
|
cmSystemTools::MakeDirectory(binDir);
|
||||||
this->AddDefinition("CMAKE_CURRENT_BINARY_DIR", binDir);
|
this->AddDefinition("CMAKE_CURRENT_BINARY_DIR", binDir);
|
||||||
}
|
}
|
||||||
|
|
||||||
const char* cmMakefile::GetCurrentBinaryDirectory() const
|
const char* cmMakefile::GetCurrentBinaryDirectory() const
|
||||||
{
|
{
|
||||||
return this->StateSnapshot.GetCurrentBinaryDirectory();
|
return this->StateSnapshot.GetDirectory().GetCurrentBinary();
|
||||||
}
|
}
|
||||||
|
|
||||||
//----------------------------------------------------------------------------
|
//----------------------------------------------------------------------------
|
||||||
|
@ -4271,7 +4272,7 @@ const char *cmMakefile::GetProperty(const std::string& prop,
|
||||||
this->StateSnapshot.GetBuildsystemDirectoryParent();
|
this->StateSnapshot.GetBuildsystemDirectoryParent();
|
||||||
if(parent.IsValid())
|
if(parent.IsValid())
|
||||||
{
|
{
|
||||||
return parent.GetCurrentSourceDirectory();
|
return parent.GetDirectory().GetCurrentSource();
|
||||||
}
|
}
|
||||||
return "";
|
return "";
|
||||||
}
|
}
|
||||||
|
|
|
@ -81,10 +81,14 @@ const char* cmOutputConverter::GetRelativeRootPath(RelativeRoot relroot) const
|
||||||
{
|
{
|
||||||
switch (relroot)
|
switch (relroot)
|
||||||
{
|
{
|
||||||
case HOME: return this->GetState()->GetSourceDirectory();
|
case HOME:
|
||||||
case START: return this->StateSnapshot.GetCurrentSourceDirectory();
|
return this->GetState()->GetSourceDirectory();
|
||||||
case HOME_OUTPUT: return this->GetState()->GetBinaryDirectory();
|
case START:
|
||||||
case START_OUTPUT: return this->StateSnapshot.GetCurrentBinaryDirectory();
|
return this->StateSnapshot.GetDirectory().GetCurrentSource();
|
||||||
|
case HOME_OUTPUT:
|
||||||
|
return this->GetState()->GetBinaryDirectory();
|
||||||
|
case START_OUTPUT:
|
||||||
|
return this->StateSnapshot.GetDirectory().GetCurrentBinary();
|
||||||
default: break;
|
default: break;
|
||||||
}
|
}
|
||||||
return 0;
|
return 0;
|
||||||
|
@ -105,7 +109,8 @@ std::string cmOutputConverter::Convert(const std::string& source,
|
||||||
break;
|
break;
|
||||||
case START:
|
case START:
|
||||||
result = this->ConvertToRelativePath(
|
result = this->ConvertToRelativePath(
|
||||||
this->StateSnapshot.GetCurrentSourceDirectoryComponents(), result);
|
this->StateSnapshot.GetDirectory().GetCurrentSourceComponents(),
|
||||||
|
result);
|
||||||
break;
|
break;
|
||||||
case HOME_OUTPUT:
|
case HOME_OUTPUT:
|
||||||
result = this->ConvertToRelativePath(
|
result = this->ConvertToRelativePath(
|
||||||
|
@ -113,7 +118,8 @@ std::string cmOutputConverter::Convert(const std::string& source,
|
||||||
break;
|
break;
|
||||||
case START_OUTPUT:
|
case START_OUTPUT:
|
||||||
result = this->ConvertToRelativePath(
|
result = this->ConvertToRelativePath(
|
||||||
this->StateSnapshot.GetCurrentBinaryDirectoryComponents(), result);
|
this->StateSnapshot.GetDirectory().GetCurrentBinaryComponents(),
|
||||||
|
result);
|
||||||
break;
|
break;
|
||||||
case FULL:
|
case FULL:
|
||||||
result = cmSystemTools::CollapseFullPath(result);
|
result = cmSystemTools::CollapseFullPath(result);
|
||||||
|
@ -213,13 +219,13 @@ cmOutputConverter::ConvertToRelativePath(const std::vector<std::string>& local,
|
||||||
// or both in the binary tree.
|
// or both in the binary tree.
|
||||||
std::string local_path = cmSystemTools::JoinPath(local);
|
std::string local_path = cmSystemTools::JoinPath(local);
|
||||||
if(!((cmOutputConverterNotAbove(local_path.c_str(),
|
if(!((cmOutputConverterNotAbove(local_path.c_str(),
|
||||||
this->StateSnapshot.GetRelativePathTopBinary()) &&
|
this->StateSnapshot.GetDirectory().GetRelativePathTopBinary())
|
||||||
cmOutputConverterNotAbove(in_remote.c_str(),
|
&& cmOutputConverterNotAbove(in_remote.c_str(),
|
||||||
this->StateSnapshot.GetRelativePathTopBinary())) ||
|
this->StateSnapshot.GetDirectory().GetRelativePathTopBinary()))
|
||||||
(cmOutputConverterNotAbove(local_path.c_str(),
|
|| (cmOutputConverterNotAbove(local_path.c_str(),
|
||||||
this->StateSnapshot.GetRelativePathTopSource()) &&
|
this->StateSnapshot.GetDirectory().GetRelativePathTopSource())
|
||||||
cmOutputConverterNotAbove(in_remote.c_str(),
|
&& cmOutputConverterNotAbove(in_remote.c_str(),
|
||||||
this->StateSnapshot.GetRelativePathTopSource()))))
|
this->StateSnapshot.GetDirectory().GetRelativePathTopSource()))))
|
||||||
{
|
{
|
||||||
return in_remote;
|
return in_remote;
|
||||||
}
|
}
|
||||||
|
|
|
@ -611,13 +611,13 @@ std::vector<std::string> const& cmState::GetBinaryDirectoryComponents() const
|
||||||
return this->BinaryDirectoryComponents;
|
return this->BinaryDirectoryComponents;
|
||||||
}
|
}
|
||||||
|
|
||||||
void cmState::Snapshot::ComputeRelativePathTopSource()
|
void cmState::Directory::ComputeRelativePathTopSource()
|
||||||
{
|
{
|
||||||
// Relative path conversion inside the source tree is not used to
|
// Relative path conversion inside the source tree is not used to
|
||||||
// construct relative paths passed to build tools so it is safe to use
|
// construct relative paths passed to build tools so it is safe to use
|
||||||
// even when the source is a network path.
|
// even when the source is a network path.
|
||||||
|
|
||||||
cmState::Snapshot snapshot = *this;
|
cmState::Snapshot snapshot = this->Snapshot_;
|
||||||
std::vector<cmState::Snapshot> snapshots;
|
std::vector<cmState::Snapshot> snapshots;
|
||||||
snapshots.push_back(snapshot);
|
snapshots.push_back(snapshot);
|
||||||
while (true)
|
while (true)
|
||||||
|
@ -633,23 +633,23 @@ void cmState::Snapshot::ComputeRelativePathTopSource()
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
std::string result = snapshots.front().GetCurrentSourceDirectory();
|
std::string result = snapshots.front().GetDirectory().GetCurrentSource();
|
||||||
|
|
||||||
for (std::vector<cmState::Snapshot>::const_iterator it =
|
for (std::vector<cmState::Snapshot>::const_iterator it =
|
||||||
snapshots.begin() + 1; it != snapshots.end(); ++it)
|
snapshots.begin() + 1; it != snapshots.end(); ++it)
|
||||||
{
|
{
|
||||||
std::string currentSource = it->GetCurrentSourceDirectory();
|
std::string currentSource = it->GetDirectory().GetCurrentSource();
|
||||||
if(cmSystemTools::IsSubDirectory(result, currentSource))
|
if(cmSystemTools::IsSubDirectory(result, currentSource))
|
||||||
{
|
{
|
||||||
result = currentSource;
|
result = currentSource;
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
this->Position->BuildSystemDirectory->RelativePathTopSource = result;
|
this->DirectoryState->RelativePathTopSource = result;
|
||||||
}
|
}
|
||||||
|
|
||||||
void cmState::Snapshot::ComputeRelativePathTopBinary()
|
void cmState::Directory::ComputeRelativePathTopBinary()
|
||||||
{
|
{
|
||||||
cmState::Snapshot snapshot = *this;
|
cmState::Snapshot snapshot = this->Snapshot_;
|
||||||
std::vector<cmState::Snapshot> snapshots;
|
std::vector<cmState::Snapshot> snapshots;
|
||||||
snapshots.push_back(snapshot);
|
snapshots.push_back(snapshot);
|
||||||
while (true)
|
while (true)
|
||||||
|
@ -666,12 +666,12 @@ void cmState::Snapshot::ComputeRelativePathTopBinary()
|
||||||
}
|
}
|
||||||
|
|
||||||
std::string result =
|
std::string result =
|
||||||
snapshots.front().GetCurrentBinaryDirectory();
|
snapshots.front().GetDirectory().GetCurrentBinary();
|
||||||
|
|
||||||
for (std::vector<cmState::Snapshot>::const_iterator it =
|
for (std::vector<cmState::Snapshot>::const_iterator it =
|
||||||
snapshots.begin() + 1; it != snapshots.end(); ++it)
|
snapshots.begin() + 1; it != snapshots.end(); ++it)
|
||||||
{
|
{
|
||||||
std::string currentBinary = it->GetCurrentBinaryDirectory();
|
std::string currentBinary = it->GetDirectory().GetCurrentBinary();
|
||||||
if(cmSystemTools::IsSubDirectory(result, currentBinary))
|
if(cmSystemTools::IsSubDirectory(result, currentBinary))
|
||||||
{
|
{
|
||||||
result = currentBinary;
|
result = currentBinary;
|
||||||
|
@ -683,11 +683,11 @@ void cmState::Snapshot::ComputeRelativePathTopBinary()
|
||||||
// is a network path.
|
// is a network path.
|
||||||
if(result.size() < 2 || result.substr(0, 2) != "//")
|
if(result.size() < 2 || result.substr(0, 2) != "//")
|
||||||
{
|
{
|
||||||
this->Position->BuildSystemDirectory->RelativePathTopBinary = result;
|
this->DirectoryState->RelativePathTopBinary = result;
|
||||||
}
|
}
|
||||||
else
|
else
|
||||||
{
|
{
|
||||||
this->Position->BuildSystemDirectory->RelativePathTopBinary = "";
|
this->DirectoryState->RelativePathTopBinary = "";
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@ -812,40 +812,39 @@ cmState::Snapshot::Snapshot(cmState* state, PositionType position)
|
||||||
|
|
||||||
}
|
}
|
||||||
|
|
||||||
const char* cmState::Snapshot::GetCurrentSourceDirectory() const
|
const char* cmState::Directory::GetCurrentSource() const
|
||||||
{
|
{
|
||||||
return this->Position->BuildSystemDirectory->Location.c_str();
|
return this->DirectoryState->Location.c_str();
|
||||||
}
|
}
|
||||||
|
|
||||||
void cmState::Snapshot::SetCurrentSourceDirectory(std::string const& dir)
|
void cmState::Directory::SetCurrentSource(std::string const& dir)
|
||||||
{
|
{
|
||||||
assert(this->State);
|
std::string& loc = this->DirectoryState->Location;
|
||||||
std::string& loc = this->Position->BuildSystemDirectory->Location;
|
|
||||||
loc = dir;
|
loc = dir;
|
||||||
cmSystemTools::ConvertToUnixSlashes(loc);
|
cmSystemTools::ConvertToUnixSlashes(loc);
|
||||||
loc = cmSystemTools::CollapseFullPath(loc);
|
loc = cmSystemTools::CollapseFullPath(loc);
|
||||||
|
|
||||||
cmSystemTools::SplitPath(
|
cmSystemTools::SplitPath(
|
||||||
loc,
|
loc,
|
||||||
this->Position->BuildSystemDirectory->CurrentSourceDirectoryComponents);
|
this->DirectoryState->CurrentSourceDirectoryComponents);
|
||||||
this->ComputeRelativePathTopSource();
|
this->ComputeRelativePathTopSource();
|
||||||
}
|
}
|
||||||
|
|
||||||
const char* cmState::Snapshot::GetCurrentBinaryDirectory() const
|
const char* cmState::Directory::GetCurrentBinary() const
|
||||||
{
|
{
|
||||||
return this->Position->BuildSystemDirectory->OutputLocation.c_str();
|
return this->DirectoryState->OutputLocation.c_str();
|
||||||
}
|
}
|
||||||
|
|
||||||
void cmState::Snapshot::SetCurrentBinaryDirectory(std::string const& dir)
|
void cmState::Directory::SetCurrentBinary(std::string const& dir)
|
||||||
{
|
{
|
||||||
std::string& loc = this->Position->BuildSystemDirectory->OutputLocation;
|
std::string& loc = this->DirectoryState->OutputLocation;
|
||||||
loc = dir;
|
loc = dir;
|
||||||
cmSystemTools::ConvertToUnixSlashes(loc);
|
cmSystemTools::ConvertToUnixSlashes(loc);
|
||||||
loc = cmSystemTools::CollapseFullPath(loc);
|
loc = cmSystemTools::CollapseFullPath(loc);
|
||||||
|
|
||||||
cmSystemTools::SplitPath(
|
cmSystemTools::SplitPath(
|
||||||
loc,
|
loc,
|
||||||
this->Position->BuildSystemDirectory->CurrentBinaryDirectoryComponents);
|
this->DirectoryState->CurrentBinaryDirectoryComponents);
|
||||||
this->ComputeRelativePathTopBinary();
|
this->ComputeRelativePathTopBinary();
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@ -855,37 +854,35 @@ void cmState::Snapshot::SetListFile(const std::string& listfile)
|
||||||
}
|
}
|
||||||
|
|
||||||
std::vector<std::string> const&
|
std::vector<std::string> const&
|
||||||
cmState::Snapshot::GetCurrentSourceDirectoryComponents() const
|
cmState::Directory::GetCurrentSourceComponents() const
|
||||||
{
|
{
|
||||||
return this->Position->BuildSystemDirectory
|
return this->DirectoryState->CurrentSourceDirectoryComponents;
|
||||||
->CurrentSourceDirectoryComponents;
|
|
||||||
}
|
}
|
||||||
|
|
||||||
std::vector<std::string> const&
|
std::vector<std::string> const&
|
||||||
cmState::Snapshot::GetCurrentBinaryDirectoryComponents() const
|
cmState::Directory::GetCurrentBinaryComponents() const
|
||||||
{
|
{
|
||||||
return this->Position->BuildSystemDirectory
|
return this->DirectoryState->CurrentBinaryDirectoryComponents;
|
||||||
->CurrentBinaryDirectoryComponents;
|
|
||||||
}
|
}
|
||||||
|
|
||||||
const char* cmState::Snapshot::GetRelativePathTopSource() const
|
const char* cmState::Directory::GetRelativePathTopSource() const
|
||||||
{
|
{
|
||||||
return this->Position->BuildSystemDirectory->RelativePathTopSource.c_str();
|
return this->DirectoryState->RelativePathTopSource.c_str();
|
||||||
}
|
}
|
||||||
|
|
||||||
const char* cmState::Snapshot::GetRelativePathTopBinary() const
|
const char* cmState::Directory::GetRelativePathTopBinary() const
|
||||||
{
|
{
|
||||||
return this->Position->BuildSystemDirectory->RelativePathTopBinary.c_str();
|
return this->DirectoryState->RelativePathTopBinary.c_str();
|
||||||
}
|
}
|
||||||
|
|
||||||
void cmState::Snapshot::SetRelativePathTopSource(const char* dir)
|
void cmState::Directory::SetRelativePathTopSource(const char* dir)
|
||||||
{
|
{
|
||||||
this->Position->BuildSystemDirectory->RelativePathTopSource = dir;
|
this->DirectoryState->RelativePathTopSource = dir;
|
||||||
}
|
}
|
||||||
|
|
||||||
void cmState::Snapshot::SetRelativePathTopBinary(const char* dir)
|
void cmState::Directory::SetRelativePathTopBinary(const char* dir)
|
||||||
{
|
{
|
||||||
this->Position->BuildSystemDirectory->RelativePathTopBinary = dir;
|
this->DirectoryState->RelativePathTopBinary = dir;
|
||||||
}
|
}
|
||||||
|
|
||||||
std::string cmState::Snapshot::GetExecutionListFile() const
|
std::string cmState::Snapshot::GetExecutionListFile() const
|
||||||
|
@ -952,3 +949,16 @@ cmState* cmState::Snapshot::GetState() const
|
||||||
{
|
{
|
||||||
return this->State;
|
return this->State;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
cmState::Directory cmState::Snapshot::GetDirectory() const
|
||||||
|
{
|
||||||
|
return Directory(this->Position->BuildSystemDirectory, *this);
|
||||||
|
}
|
||||||
|
|
||||||
|
cmState::Directory::Directory(
|
||||||
|
cmLinkedTree<BuildsystemDirectoryStateType>::iterator iter,
|
||||||
|
const cmState::Snapshot& snapshot)
|
||||||
|
: DirectoryState(iter), Snapshot_(snapshot)
|
||||||
|
{
|
||||||
|
|
||||||
|
}
|
||||||
|
|
|
@ -39,27 +39,14 @@ public:
|
||||||
InlineListFileType
|
InlineListFileType
|
||||||
};
|
};
|
||||||
|
|
||||||
|
class Directory;
|
||||||
|
|
||||||
class Snapshot {
|
class Snapshot {
|
||||||
public:
|
public:
|
||||||
Snapshot(cmState* state = 0, PositionType position = PositionType());
|
Snapshot(cmState* state = 0, PositionType position = PositionType());
|
||||||
|
|
||||||
const char* GetCurrentSourceDirectory() const;
|
|
||||||
void SetCurrentSourceDirectory(std::string const& dir);
|
|
||||||
const char* GetCurrentBinaryDirectory() const;
|
|
||||||
void SetCurrentBinaryDirectory(std::string const& dir);
|
|
||||||
|
|
||||||
void SetListFile(std::string const& listfile);
|
void SetListFile(std::string const& listfile);
|
||||||
|
|
||||||
std::vector<std::string> const&
|
|
||||||
GetCurrentSourceDirectoryComponents() const;
|
|
||||||
std::vector<std::string> const&
|
|
||||||
GetCurrentBinaryDirectoryComponents() const;
|
|
||||||
|
|
||||||
const char* GetRelativePathTopSource() const;
|
|
||||||
const char* GetRelativePathTopBinary() const;
|
|
||||||
void SetRelativePathTopSource(const char* dir);
|
|
||||||
void SetRelativePathTopBinary(const char* dir);
|
|
||||||
|
|
||||||
std::string GetExecutionListFile() const;
|
std::string GetExecutionListFile() const;
|
||||||
std::string GetEntryPointCommand() const;
|
std::string GetEntryPointCommand() const;
|
||||||
long GetEntryPointLine() const;
|
long GetEntryPointLine() const;
|
||||||
|
@ -70,14 +57,43 @@ public:
|
||||||
|
|
||||||
cmState* GetState() const;
|
cmState* GetState() const;
|
||||||
|
|
||||||
|
Directory GetDirectory() const;
|
||||||
|
|
||||||
|
private:
|
||||||
|
friend class cmState;
|
||||||
|
friend class Directory;
|
||||||
|
cmState* State;
|
||||||
|
cmState::PositionType Position;
|
||||||
|
};
|
||||||
|
|
||||||
|
class Directory
|
||||||
|
{
|
||||||
|
Directory(cmLinkedTree<BuildsystemDirectoryStateType>::iterator iter,
|
||||||
|
Snapshot const& snapshot);
|
||||||
|
public:
|
||||||
|
const char* GetCurrentSource() const;
|
||||||
|
void SetCurrentSource(std::string const& dir);
|
||||||
|
const char* GetCurrentBinary() const;
|
||||||
|
void SetCurrentBinary(std::string const& dir);
|
||||||
|
|
||||||
|
std::vector<std::string> const&
|
||||||
|
GetCurrentSourceComponents() const;
|
||||||
|
std::vector<std::string> const&
|
||||||
|
GetCurrentBinaryComponents() const;
|
||||||
|
|
||||||
|
const char* GetRelativePathTopSource() const;
|
||||||
|
const char* GetRelativePathTopBinary() const;
|
||||||
|
void SetRelativePathTopSource(const char* dir);
|
||||||
|
void SetRelativePathTopBinary(const char* dir);
|
||||||
|
|
||||||
private:
|
private:
|
||||||
void ComputeRelativePathTopSource();
|
void ComputeRelativePathTopSource();
|
||||||
void ComputeRelativePathTopBinary();
|
void ComputeRelativePathTopBinary();
|
||||||
|
|
||||||
private:
|
private:
|
||||||
friend class cmState;
|
cmLinkedTree<BuildsystemDirectoryStateType>::iterator DirectoryState;
|
||||||
cmState* State;
|
Snapshot Snapshot_;
|
||||||
cmState::PositionType Position;
|
friend class Snapshot;
|
||||||
};
|
};
|
||||||
|
|
||||||
Snapshot CreateBaseSnapshot();
|
Snapshot CreateBaseSnapshot();
|
||||||
|
|
Loading…
Reference in New Issue