/* l2xirexp.h Include file for regular expression code */ #define Atom 256 /* token Atom (an impossible char value) */ #define Epsilon 257 /* epsilon arc (an impossible char value) */ /* track field must be same for all node types */ typedef struct _a { struct _a *track; /* track mem allocation */ int label; struct _a *next; struct _n *target; } Arc, *ArcPtr; typedef struct _n { struct _n *track; ArcPtr arcs, arctail; } Node, *NodePtr; typedef struct { NodePtr left, right; } Graph, *GraphPtr; int rexpr(); int match(); int like_expr();