forked from zeek/zeek
-
Notifications
You must be signed in to change notification settings - Fork 0
/
Copy pathEquivClass.h
43 lines (32 loc) · 1.05 KB
/
EquivClass.h
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
// See the file "COPYING" in the main distribution directory for copyright.
#pragma once
#include <stdio.h>
class CCL;
class EquivClass {
public:
explicit EquivClass(int size);
~EquivClass();
void UniqueChar(int sym);
void CCL_Use(CCL* ccl);
// All done adding character usage info - generate equivalence
// classes. Returns number of classes.
int BuildECs();
void ConvertCCL(CCL* ccl);
int IsRep(int sym) const { return rep[sym] == sym; }
int EquivRep(int sym) const { return rep[sym]; }
int SymEquivClass(int sym) const { return equiv_class[sym]; }
int* EquivClasses() const { return equiv_class; }
int NumSyms() const { return size; }
int NumClasses() const { return num_ecs; }
void Dump(FILE* f);
int Size() const;
protected:
int size; // size of character set
int num_ecs; // size of equivalence classes
int* fwd; // forward list of different classes
int* bck; // backward list
int* equiv_class; // symbol's equivalence class
int* rep; // representative for symbol's equivalence class
int* ccl_flags;
int ec_nil, no_class, no_rep;
};