summaryrefslogtreecommitdiffstats
path: root/Source/cmake.cxx
diff options
context:
space:
mode:
authorRobert Maynard <rmaynard@nvidia.com>2022-03-17 19:23:01 (GMT)
committerRobert Maynard <rmaynard@nvidia.com>2022-03-17 19:23:01 (GMT)
commitb44ad7992a2a377cc48ba1b7f666d863dbac34f3 (patch)
tree2be4cacd05496165cb508509940a9b5d27f77eb6 /Source/cmake.cxx
parent736e80dbcafc4c46950688b915e0688f1b817862 (diff)
downloadCMake-b44ad7992a2a377cc48ba1b7f666d863dbac34f3.zip
CMake-b44ad7992a2a377cc48ba1b7f666d863dbac34f3.tar.gz
CMake-b44ad7992a2a377cc48ba1b7f666d863dbac34f3.tar.bz2
cmake: Always prefer the last source directory provided
Fixes: #23334
Diffstat (limited to 'Source/cmake.cxx')
-rw-r--r--Source/cmake.cxx19
1 files changed, 5 insertions, 14 deletions
diff --git a/Source/cmake.cxx b/Source/cmake.cxx
index f9e2d6e..7de488b 100644
--- a/Source/cmake.cxx
+++ b/Source/cmake.cxx
@@ -819,7 +819,7 @@ void cmake::SetArgs(const std::vector<std::string>& args)
std::string path = cmSystemTools::CollapseFullPath(value);
cmSystemTools::ConvertToUnixSlashes(path);
- state->SetHomeDirectoryViaCommandLine(path, HomeDirArgStyle::Dash_S);
+ state->SetHomeDirectoryViaCommandLine(path);
return true;
};
@@ -1555,7 +1555,7 @@ bool cmake::SetDirectoriesFromFile(const std::string& arg)
// When invoked with a path that points to an existing CMakeCache
// This function is called multiple times with the same path
if (is_source_dir) {
- this->SetHomeDirectoryViaCommandLine(listPath, HomeDirArgStyle::Plain);
+ this->SetHomeDirectoryViaCommandLine(listPath);
if (no_build_tree) {
std::string cwd = cmSystemTools::GetCurrentWorkingDirectory();
this->SetHomeOutputDirectory(cwd);
@@ -1780,28 +1780,19 @@ void cmake::PrintPresetList(const cmCMakePresetsGraph& graph) const
}
#endif
-void cmake::SetHomeDirectoryViaCommandLine(std::string const& path,
- HomeDirArgStyle argStyle)
+void cmake::SetHomeDirectoryViaCommandLine(std::string const& path)
{
- bool fromDashS = argStyle == HomeDirArgStyle::Dash_S;
- static bool homeDirectorySetExplicitly = false;
if (path.empty()) {
return;
}
auto prev_path = this->GetHomeDirectory();
if (prev_path != path && !prev_path.empty()) {
- const bool ignore_prev_path =
- (fromDashS || (!fromDashS && !homeDirectorySetExplicitly));
- const std::string& ignored_path = (ignore_prev_path) ? prev_path : path;
this->IssueMessage(MessageType::WARNING,
cmStrCat("Ignoring extra path from command line:\n \"",
- ignored_path, "\""));
+ prev_path, "\""));
}
- if (fromDashS || !homeDirectorySetExplicitly) {
- this->SetHomeDirectory(path);
- }
- homeDirectorySetExplicitly = fromDashS;
+ this->SetHomeDirectory(path);
}
void cmake::SetHomeDirectory(const std::string& dir)