When running rql_test sometimes the split function gets stuck and gets to a point of out of memory.
After a lot of debugging i found out that the way the equalExp function implemented is wrong.
The check
if s1[i][0] == '(' && s2[j][0] == '(' {
found = equalExp(s1[i][1:len(s1[i])-1], s2[j][1:len(s2[j])-1])
}
is wrong because if we get ( at the start we are removing the end of the string, not the next ) found which is the problem
there is a corruption of data (a = b AND c = d) OR (a = c AND (c = d OR d = f)) will be a = b AND c = d) OR (a = c AND (c = d OR d = f)
The problem starts here and get to the split function which is not validating the given data and not breaking out of the while loop after it failes at the start with finding )
When running rql_test sometimes the
splitfunction gets stuck and gets to a point of out of memory.After a lot of debugging i found out that the way the
equalExpfunction implemented is wrong.The check
is wrong because if we get
(at the start we are removing the end of the string, not the next)found which is the problemthere is a corruption of data
(a = b AND c = d) OR (a = c AND (c = d OR d = f))will bea = b AND c = d) OR (a = c AND (c = d OR d = f)The problem starts here and get to the
splitfunction which is not validating the given data and not breaking out of thewhileloop after it failes at the start with finding)