8
0
mirror of https://github.com/FirebirdSQL/firebird.git synced 2025-01-24 06:03:02 +01:00

Fixed CORE-4102: Bad optimization of OR predicates applied to unions.

This commit is contained in:
dimitr 2013-05-23 08:25:56 +00:00
parent 8a395f40f7
commit 525a178114

View File

@ -4204,7 +4204,39 @@ static void gen_deliver_unmapped(thread_db* tdbb, NodeStack* deliverStack,
for (NodeStack::iterator stack1(*parentStack); stack1.hasData(); ++stack1) for (NodeStack::iterator stack1(*parentStack); stack1.hasData(); ++stack1)
{ {
jrd_nod* boolean = stack1.object(); jrd_nod* const boolean = stack1.object();
// Handle the "OR" case first
if (boolean->nod_type == nod_or)
{
NodeStack org_stack, new_stack;
org_stack.push(boolean->nod_arg[0]);
org_stack.push(boolean->nod_arg[1]);
gen_deliver_unmapped(tdbb, &new_stack, map, &org_stack, shellStream);
if (new_stack.getCount() == 2)
{
jrd_nod* const deliverNode = PAR_make_node(tdbb, boolean->nod_count);
deliverNode->nod_count = boolean->nod_count;
deliverNode->nod_type = boolean->nod_type;
deliverNode->nod_flags = boolean->nod_flags;
deliverNode->nod_impure = boolean->nod_impure;
deliverNode->nod_arg[1] = new_stack.pop();
deliverNode->nod_arg[0] = new_stack.pop();
deliverStack->push(deliverNode);
}
else
{
while (new_stack.hasData())
delete new_stack.pop();
}
continue;
}
// Reduce to simple comparisons // Reduce to simple comparisons
if (!((boolean->nod_type == nod_eql) || if (!((boolean->nod_type == nod_eql) ||
@ -4243,7 +4275,6 @@ static void gen_deliver_unmapped(thread_db* tdbb, NodeStack* deliverStack,
bool wrongNode = false; bool wrongNode = false;
for (indexArg = 0; (indexArg < boolean->nod_count) && (!wrongNode); indexArg++) for (indexArg = 0; (indexArg < boolean->nod_count) && (!wrongNode); indexArg++)
{ {
jrd_nod* booleanNode = jrd_nod* booleanNode =
get_unmapped_node(tdbb, boolean->nod_arg[indexArg], map, shellStream, true); get_unmapped_node(tdbb, boolean->nod_arg[indexArg], map, shellStream, true);