File: cle_indexfunctions.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 (120 lines) | stat: -rw-r--r-- 3,589 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
94
95
96
97
98
99
100
101
102
103
104
105
106
107
108
109
110
111
112
113
114
115
116
117
118
119
120
/*-----------------------------------------------------------------------

  File  : cle_indexfunctions.h

  Author: Stephan Schulz

  Contents

  Functions and data types realizing simple index functions.

  Copyright 1998, 1999 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.

  Created: Wed Aug  4 15:36:51 MET DST 1999

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

#ifndef CLE_INDEXFUNCTIONS

#define CLE_INDEXFUNCTIONS

#include <clb_simple_stuff.h>
#include <clb_objtrees.h>
#include <cle_patterns.h>
#include <cle_termtops.h>


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

typedef enum
{
   IndexNoIndex  =   0,
   IndexArity    =   1,
   IndexSymbol   =   2,
   IndexTop      =   4,
   IndexAltTop   =   8,
   IndexCSTop    =  16,
   IndexESTop    =  32,
   IndexIdentity =  64,
   IndexEmpty    = 128
}IndexType;


typedef struct indextermcell
{
   Term_p   term;         /* Usually has reference if malloced() */
   PatternSubst_p subst;  /* Shared, necessary for object-tree
                             comparison */
   long           key;    /* The returned index number */
}IndexTermCell, *IndexTerm_p;


/* Operations on index:

   - insert(term, patternsubst) -> value >=0,
   - find(term, patternsubst) -> value or -1

   All values should populate 0...max{values} somewhat densely

*/


typedef struct tsmindexcell
{
   long           ident;
   IndexType      type;
   int            depth;
   long           count;
   TB_p           bank;       /* Shared, only here for convenience */
   PatternSubst_p subst;      /* Ditto */
   union
   {
      PTree_p     t_index;    /* Map IndexTerms onto index number */
      NumTree_p   n_index;    /* Map f_codes onto number */
   }              tree;
}TSMIndexCell, *TSMIndex_p;

#define IndexDynamicDepth 0


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

extern char* IndexFunNames[];

#define IndexTermCellAlloc()    (IndexTermCell*)SizeMalloc(sizeof(IndexTermCell))
#define IndexTermCellFree(junk) SizeFree(junk, sizeof(IndexTermCell))

int GetIndexType(char* name);

IndexTerm_p IndexTermAlloc(Term_p term, PatternSubst_p subst, long
                           key);
void         IndexTermFree(IndexTerm_p junk, TB_p bank);

int          IndexTermCompareFun(const void* term1, const void* term2);

#define TSMIndexCellAlloc()    (TSMIndexCell*)SizeMalloc(sizeof(TSMIndexCell))
#define TSMIndexCellFree(junk) SizeFree(junk, sizeof(TSMIndexCell))

TSMIndex_p TSMIndexAlloc(IndexType type, int depth, TB_p bank,
                         PatternSubst_p subst);
void       TSMIndexFree(TSMIndex_p junk);

long       TSMIndexFind(TSMIndex_p index, Term_p term, PatternSubst_p
                        subst);
long       TSMIndexInsert(TSMIndex_p index, Term_p term);

void       TSMIndexPrint(FILE* out, TSMIndex_p index, int depth);

#endif

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