3
0
Fork 0
mirror of https://github.com/Z3Prover/z3 synced 2025-04-06 17:44:08 +00:00

new hashtable.h invariants (#7296)

* add copyright for dlist unit test

* new hashtable invariants

* add copyright
This commit is contained in:
LiviaSun 2024-07-19 14:01:42 -07:00 committed by GitHub
parent 08b6338061
commit bc636d7ee0
No known key found for this signature in database
GPG key ID: B5690EEEBB952194
2 changed files with 31 additions and 0 deletions

View file

@ -1,3 +1,20 @@
/*++
Copyright (c) 2024 Microsoft Corporation
Module Name:
tst_dlist.cpp
Abstract:
Test dlist module
Author:
Chuyue Sun 2024-07-18.
--*/
#include <cassert>
#include <iostream>
#include "util/dlist.h"

View file

@ -12,6 +12,7 @@ Abstract:
Author:
Leonardo de Moura (leonardo) 2006-09-11.
Chuyue Sun (liviasun) 2024-07-18.
Revision History:
@ -639,6 +640,19 @@ public:
#ifdef Z3DEBUG
bool check_invariant() {
// The capacity must always be a power of two.
if (!is_power_of_two(m_capacity))
return false;
// The number of deleted plus the size must not exceed the capacity.
if (m_num_deleted + m_size > m_capacity)
return false;
// Checking that m_num_deleted is less than or equal to m_size.
if (m_num_deleted > m_size) {
return false;
}
entry * curr = m_table;
entry * end = m_table + m_capacity;
unsigned num_deleted = 0;