Fix number of params and expand vars in all args
This commit is contained in:
parent
9ad598a9f0
commit
e17724279e
@ -19,54 +19,69 @@
|
|||||||
// cmAddCustomCommandCommand
|
// cmAddCustomCommandCommand
|
||||||
bool cmAddCustomCommandCommand::InitialPass(std::vector<std::string> const& argsIn)
|
bool cmAddCustomCommandCommand::InitialPass(std::vector<std::string> const& argsIn)
|
||||||
{
|
{
|
||||||
if (argsIn.size()< 9)
|
if (argsIn.size() < 6)
|
||||||
{
|
{
|
||||||
this->SetError("called with wrong number of arguments.");
|
this->SetError("called with wrong number of arguments.");
|
||||||
return false;
|
return false;
|
||||||
}
|
}
|
||||||
std::vector<std::string> args = argsIn;
|
|
||||||
std::vector<std::string> commandArgs;
|
|
||||||
std::vector<std::string> depends;
|
|
||||||
std::vector<std::string> outputs;
|
|
||||||
|
|
||||||
const char* source = args[0].c_str();
|
std::vector<std::string> args = argsIn;
|
||||||
const char* command = args[1].c_str();
|
|
||||||
if(args[2] != "ARGS")
|
if(args[2] != "ARGS")
|
||||||
{
|
{
|
||||||
this->SetError("Wrong syntax. The third argument should be ARGS");
|
this->SetError("Wrong syntax. The third argument should be ARGS");
|
||||||
return false;
|
return false;
|
||||||
}
|
}
|
||||||
int cc=3;
|
int cc=3;
|
||||||
|
|
||||||
|
std::vector<std::string> commandArgs;
|
||||||
while(args[cc] != "DEPENDS" && cc < argsIn.size())
|
while(args[cc] != "DEPENDS" && cc < argsIn.size())
|
||||||
{
|
{
|
||||||
|
m_Makefile->ExpandVariablesInString(args[cc]);
|
||||||
commandArgs.push_back(args[cc]);
|
commandArgs.push_back(args[cc]);
|
||||||
cc++;
|
cc++;
|
||||||
}
|
}
|
||||||
|
|
||||||
if(cc == argsIn.size()-1)
|
if(cc == argsIn.size()-1)
|
||||||
{
|
{
|
||||||
this->SetError("Wrong syntax. Missing DEPENDS.");
|
this->SetError("Wrong syntax. Missing DEPENDS.");
|
||||||
return false;
|
return false;
|
||||||
}
|
}
|
||||||
cc ++ ; // Skip DEPENDS
|
cc++ ; // Skip DEPENDS
|
||||||
|
|
||||||
|
std::vector<std::string> depends;
|
||||||
while(args[cc] != "OUTPUTS" && cc < argsIn.size())
|
while(args[cc] != "OUTPUTS" && cc < argsIn.size())
|
||||||
{
|
{
|
||||||
|
m_Makefile->ExpandVariablesInString(args[cc]);
|
||||||
depends.push_back(args[cc]);
|
depends.push_back(args[cc]);
|
||||||
cc++;
|
cc++;
|
||||||
}
|
}
|
||||||
|
|
||||||
if(cc == argsIn.size()-1)
|
if(cc == argsIn.size()-1)
|
||||||
{
|
{
|
||||||
this->SetError("Wrong syntax. Missing OUTPUTS.");
|
this->SetError("Wrong syntax. Missing OUTPUTS.");
|
||||||
return false;
|
return false;
|
||||||
}
|
}
|
||||||
cc ++; // Skip OUTPUTS
|
cc ++; // Skip OUTPUTS
|
||||||
|
|
||||||
|
std::vector<std::string> outputs;
|
||||||
while(cc < argsIn.size()-1)
|
while(cc < argsIn.size()-1)
|
||||||
{
|
{
|
||||||
|
m_Makefile->ExpandVariablesInString(args[cc]);
|
||||||
outputs.push_back(args[cc]);
|
outputs.push_back(args[cc]);
|
||||||
cc++;
|
cc++;
|
||||||
}
|
}
|
||||||
const char *target = args[argsIn.size()-1].c_str();
|
|
||||||
m_Makefile->AddCustomCommand( source, command, commandArgs,
|
m_Makefile->ExpandVariablesInString(args[0]);
|
||||||
depends, outputs, target );
|
m_Makefile->ExpandVariablesInString(args[1]);
|
||||||
|
m_Makefile->ExpandVariablesInString(args[argsIn.size()-1]);
|
||||||
|
|
||||||
|
m_Makefile->AddCustomCommand(args[0].c_str(),
|
||||||
|
args[1].c_str(),
|
||||||
|
commandArgs,
|
||||||
|
depends,
|
||||||
|
outputs,
|
||||||
|
args[argsIn.size()-1].c_str());
|
||||||
return true;
|
return true;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
Loading…
x
Reference in New Issue
Block a user