summaryrefslogtreecommitdiffstats
path: root/Source/cmListCommand.cxx
diff options
context:
space:
mode:
Diffstat (limited to 'Source/cmListCommand.cxx')
-rw-r--r--Source/cmListCommand.cxx31
1 files changed, 17 insertions, 14 deletions
diff --git a/Source/cmListCommand.cxx b/Source/cmListCommand.cxx
index 1e8b7eb..a252dc0 100644
--- a/Source/cmListCommand.cxx
+++ b/Source/cmListCommand.cxx
@@ -205,27 +205,30 @@ bool cmListCommand::HandleInsertCommand(std::vector<std::string> const& args)
// expand the variable
int item = atoi(args[2].c_str());
std::vector<std::string> varArgsExpanded;
- if ( !this->GetList(varArgsExpanded, listName.c_str()) && (item > 0 || item < -1))
+ if ( !this->GetList(varArgsExpanded, listName.c_str()) && item != 0)
{
cmOStringStream str;
- str << "index: " << item << " out of range (-1, 0)";
+ str << "index: " << item << " out of range (0, 0)";
this->SetError(str.str().c_str());
return false;
}
- size_t nitem = varArgsExpanded.size();
- if ( item < 0 )
+ if ( varArgsExpanded.size() != 0 )
{
- item = (int)nitem + item;
- }
- if ( item < 0 || nitem <= (size_t)item )
- {
- cmOStringStream str;
- str << "index: " << item << " out of range (-"
- << varArgsExpanded.size() << ", "
- << varArgsExpanded.size()-1 << ")";
- this->SetError(str.str().c_str());
- return false;
+ size_t nitem = varArgsExpanded.size();
+ if ( item < 0 )
+ {
+ item = (int)nitem + item;
+ }
+ if ( item < 0 || nitem <= (size_t)item )
+ {
+ cmOStringStream str;
+ str << "index: " << item << " out of range (-"
+ << varArgsExpanded.size() << ", "
+ << (varArgsExpanded.size() == 0?0:(varArgsExpanded.size()-1)) << ")";
+ this->SetError(str.str().c_str());
+ return false;
+ }
}
size_t cc;
size_t cnt = 0;