mirror of
https://github.com/UberGames/lilium-voyager.git
synced 2025-01-10 02:30:43 +00:00
65 lines
2 KiB
C
65 lines
2 KiB
C
#ifndef BURG_INCLUDED
|
|
#define BURG_INCLUDED
|
|
|
|
/* iburg.c: */
|
|
extern void *alloc(int nbytes);
|
|
|
|
typedef enum { TERM=1, NONTERM } Kind;
|
|
typedef struct rule *Rule;
|
|
typedef struct term *Term;
|
|
struct term { /* terminals: */
|
|
char *name; /* terminal name */
|
|
Kind kind; /* TERM */
|
|
int esn; /* external symbol number */
|
|
int arity; /* operator arity */
|
|
Term link; /* next terminal in esn order */
|
|
Rule rules; /* rules whose pattern starts with term */
|
|
};
|
|
|
|
typedef struct nonterm *Nonterm;
|
|
struct nonterm { /* nonterminals: */
|
|
char *name; /* nonterminal name */
|
|
Kind kind; /* NONTERM */
|
|
int number; /* identifying number */
|
|
int lhscount; /* # times nt appears in a rule lhs */
|
|
int reached; /* 1 iff reached from start nonterminal */
|
|
Rule rules; /* rules w/nonterminal on lhs */
|
|
Rule chain; /* chain rules w/nonterminal on rhs */
|
|
Nonterm link; /* next terminal in number order */
|
|
};
|
|
extern Nonterm nonterm(char *id);
|
|
extern Term term(char *id, int esn);
|
|
|
|
typedef struct tree *Tree;
|
|
struct tree { /* tree patterns: */
|
|
void *op; /* a terminal or nonterminal */
|
|
Tree left, right; /* operands */
|
|
int nterms; /* number of terminal nodes in this tree */
|
|
};
|
|
extern Tree tree(char *op, Tree left, Tree right);
|
|
|
|
struct rule { /* rules: */
|
|
Nonterm lhs; /* lefthand side nonterminal */
|
|
Tree pattern; /* rule pattern */
|
|
int ern; /* external rule number */
|
|
int packed; /* packed external rule number */
|
|
int cost; /* cost, if a constant */
|
|
char *code; /* cost, if an expression */
|
|
char *template; /* assembler template */
|
|
Rule link; /* next rule in ern order */
|
|
Rule next; /* next rule with same pattern root */
|
|
Rule chain; /* next chain rule with same rhs */
|
|
Rule decode; /* next rule with same lhs */
|
|
Rule kids; /* next rule with same _kids pattern */
|
|
};
|
|
extern Rule rule(char *id, Tree pattern, char *template, char *code);
|
|
|
|
/* gram.y: */
|
|
void yyerror(char *fmt, ...);
|
|
int yyparse(void);
|
|
void yywarn(char *fmt, ...);
|
|
extern int errcnt;
|
|
extern FILE *infp;
|
|
extern FILE *outfp;
|
|
|
|
#endif
|