From 2b4e802a947ad5fd86b1ed296ea2f31714270dfa Mon Sep 17 00:00:00 2001 From: Bill Hoffman Date: Mon, 1 Apr 2002 14:50:00 -0500 Subject: ENH: fix for regkey and ; separation --- Source/cmSystemTools.cxx | 59 ++++++++++++++++++++++++++++++++++++------------ 1 file changed, 45 insertions(+), 14 deletions(-) diff --git a/Source/cmSystemTools.cxx b/Source/cmSystemTools.cxx index da6ea4c..6a2a56b 100644 --- a/Source/cmSystemTools.cxx +++ b/Source/cmSystemTools.cxx @@ -1785,32 +1785,63 @@ void cmSystemTools::ExpandListArguments(std::vector const& argument std::vector::const_iterator i; for(i = arguments.begin();i != arguments.end(); ++i) { - if(i->find(';') != std::string::npos) + // if there are no ; in the name then just copy the current string + if(i->find(';') == std::string::npos) + { + newargs.push_back(*i); + } + else { std::string::size_type start = 0; std::string::size_type endpos = 0; - while(endpos != std::string::npos) + const std::string::size_type size = i->size(); + // break up ; separated sections of the string into separate strings + while(endpos != size) { endpos = i->find(';', start); - std::string::size_type len; - if(endpos != std::string::npos) + if(endpos == std::string::npos) { - len = endpos - start; - } - else - { - len = i->size()-start; + endpos = i->size(); } + std::string::size_type len = endpos - start; if (len > 0) { - newargs.push_back(i->substr(start, len)); + // check for a closing ] after the start position + if(i->find('[', start) == std::string::npos) + { + // if there is no [ in the string then keep it + newargs.push_back(i->substr(start, len)); + } + else + { + int opencount = 0; + int closecount = 0; + for(std::string::size_type j = start; j < endpos; ++j) + { + if(i->at(j) == '[') + { + ++opencount; + } + else if (i->at(j) == ']') + { + ++closecount; + } + } + if(opencount != closecount) + { + // skip this one + endpos = i->find(';', endpos+1); + if(endpos == std::string::npos) + { + endpos = i->size(); + } + len = endpos - start; + } + newargs.push_back(i->substr(start, len)); + } } start = endpos+1; } } - else - { - newargs.push_back(*i); - } } } -- cgit v0.12