mirror of
https://gitlab.nic.cz/labs/bird.git
synced 2025-01-07 01:21:54 +00:00
Refactor and fix aggregator_bucket_unionize()
This commit is contained in:
parent
45c7a5463e
commit
6d5e75e46d
@ -275,16 +275,32 @@ aggregator_bucket_unionize(struct trie_node *node, const struct trie_node *left,
|
|||||||
|
|
||||||
int res = aggregator_bucket_compare(left->potential_buckets[i], right->potential_buckets[j]);
|
int res = aggregator_bucket_compare(left->potential_buckets[i], right->potential_buckets[j]);
|
||||||
|
|
||||||
if (res == 0)
|
switch (res)
|
||||||
{
|
{
|
||||||
|
case 0:
|
||||||
|
if (node->potential_buckets_count == 0 || node->potential_buckets[node->potential_buckets_count - 1] != left->potential_buckets[i])
|
||||||
node->potential_buckets[node->potential_buckets_count++] = left->potential_buckets[i];
|
node->potential_buckets[node->potential_buckets_count++] = left->potential_buckets[i];
|
||||||
|
|
||||||
i++;
|
i++;
|
||||||
j++;
|
j++;
|
||||||
}
|
break;
|
||||||
else if (res == -1)
|
|
||||||
node->potential_buckets[node->potential_buckets_count++] = left->potential_buckets[i++];
|
case -1:
|
||||||
else if (res == 1)
|
if (node->potential_buckets_count == 0 || node->potential_buckets[node->potential_buckets_count - 1] != left->potential_buckets[i])
|
||||||
node->potential_buckets[node->potential_buckets_count++] = right->potential_buckets[j++];
|
node->potential_buckets[node->potential_buckets_count++] = left->potential_buckets[i];
|
||||||
|
|
||||||
|
i++;
|
||||||
|
break;
|
||||||
|
|
||||||
|
case 1:
|
||||||
|
if (node->potential_buckets_count == 0 || node->potential_buckets[node->potential_buckets_count - 1] != right->potential_buckets[j])
|
||||||
|
node->potential_buckets[node->potential_buckets_count++] = right->potential_buckets[j];
|
||||||
|
|
||||||
|
j++;
|
||||||
|
break;
|
||||||
|
|
||||||
|
default:
|
||||||
|
bug("Impossible");
|
||||||
}
|
}
|
||||||
|
|
||||||
while (i < left->potential_buckets_count)
|
while (i < left->potential_buckets_count)
|
||||||
@ -292,7 +308,10 @@ aggregator_bucket_unionize(struct trie_node *node, const struct trie_node *left,
|
|||||||
if (node->potential_buckets_count >= MAX_POTENTIAL_NEXTHOP_COUNT)
|
if (node->potential_buckets_count >= MAX_POTENTIAL_NEXTHOP_COUNT)
|
||||||
return;
|
return;
|
||||||
|
|
||||||
node->potential_buckets[node->potential_buckets_count++] = left->potential_buckets[i++];
|
if (node->potential_buckets_count == 0 || node->potential_buckets[node->potential_buckets_count - 1] != left->potential_buckets[i])
|
||||||
|
node->potential_buckets[node->potential_buckets_count++] = left->potential_buckets[i];
|
||||||
|
|
||||||
|
i++;
|
||||||
}
|
}
|
||||||
|
|
||||||
while (j < right->potential_buckets_count)
|
while (j < right->potential_buckets_count)
|
||||||
@ -300,7 +319,11 @@ aggregator_bucket_unionize(struct trie_node *node, const struct trie_node *left,
|
|||||||
if (node->potential_buckets_count >= MAX_POTENTIAL_NEXTHOP_COUNT)
|
if (node->potential_buckets_count >= MAX_POTENTIAL_NEXTHOP_COUNT)
|
||||||
return;
|
return;
|
||||||
|
|
||||||
node->potential_buckets[node->potential_buckets_count++] = right->potential_buckets[j++];
|
if (node->potential_buckets_count == 0 || node->potential_buckets[node->potential_buckets_count - 1] != right->potential_buckets[j])
|
||||||
|
node->potential_buckets[node->potential_buckets_count++] = right->potential_buckets[j];
|
||||||
|
|
||||||
|
j++;
|
||||||
|
}
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
|
Loading…
Reference in New Issue
Block a user