Mercurial > ~dholland > hg > ag > index.cgi
diff tests/agcl/examples/good/fc2.h @ 0:13d2b8934445
Import AnaGram (near-)release tree into Mercurial.
author | David A. Holland |
---|---|
date | Sat, 22 Dec 2007 17:52:45 -0500 |
parents | |
children |
line wrap: on
line diff
--- /dev/null Thu Jan 01 00:00:00 1970 +0000 +++ b/tests/agcl/examples/good/fc2.h Sat Dec 22 17:52:45 2007 -0500 @@ -0,0 +1,46 @@ +#ifndef FC2_H +#define FC2_H + +typedef enum { + fc2_grammar_token = 1, fc2_temperature_token, fc2_eof_token = 7, + fc2_number_token, fc2_error_token = 11, fc2_integer_token = 13 +} fc2_token_type; + +typedef struct fc2_pcb_struct{ + fc2_token_type token_number, reduction_token, error_frame_token; + int input_code; + int input_value; + int line, column; + int ssx, sn, error_frame_ssx; + int drt, dssx, dsn; + int ss[128]; + int vs[128]; + int ag_ap; + const char *error_message; + char read_flag; + char exit_flag; + int bts[128], btsx; + char ag_msg[82]; +} fc2_pcb_type; + +#ifndef PRULE_CONTEXT +#define PRULE_CONTEXT(pcb) (&((pcb).cs[(pcb).ssx])) +#define PERROR_CONTEXT(pcb) ((pcb).cs[(pcb).error_frame_ssx]) +#define PCONTEXT(pcb) ((pcb).cs[(pcb).ssx]) +#endif + +#ifndef AG_RUNNING_CODE +/* PCB.exit_flag values */ +#define AG_RUNNING_CODE 0 +#define AG_SUCCESS_CODE 1 +#define AG_SYNTAX_ERROR_CODE 2 +#define AG_REDUCTION_ERROR_CODE 3 +#define AG_STACK_ERROR_CODE 4 +#define AG_SEMANTIC_ERROR_CODE 5 +#endif + +extern fc2_pcb_type fc2_pcb; +void init_fc2(void); +void fc2(void); +#endif +