Fix css rule declaration splitting

fixes
Nimetu 3 years ago
parent d0d38238a8
commit 5bf139f690

@ -38,21 +38,57 @@ namespace NLGUI
TStyleVec CCssParser::parseDecls(const std::string &styleString) TStyleVec CCssParser::parseDecls(const std::string &styleString)
{ {
TStyleVec styles; TStyleVec styles;
std::vector<std::string> elements; size_t pos = 0;
NLMISC::splitString(styleString, ";", elements); size_t end = styleString.size();
while(pos < end)
for(uint i = 0; i < elements.size(); ++i)
{ {
std::string::size_type pos; size_t sep = styleString.find(':', pos);
pos = elements[i].find_first_of(':'); if (sep == std::string::npos)
if (pos != std::string::npos) break;
size_t keyIndex = pos;
size_t keyLength = sep - pos;
sep++;
pos = sep;
while(sep < end)
{ {
std::string key = trim(toLower(elements[i].substr(0, pos))); sep = styleString.find_first_of(";'\"(", sep);
std::string value = trim(elements[i].substr(pos+1)); if (sep == std::string::npos || styleString[sep] == ';')
styles.push_back(TStylePair(key, value)); break;
if (styleString[sep] == '\'' || styleString[sep] == '"')
{
char ch = styleString[sep];
// skip open quote
sep++;
while(sep < end && styleString[sep] != ch)
{
if (styleString[sep] == '\\')
sep++;
sep++;
}
// skip close quote
sep++;
}
else if (styleString[sep] == '(')
{
while(sep < end && styleString[sep] != ')')
{
sep++;
}
// skip close parenthesis
sep++;
}
} }
}
styles.push_back(TStylePair(trim(styleString.substr(keyIndex, keyLength)), trim(styleString.substr(pos, sep - pos))));
if (sep >= end)
break;
pos = sep + 1;
}
return styles; return styles;
} }

Loading…
Cancel
Save