0
0
mirror of https://gitlab.nic.cz/labs/bird.git synced 2025-01-08 18:11:54 +00:00

Add more assertions

This commit is contained in:
Igor Putovny 2024-04-09 11:35:49 +02:00
parent d5930c4f76
commit 24a450a817

View File

@ -297,12 +297,15 @@ first_pass(struct trie_node *node, slab *trie_slab)
if (is_leaf(node)) if (is_leaf(node))
{ {
/*
for (int i = 0; i < node->potential_buckets_count; i++) for (int i = 0; i < node->potential_buckets_count; i++)
{ {
if (node->potential_buckets[i] == node->bucket) if (node->potential_buckets[i] == node->bucket)
return; return;
} }
*/
assert(node->bucket != NULL);
node->potential_buckets[node->potential_buckets_count++] = node->bucket; node->potential_buckets[node->potential_buckets_count++] = node->bucket;
return; return;
} }
@ -513,12 +516,14 @@ second_pass(struct trie_node *node)
assert(node != NULL); assert(node != NULL);
assert(node->potential_buckets_count <= MAX_POTENTIAL_BUCKETS_COUNT); assert(node->potential_buckets_count <= MAX_POTENTIAL_BUCKETS_COUNT);
if (node->parent == NULL) //if (node->parent == NULL)
assert(node->bucket != NULL); //assert(node->bucket != NULL);
if (is_leaf(node)) if (is_leaf(node))
{ {
assert(node->potential_buckets_count > 0); assert(node->potential_buckets_count > 0);
assert(node->potential_buckets[0] != NULL);
assert(node->potential_buckets[0] == node->bucket);
return; return;
} }
@ -593,8 +598,8 @@ third_pass(struct trie_node *node)
if (node == NULL) if (node == NULL)
return; return;
if (node->parent == NULL) //if (node->parent == NULL)
assert(node->bucket != NULL); //assert(node->bucket != NULL);
assert(node->potential_buckets_count <= MAX_POTENTIAL_BUCKETS_COUNT); assert(node->potential_buckets_count <= MAX_POTENTIAL_BUCKETS_COUNT);
@ -602,7 +607,8 @@ third_pass(struct trie_node *node)
if (node->parent == NULL) if (node->parent == NULL)
{ {
assert(node->potential_buckets_count > 0); assert(node->potential_buckets_count > 0);
assert(node->bucket != NULL); assert(node->potential_buckets[0] != NULL);
//assert(node->bucket != NULL);
node->bucket = node->potential_buckets[0]; node->bucket = node->potential_buckets[0];
goto descent; goto descent;
} }