CMake/Source/cmAddCustomCommandCommand.cxx

143 lines
3.4 KiB
C++
Raw Normal View History

2001-11-08 00:47:38 +03:00
/*=========================================================================
Program: Insight Segmentation & Registration Toolkit
Module: $RCSfile$
Language: C++
Date: $Date$
Version: $Revision$
2002-01-21 23:30:43 +03:00
Copyright (c) 2002 Insight Consortium. All rights reserved.
See ITKCopyright.txt or http://www.itk.org/HTML/Copyright.htm for details.
2001-11-08 00:47:38 +03:00
2002-01-21 23:30:43 +03:00
This software is distributed WITHOUT ANY WARRANTY; without even
the implied warranty of MERCHANTABILITY or FITNESS FOR A PARTICULAR
PURPOSE. See the above copyright notices for more information.
2001-11-08 00:47:38 +03:00
=========================================================================*/
#include "cmAddCustomCommandCommand.h"
// cmAddCustomCommandCommand
2002-05-22 21:20:54 +04:00
bool cmAddCustomCommandCommand::InitialPass(std::vector<std::string> const& argsIn)
2001-11-08 00:47:38 +03:00
{
/* Let's complain at the end of this function about the lack of a particular
arg. For the moment, let's say that COMMAND, TARGET are always
required.
*/
2002-05-22 21:20:54 +04:00
if (argsIn.size() < 4)
2001-11-08 00:47:38 +03:00
{
this->SetError("called with wrong number of arguments.");
return false;
}
2002-05-22 21:20:54 +04:00
std::vector<std::string> args;
cmSystemTools::ExpandListArguments(argsIn, args);
std::string source, command, target;
std::vector<std::string> command_args, depends, outputs;
enum tdoing {
doing_source,
doing_command,
doing_target,
doing_args,
doing_depends,
doing_outputs,
doing_nothing
};
tdoing doing = doing_nothing;
for (unsigned int j = 0; j < args.size(); ++j)
2001-11-08 00:47:38 +03:00
{
std::string const& copy = args[j];
if(copy == "SOURCE")
{
doing = doing_source;
}
else if(copy == "COMMAND")
{
doing = doing_command;
}
else if(copy == "TARGET")
{
doing = doing_target;
}
else if(copy == "ARGS")
{
doing = doing_args;
}
else if (copy == "DEPENDS")
{
doing = doing_depends;
}
else if (copy == "OUTPUTS")
{
doing = doing_outputs;
}
else
{
switch (doing)
{
case doing_source:
source = copy;
break;
case doing_command:
command = copy;
break;
case doing_target:
target = copy;
break;
case doing_args:
command_args.push_back(copy);
break;
case doing_depends:
depends.push_back(copy);
break;
case doing_outputs:
outputs.push_back(copy);
break;
default:
this->SetError("Wrong syntax. Unknow type of argument.");
return false;
}
}
2001-11-08 00:47:38 +03:00
}
/* At this point we could complain about the lack of arguments.
For the moment, let's say that COMMAND, TARGET are always
required.
*/
if(command.empty())
2001-11-08 00:47:38 +03:00
{
this->SetError("Wrong syntax. Empty COMMAND.");
2001-11-08 00:47:38 +03:00
return false;
}
if(target.empty())
2001-11-08 00:47:38 +03:00
{
this->SetError("Wrong syntax. Empty TARGET.");
return false;
2001-11-08 00:47:38 +03:00
}
// If source is empty, use target as source, so that this command
// can be used to just attach a commmand to a target
if(source.empty())
{
source = target;
}
m_Makefile->AddCustomCommand(source.c_str(),
command.c_str(),
command_args,
depends,
outputs,
target.c_str());
2001-11-08 00:47:38 +03:00
return true;
}