ENH: Restored implementation of AddCustomCommandToCreateObject. Updated it to use newer custom command functionality.
This commit is contained in:
parent
ae2cbc346d
commit
bb014b0f4d
|
@ -472,6 +472,9 @@ void cmLocalGenerator::AddCustomCommandToCreateObject(const char* ofname,
|
|||
flags += this->Makefile->GetSafeDefinition(varString.c_str());
|
||||
flags += " ";
|
||||
flags += this->GetIncludeFlags(lang);
|
||||
|
||||
// Construct the command lines.
|
||||
cmCustomCommandLines commandLines;
|
||||
std::vector<std::string> commands;
|
||||
cmSystemTools::ExpandList(rules, commands);
|
||||
cmLocalGenerator::RuleVariables vars;
|
||||
|
@ -482,39 +485,45 @@ void cmLocalGenerator::AddCustomCommandToCreateObject(const char* ofname,
|
|||
for(std::vector<std::string>::iterator i = commands.begin();
|
||||
i != commands.end(); ++i)
|
||||
{
|
||||
// Expand the full command line string.
|
||||
this->ExpandRuleVariables(*i, vars);
|
||||
|
||||
// Parse the string to get the custom command line.
|
||||
cmCustomCommandLine commandLine;
|
||||
std::vector<cmStdString> cmd = cmSystemTools::ParseArguments(i->c_str());
|
||||
for(std::vector<cmStdString>::iterator a = cmd.begin();
|
||||
a != cmd.end(); ++a)
|
||||
{
|
||||
commandLine.push_back(*a);
|
||||
}
|
||||
|
||||
// Store this command line.
|
||||
commandLines.push_back(commandLine);
|
||||
}
|
||||
std::vector<std::string> sourceAndDeps;
|
||||
sourceAndDeps.push_back(sourceFile);
|
||||
if(commands.size() > 1)
|
||||
{
|
||||
cmSystemTools::Error("Currently custom rules can only have one command sorry ");
|
||||
}
|
||||
// Check for extra object-file dependencies.
|
||||
|
||||
// Check for extra object-file dependencies.
|
||||
std::vector<std::string> depends;
|
||||
const char* additionalDeps = source.GetProperty("OBJECT_DEPENDS");
|
||||
if(additionalDeps)
|
||||
{
|
||||
cmSystemTools::ExpandListArgument(additionalDeps, depends);
|
||||
for(std::vector<std::string>::iterator i = depends.begin();
|
||||
i != depends.end(); ++i)
|
||||
{
|
||||
sourceAndDeps.push_back(this->Convert(i->c_str(),START_OUTPUT,SHELL));
|
||||
}
|
||||
}
|
||||
#if 0
|
||||
std::string command;
|
||||
std::string args;
|
||||
cmSystemTools::SplitProgramFromArgs(commands[0].c_str(), command, args);
|
||||
std::vector<std::string> argsv;
|
||||
argsv.push_back(args);
|
||||
this->Makefile->AddCustomCommandToOutput(ofname,
|
||||
command.c_str(),
|
||||
argsv,
|
||||
source.GetFullPath().c_str(),
|
||||
sourceAndDeps,
|
||||
"build from source");
|
||||
#endif
|
||||
}
|
||||
|
||||
// Generate a meaningful comment for the command.
|
||||
std::string comment = "Building ";
|
||||
comment += lang;
|
||||
comment += " object ";
|
||||
comment += this->Convert(ofname, START_OUTPUT);
|
||||
|
||||
// Add the custom command to build the object file.
|
||||
this->Makefile->AddCustomCommandToOutput(
|
||||
ofname,
|
||||
depends,
|
||||
source.GetFullPath().c_str(),
|
||||
commandLines,
|
||||
comment.c_str(),
|
||||
this->Makefile->GetStartOutputDirectory()
|
||||
);
|
||||
}
|
||||
|
||||
void cmLocalGenerator::AddBuildTargetRule(const char* llang, cmTarget& target)
|
||||
|
|
Loading…
Reference in New Issue