File: clb_numxtrees.h

package info (click to toggle)
eprover 2.6%2Bds-3
  • links: PTS, VCS
  • area: main
  • in suites: bookworm
  • size: 21,288 kB
  • sloc: ansic: 331,111; csh: 12,026; python: 10,178; awk: 5,825; makefile: 461; sh: 389
file content (93 lines) | stat: -rw-r--r-- 2,951 bytes parent folder | download | duplicates (2)
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
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
/*-----------------------------------------------------------------------

File  : clb_numxtrees.h

Author: Stephan Schulz

Contents

  Definitions for SPLAY trees with long integer keys and vectors of
  IntOrPs as values. Copied from clb_numtrees.h

  Copyright 1998, 1999, 2011 by the author.
  This code is released under the GNU General Public Licence and
  the GNU Lesser General Public License.
  See the file COPYING in the main E directory for details..
  Run "eprover -h" for contact information.

Changes

<1> Mon Aug  1 11:04:53 CEST 2011
    New from clb_numtrees.h

-----------------------------------------------------------------------*/

#ifndef CLB_NUMXTREES

#define CLB_NUMXTREES

#include <clb_dstrings.h>
#include <clb_avlgeneric.h>

/*---------------------------------------------------------------------*/
/*                    Data type declarations                           */
/*---------------------------------------------------------------------*/




/*---------------------------------------------------------------------*/
/*                Exported Functions and Variables                     */
/*---------------------------------------------------------------------*/


#define NUMXTREEVALUES 4

/* General purpose data structure for indexing objects by a numerical
   key. Integer values are supported directly, for all other objects
   pointers can be used (and need to be casted carefully by the
   wrapper functions). Objects pointed to by the value fields are not
   part of the data stucture and will not be touched by deallocating
   trees or tree nodes. */

typedef struct numxtreecell
{
   long                key;
   IntOrP              vals[NUMXTREEVALUES];
   struct numxtreecell *lson;
   struct numxtreecell *rson;
}NumXTreeCell, *NumXTree_p;


#define NumXTreeCellAlloc() (NumXTreeCell*)SizeMalloc(sizeof(NumXTreeCell))
#define NumXTreeCellFree(junk)        SizeFree(junk, sizeof(NumXTreeCell))


NumXTree_p NumXTreeCellAllocEmpty(void);
void      NumXTreeFree(NumXTree_p junk);
NumXTree_p NumXTreeInsert(NumXTree_p *root, NumXTree_p newnode);
bool       NumXTreeStore(NumXTree_p *root, long key, IntOrP val1, IntOrP val2);
NumXTree_p NumXTreeFind(NumXTree_p *root, long key);
NumXTree_p NumXTreeExtractEntry(NumXTree_p *root, long key);
NumXTree_p NumXTreeExtractRoot(NumXTree_p *root);
bool      NumXTreeDeleteEntry(NumXTree_p *root, long key);
long      NumXTreeNodes(NumXTree_p root);
NumXTree_p NumXTreeMaxNode(NumXTree_p root);
#define   NumXTreeMaxKey(tree) (NumXTreeMaxNode(tree)->key)

PStack_p NumXTreeLimitedTraverseInit(NumXTree_p root, long limit);

AVL_TRAVERSE_DECLARATION(NumXTree, NumXTree_p)
#define NumXTreeTraverseExit(stack) PStackFree(stack)


#endif

/*---------------------------------------------------------------------*/
/*                        End of File                                  */
/*---------------------------------------------------------------------*/