File: valid.cc

package info (click to toggle)
aegis 4.24-5
  • links: PTS
  • area: main
  • in suites: lenny
  • size: 37,640 kB
  • ctags: 12,410
  • sloc: cpp: 178,288; sh: 79,325; makefile: 34,810; yacc: 4,605; perl: 1,499; ansic: 492; awk: 325
file content (51 lines) | stat: -rw-r--r-- 1,392 bytes parent folder | download | duplicates (3)
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
//
//	aegis - project change supervisor
//	Copyright (C) 2004-2008 Peter Miller
//
//	This program is free software; you can redistribute it and/or modify
//	it under the terms of the GNU General Public License as published by
//	the Free Software Foundation; either version 3 of the License, or
//	(at your option) any later version.
//
//	This program is distributed in the hope that it will be useful,
//	but WITHOUT ANY WARRANTY; without even the implied warranty of
//	MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.  See the
//	GNU General Public License for more details.
//
//	You should have received a copy of the GNU General Public License
//	along with this program. If not, see
//	<http://www.gnu.org/licenses/>.
//

#include <common/symtab.h>


bool
symtab_ty::valid()
    const
{
    if (hash_table == 0)
	return false;
    if (hash_modulus == 0)
	return false;
    // the hash_modulus is required to be a power of two
    if ((hash_modulus & (hash_modulus - 1)) != 0)
	return false;
    if (hash_mask + 1 != hash_modulus)
	return false;
    if (hash_load >= hash_modulus)
	return false;
    str_hash_ty count = 0;
    for (str_hash_ty j = 0; j < hash_modulus; ++j)
    {
	for (row_t *rp = hash_table[j]; rp; rp = rp->overflow)
	{
	    if (rp->data == 0)
		return false;
	    if (!rp->key.valid())
		return false;
	    ++count;
	}
    }
    return (count == hash_load);
}