diff options
author | Alexander Neundorf <neundorf@kde.org> | 2007-07-12 15:56:45 (GMT) |
---|---|---|
committer | Alexander Neundorf <neundorf@kde.org> | 2007-07-12 15:56:45 (GMT) |
commit | c8010cd7fb0f87dd6ceb07679a2840029f4238a3 (patch) | |
tree | 1fbdffa0e4b323119760c3693bbd226d301eac33 /Source | |
parent | a5be2b77823d6dd2ce1fd6859eb037dd2c939134 (diff) | |
download | CMake-c8010cd7fb0f87dd6ceb07679a2840029f4238a3.zip CMake-c8010cd7fb0f87dd6ceb07679a2840029f4238a3.tar.gz CMake-c8010cd7fb0f87dd6ceb07679a2840029f4238a3.tar.bz2 |
ENH: add LIST(CONTAINS ...) patch from "Miguel A. Figueroa-Villanueva, miguelf (AT) ieee.org
added tests for LIST(CONTAINS, SORT, REVERSE)
Alex
Diffstat (limited to 'Source')
-rw-r--r-- | Source/cmListCommand.cxx | 37 | ||||
-rw-r--r-- | Source/cmListCommand.h | 7 |
2 files changed, 43 insertions, 1 deletions
diff --git a/Source/cmListCommand.cxx b/Source/cmListCommand.cxx index b546d20..f0df03b 100644 --- a/Source/cmListCommand.cxx +++ b/Source/cmListCommand.cxx @@ -42,6 +42,10 @@ bool cmListCommand::InitialPass(std::vector<std::string> const& args) { return this->HandleAppendCommand(args); } + if(subCommand == "CONTAINS") + { + return this->HandleContainsCommand(args); + } if(subCommand == "INSERT") { return this->HandleInsertCommand(args); @@ -200,6 +204,39 @@ bool cmListCommand::HandleAppendCommand(std::vector<std::string> const& args) } //---------------------------------------------------------------------------- +bool cmListCommand::HandleContainsCommand(std::vector<std::string> const& args) +{ + if(args.size() != 4) + { + this->SetError("sub-command CONTAINS requires three arguments."); + return false; + } + + const std::string& listName = args[1]; + const std::string& variableName = args[args.size() - 1]; + // expand the variable + std::vector<std::string> varArgsExpanded; + if ( !this->GetList(varArgsExpanded, listName.c_str()) ) + { + this->Makefile->AddDefinition(variableName.c_str(), "FALSE"); + return true; + } + + std::vector<std::string>::iterator it; + for ( it = varArgsExpanded.begin(); it != varArgsExpanded.end(); ++ it ) + { + if ( *it == args[2] ) + { + this->Makefile->AddDefinition(variableName.c_str(), "TRUE"); + return true; + } + } + + this->Makefile->AddDefinition(variableName.c_str(), "FALSE"); + return true; +} + +//---------------------------------------------------------------------------- bool cmListCommand::HandleInsertCommand(std::vector<std::string> const& args) { if(args.size() < 4) diff --git a/Source/cmListCommand.h b/Source/cmListCommand.h index 2dbe1d8..d8a4688 100644 --- a/Source/cmListCommand.h +++ b/Source/cmListCommand.h @@ -68,20 +68,24 @@ public: " LIST(GET <list> <element index> [<element index> ...] " "<output variable>)\n" " LIST(APPEND <list> <element> [<element> ...])\n" + " LIST(CONTAINS <list> <value> <output variable>)\n" " LIST(INSERT <list> <element_index> <element> [<element> ...])\n" " LIST(REMOVE_ITEM <list> <value> [<value> ...])\n" " LIST(REMOVE_AT <list> <index> [<index> ...])\n" - " LIST(SORT <list>)\n" " LIST(REVERSE <list>)\n" + " LIST(SORT <list>)\n" "LENGTH will return a given list's length.\n" "GET will return list of elements specified by indices from the list.\n" "APPEND will append elements to the list.\n" + "CONTAINS will return TRUE if the element specified is in the list.\n" "INSERT will insert elements to the list to the specified location.\n" "When specifying an index, negative value corresponds to index from the" " end of the list.\n" "REMOVE_AT and REMOVE_ITEM will remove items from the list. The " "difference is that REMOVE_ITEM will remove the given items, while " "REMOVE_AT will remove the items at the given indices.\n" + "REVERSE reverses the contents of the list in-place.\n" + "SORT sorts the list in-place alphabetically.\n" ; } @@ -90,6 +94,7 @@ protected: bool HandleLengthCommand(std::vector<std::string> const& args); bool HandleGetCommand(std::vector<std::string> const& args); bool HandleAppendCommand(std::vector<std::string> const& args); + bool HandleContainsCommand(std::vector<std::string> const& args); bool HandleInsertCommand(std::vector<std::string> const& args); bool HandleRemoveAtCommand(std::vector<std::string> const& args); bool HandleRemoveItemCommand(std::vector<std::string> const& args); |