From 39766efaaaf7ce30f6bc2d7f1f98252eab5294b3 Mon Sep 17 00:00:00 2001 From: Andy Cedilnik Date: Wed, 7 Nov 2001 16:47:38 -0500 Subject: [PATCH] Added accessor for add custom command --- Source/cmAddCustomCommandCommand.cxx | 73 +++++++++++++++++++++++++ Source/cmAddCustomCommandCommand.h | 79 ++++++++++++++++++++++++++++ Source/cmCommands.cxx | 2 + 3 files changed, 154 insertions(+) create mode 100644 Source/cmAddCustomCommandCommand.cxx create mode 100644 Source/cmAddCustomCommandCommand.h diff --git a/Source/cmAddCustomCommandCommand.cxx b/Source/cmAddCustomCommandCommand.cxx new file mode 100644 index 000000000..5cb01a729 --- /dev/null +++ b/Source/cmAddCustomCommandCommand.cxx @@ -0,0 +1,73 @@ +/*========================================================================= + + Program: Insight Segmentation & Registration Toolkit + Module: $RCSfile$ + Language: C++ + Date: $Date$ + Version: $Revision$ + + + Copyright (c) 2000 National Library of Medicine + All rights reserved. + + See COPYRIGHT.txt for copyright details. + +=========================================================================*/ +#include "cmAddCustomCommandCommand.h" + + +// cmAddCustomCommandCommand +bool cmAddCustomCommandCommand::InitialPass(std::vector const& argsIn) +{ + if (argsIn.size()< 9) + { + this->SetError("called with wrong number of arguments."); + return false; + } + std::vector args = argsIn; + std::vector commandArgs; + std::vector depends; + std::vector outputs; + + const char* source = args[0].c_str(); + const char* command = args[1].c_str(); + if(args[2] != "ARGS") + { + this->SetError("Wrong syntax. The third argument should be ARGS"); + return false; + } + int cc=3; + while(args[cc] != "DEPENDS" && cc < argsIn.size()) + { + commandArgs.push_back(args[cc]); + cc++; + } + if(cc == argsIn.size()-1) + { + this->SetError("Wrong syntax. Missing DEPENDS."); + return false; + } + cc ++ ; // Skip DEPENDS + while(args[cc] != "OUTPUTS" && cc < argsIn.size()) + { + depends.push_back(args[cc]); + cc++; + } + if(cc == argsIn.size()-1) + { + this->SetError("Wrong syntax. Missing OUTPUTS."); + return false; + } + cc ++; // Skip OUTPUTS + while(cc < argsIn.size()-1) + { + outputs.push_back(args[cc]); + cc++; + } + const char *target = args[argsIn.size()-1].c_str(); + m_Makefile->AddCustomCommand( source, command, commandArgs, + depends, outputs, target ); + return true; +} + + diff --git a/Source/cmAddCustomCommandCommand.h b/Source/cmAddCustomCommandCommand.h new file mode 100644 index 000000000..1f1a6dc34 --- /dev/null +++ b/Source/cmAddCustomCommandCommand.h @@ -0,0 +1,79 @@ +/*========================================================================= + + Program: Insight Segmentation & Registration Toolkit + Module: $RCSfile$ + Language: C++ + Date: $Date$ + Version: $Revision$ + + + Copyright (c) 2000 National Library of Medicine + All rights reserved. + + See COPYRIGHT.txt for copyright details. + +=========================================================================*/ +#ifndef cmAddCustomCommandCommand_h +#define cmAddCustomCommandCommand_h + +#include "cmStandardIncludes.h" +#include "cmCommand.h" + +/** \class cmAddCustomCommandCommand + * \brief + * + * cmAddCustomCommandCommand defines a new command that can + * be executed within the CMake + */ +class cmAddCustomCommandCommand : public cmCommand +{ +public: + /** + * This is a virtual constructor for the command. + */ + virtual cmCommand* Clone() + { + return new cmAddCustomCommandCommand; + } + + /** + * This is called when the command is first encountered in + * the CMakeLists.txt file. + */ + virtual bool InitialPass(std::vector const& args); + + /** + * This determines if the command gets propagated down + * to makefiles located in subdirectories. + */ + virtual bool IsInherited() {return true;} + + /** + * The name of the command as specified in CMakeList.txt. + */ + virtual const char* GetName() {return "ADD_CUSTOM_COMMAND";} + + /** + * Succinct documentation. + */ + virtual const char* GetTerseDocumentation() + { + return "Create new command within CMake."; + } + + /** + * More documentation. + */ + virtual const char* GetFullDocumentation() + { + return + "ADD_CUSTOM_COMMAND(source, command ARGS [args] DEPENDS [depends] " + "OUTPUTS [outputs] target)\nAdd a custom command."; + } + + cmTypeMacro(cmAddCustomCommandCommand, cmCommand); +}; + + + +#endif diff --git a/Source/cmCommands.cxx b/Source/cmCommands.cxx index 550f58061..c4a6fadc6 100644 --- a/Source/cmCommands.cxx +++ b/Source/cmCommands.cxx @@ -59,6 +59,7 @@ #include "cmVTKWrapTclCommand.cxx" #include "cmQTWrapCPPCommand.cxx" #include "cmWrapExcludeFilesCommand.cxx" +#include "cmAddCustomCommandCommand.cxx" void GetPredefinedCommands(std::list& commands) { @@ -118,6 +119,7 @@ void GetPredefinedCommands(std::list& commands) commands.push_back(new cmVTKWrapTclCommand); commands.push_back(new cmQTWrapCPPCommand); commands.push_back(new cmWrapExcludeFilesCommand); + commands.push_back(new cmAddCustomCommandCommand); }