Alex Rebert 2021-10-28 23:13:29 -04:00
parent 107371657b
commit 6a3ac623b9
No known key found for this signature in database
GPG Key ID: E082090D746F1A81
2 changed files with 14 additions and 9 deletions

View File

@ -292,12 +292,15 @@ char *OpenDDLParser::parseHeader(char *in, char *end) {
Property *first(nullptr); Property *first(nullptr);
in = lookForNextToken(in, end); in = lookForNextToken(in, end);
if (*in == Grammar::OpenPropertyToken[0]) { if (in != end && *in == Grammar::OpenPropertyToken[0]) {
in++; in++;
Property *prop(nullptr), *prev(nullptr); Property *prop(nullptr), *prev(nullptr);
while (*in != Grammar::ClosePropertyToken[0] && in != end) { while (in != end && *in != Grammar::ClosePropertyToken[0]) {
in = OpenDDLParser::parseProperty(in, end, &prop); in = OpenDDLParser::parseProperty(in, end, &prop);
in = lookForNextToken(in, end); in = lookForNextToken(in, end);
if(in == end) {
break;
}
if (*in != Grammar::CommaSeparator[0] && *in != Grammar::ClosePropertyToken[0]) { if (*in != Grammar::CommaSeparator[0] && *in != Grammar::ClosePropertyToken[0]) {
logInvalidTokenError(in, Grammar::ClosePropertyToken, m_logCallback); logInvalidTokenError(in, Grammar::ClosePropertyToken, m_logCallback);
@ -314,8 +317,10 @@ char *OpenDDLParser::parseHeader(char *in, char *end) {
prev = prop; prev = prop;
} }
} }
if(in != end) {
++in; ++in;
} }
}
// set the properties // set the properties
if (nullptr != first && nullptr != node) { if (nullptr != first && nullptr != node) {
@ -479,7 +484,7 @@ void OpenDDLParser::normalizeBuffer(std::vector<char> &buffer) {
// check for a comment // check for a comment
if (isCommentOpenTag(c, end)) { if (isCommentOpenTag(c, end)) {
++readIdx; ++readIdx;
while (!isCommentCloseTag(&buffer[readIdx], end)) { while (readIdx < len && !isCommentCloseTag(&buffer[readIdx], end)) {
++readIdx; ++readIdx;
} }
++readIdx; ++readIdx;
@ -489,7 +494,7 @@ void OpenDDLParser::normalizeBuffer(std::vector<char> &buffer) {
if (isComment<char>(c, end)) { if (isComment<char>(c, end)) {
++readIdx; ++readIdx;
// skip the comment and the rest of the line // skip the comment and the rest of the line
while (!isEndofLine(buffer[readIdx])) { while (readIdx < len && !isEndofLine(buffer[readIdx])) {
++readIdx; ++readIdx;
} }
} }
@ -548,8 +553,7 @@ char *OpenDDLParser::parseIdentifier(char *in, char *end, Text **id) {
// get size of id // get size of id
size_t idLen(0); size_t idLen(0);
char *start(in); char *start(in);
while (!isSeparator(*in) && while ((in != end) && !isSeparator(*in) && !isNewLine(*in) &&
!isNewLine(*in) && (in != end) &&
*in != Grammar::OpenPropertyToken[0] && *in != Grammar::OpenPropertyToken[0] &&
*in != Grammar::ClosePropertyToken[0] && *in != Grammar::ClosePropertyToken[0] &&
*in != '$') { *in != '$') {
@ -861,7 +865,7 @@ char *OpenDDLParser::parseProperty(char *in, char *end, Property **prop) {
in = parseIdentifier(in, end, &id); in = parseIdentifier(in, end, &id);
if (nullptr != id) { if (nullptr != id) {
in = lookForNextToken(in, end); in = lookForNextToken(in, end);
if (*in == '=') { if (in != end && *in == '=') {
++in; ++in;
in = getNextToken(in, end); in = getNextToken(in, end);
Value *primData(nullptr); Value *primData(nullptr);

View File

@ -318,7 +318,8 @@ static const unsigned char chartype_table[256] = {
template <class T> template <class T>
inline bool isNumeric(const T in) { inline bool isNumeric(const T in) {
return (chartype_table[static_cast<size_t>(in)] == 1); size_t idx = static_cast<size_t>(in);
return idx < sizeof(chartype_table) && (chartype_table[idx] == 1);
} }
template <class T> template <class T>