summaryrefslogtreecommitdiffstats
diff options
context:
space:
mode:
authorStephen Kelly <steveire@gmail.com>2015-01-24 17:43:37 (GMT)
committerStephen Kelly <steveire@gmail.com>2015-02-15 13:28:50 (GMT)
commit1cecd3a53107f7f670cf011201c1da3a33b795b6 (patch)
treec51c2b1aaa9eaf8c8ad1755ea72da2a9f6b68b5c
parentbe3d4b665f27b9ea301540d5bf8154491ed815e0 (diff)
downloadCMake-1cecd3a53107f7f670cf011201c1da3a33b795b6.zip
CMake-1cecd3a53107f7f670cf011201c1da3a33b795b6.tar.gz
CMake-1cecd3a53107f7f670cf011201c1da3a33b795b6.tar.bz2
cmListCommand: Use std::find algorithm for FIND subcommand.
Use a ostringstream to account for the input being a variable of type size_t as a result of using std::distance. There is no single format string which portably accepts a size_t.
-rw-r--r--Source/cmListCommand.cxx18
1 files changed, 7 insertions, 11 deletions
diff --git a/Source/cmListCommand.cxx b/Source/cmListCommand.cxx
index dd0cfa9..ae13fdf 100644
--- a/Source/cmListCommand.cxx
+++ b/Source/cmListCommand.cxx
@@ -284,18 +284,14 @@ bool cmListCommand::HandleFindCommand(std::vector<std::string> const& args)
return true;
}
- std::vector<std::string>::iterator it;
- unsigned int index = 0;
- for ( it = varArgsExpanded.begin(); it != varArgsExpanded.end(); ++ it )
+ std::vector<std::string>::iterator it =
+ std::find(varArgsExpanded.begin(), varArgsExpanded.end(), args[2]);
+ if (it != varArgsExpanded.end())
{
- if ( *it == args[2] )
- {
- char indexString[32];
- sprintf(indexString, "%d", index);
- this->Makefile->AddDefinition(variableName, indexString);
- return true;
- }
- index++;
+ std::ostringstream indexStream;
+ indexStream << std::distance(varArgsExpanded.begin(), it);
+ this->Makefile->AddDefinition(variableName, indexStream.str().c_str());
+ return true;
}
this->Makefile->AddDefinition(variableName, "-1");