mirror of
https://github.com/Kitware/CMake.git
synced 2026-04-30 02:59:22 -05:00
@@ -5,21 +5,20 @@
|
||||
#include <sstream>
|
||||
#include <string.h>
|
||||
|
||||
#include "cmExecutionStatus.h"
|
||||
#include "cmMakefile.h"
|
||||
#include "cmRange.h"
|
||||
#include "cmSystemTools.h"
|
||||
|
||||
class cmExecutionStatus;
|
||||
|
||||
// cmAddSubDirectoryCommand
|
||||
bool cmAddSubDirectoryCommand::InitialPass(
|
||||
std::vector<std::string> const& args, cmExecutionStatus&)
|
||||
bool cmAddSubDirectoryCommand(std::vector<std::string> const& args,
|
||||
cmExecutionStatus& status)
|
||||
{
|
||||
if (args.empty()) {
|
||||
this->SetError("called with incorrect number of arguments");
|
||||
status.SetError("called with incorrect number of arguments");
|
||||
return false;
|
||||
}
|
||||
|
||||
cmMakefile& mf = status.GetMakefile();
|
||||
// store the binpath
|
||||
std::string const& srcArg = args.front();
|
||||
std::string binArg;
|
||||
@@ -35,7 +34,7 @@ bool cmAddSubDirectoryCommand::InitialPass(
|
||||
if (binArg.empty()) {
|
||||
binArg = arg;
|
||||
} else {
|
||||
this->SetError("called with incorrect number of arguments");
|
||||
status.SetError("called with incorrect number of arguments");
|
||||
return false;
|
||||
}
|
||||
}
|
||||
@@ -46,7 +45,7 @@ bool cmAddSubDirectoryCommand::InitialPass(
|
||||
if (cmSystemTools::FileIsFullPath(srcArg)) {
|
||||
srcPath = srcArg;
|
||||
} else {
|
||||
srcPath = this->Makefile->GetCurrentSourceDirectory();
|
||||
srcPath = mf.GetCurrentSourceDirectory();
|
||||
srcPath += "/";
|
||||
srcPath += srcArg;
|
||||
}
|
||||
@@ -54,7 +53,7 @@ bool cmAddSubDirectoryCommand::InitialPass(
|
||||
std::string error = "given source \"";
|
||||
error += srcArg;
|
||||
error += "\" which is not an existing directory.";
|
||||
this->SetError(error);
|
||||
status.SetError(error);
|
||||
return false;
|
||||
}
|
||||
srcPath = cmSystemTools::CollapseFullPath(srcPath);
|
||||
@@ -65,22 +64,22 @@ bool cmAddSubDirectoryCommand::InitialPass(
|
||||
// No binary directory was specified. If the source directory is
|
||||
// not a subdirectory of the current directory then it is an
|
||||
// error.
|
||||
if (!cmSystemTools::IsSubDirectory(
|
||||
srcPath, this->Makefile->GetCurrentSourceDirectory())) {
|
||||
if (!cmSystemTools::IsSubDirectory(srcPath,
|
||||
mf.GetCurrentSourceDirectory())) {
|
||||
std::ostringstream e;
|
||||
e << "not given a binary directory but the given source directory "
|
||||
<< "\"" << srcPath << "\" is not a subdirectory of \""
|
||||
<< this->Makefile->GetCurrentSourceDirectory() << "\". "
|
||||
<< mf.GetCurrentSourceDirectory() << "\". "
|
||||
<< "When specifying an out-of-tree source a binary directory "
|
||||
<< "must be explicitly specified.";
|
||||
this->SetError(e.str());
|
||||
status.SetError(e.str());
|
||||
return false;
|
||||
}
|
||||
|
||||
// Remove the CurrentDirectory from the srcPath and replace it
|
||||
// with the CurrentOutputDirectory.
|
||||
const std::string& src = this->Makefile->GetCurrentSourceDirectory();
|
||||
const std::string& bin = this->Makefile->GetCurrentBinaryDirectory();
|
||||
const std::string& src = mf.GetCurrentSourceDirectory();
|
||||
const std::string& bin = mf.GetCurrentBinaryDirectory();
|
||||
size_t srcLen = src.length();
|
||||
size_t binLen = bin.length();
|
||||
if (srcLen > 0 && src.back() == '/') {
|
||||
@@ -96,7 +95,7 @@ bool cmAddSubDirectoryCommand::InitialPass(
|
||||
if (cmSystemTools::FileIsFullPath(binArg)) {
|
||||
binPath = binArg;
|
||||
} else {
|
||||
binPath = this->Makefile->GetCurrentBinaryDirectory();
|
||||
binPath = mf.GetCurrentBinaryDirectory();
|
||||
binPath += "/";
|
||||
binPath += binArg;
|
||||
}
|
||||
@@ -104,7 +103,7 @@ bool cmAddSubDirectoryCommand::InitialPass(
|
||||
binPath = cmSystemTools::CollapseFullPath(binPath);
|
||||
|
||||
// Add the subdirectory using the computed full paths.
|
||||
this->Makefile->AddSubDirectory(srcPath, binPath, excludeFromAll, true);
|
||||
mf.AddSubDirectory(srcPath, binPath, excludeFromAll, true);
|
||||
|
||||
return true;
|
||||
}
|
||||
|
||||
Reference in New Issue
Block a user