Mercurial > ~dholland > hg > ag > index.cgi
diff tests/agcl/parsifal/good/ss-fp.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/parsifal/good/ss-fp.h Sat Dec 22 17:52:45 2007 -0500 @@ -0,0 +1,74 @@ +#ifndef SS-FP_H +#define SS-FP_H + +typedef union { + double alignment; + char ag_vt_2[sizeof(int)]; + char ag_vt_4[sizeof(number)]; + char ag_vt_5[sizeof(format_code)]; + char ag_vt_6[sizeof(pair<int>)]; + char ag_vt_7[sizeof(char *)]; + char ag_vt_8[sizeof(function_name)]; + char ag_vt_9[sizeof(double)]; +} ss-fp_vs_type; + +typedef enum { + ss-fp_space_token = 1, ss-fp_grammar_token, ss-fp_cell_name_token = 4, + ss-fp_eof_token, ss-fp_input_line_token = 7, + ss-fp_conditional_expression_token, ss-fp_to_token = 14, + ss-fp_format_token = 18, ss-fp_alignment_token = 23, + ss-fp_conversion_token = 26, ss-fp_integer_token = 28, + ss-fp_column_id_token = 34, ss-fp_letter_token, ss-fp_digit_token = 37, + ss-fp_x_expression_token, ss-fp_expression_token, ss-fp_disjunction_token, + ss-fp_conjunction_token = 42, ss-fp_logical_value_token = 44, + ss-fp_comparison_token = 46, ss-fp_partial_comparison_token = 50, + ss-fp_summation_token = 57, ss-fp_term_token = 60, ss-fp_xxfactor_token, + ss-fp_xfactor_token = 63, ss-fp_function_token, ss-fp_factor_token, + ss-fp_yfactor_token, ss-fp_base_token, ss-fp_simple_factor_token = 69, + ss-fp_r_value_token, ss-fp_l_value_token, ss-fp_c_value_token, + ss-fp_number_token, ss-fp_parens_token, ss-fp_sigma_token = 76, + ss-fp_bound_variable_token, ss-fp_x_expression_string_token, + ss-fp_integer_part_token = 99, ss-fp_decimal_point_token, + ss-fp_fraction_part_token = 102, ss-fp_cell_name_request_token = 109, + ss-fp_input_line_request_token, ss-fp_block_request_token = 112, + ss-fp_nonzero_digit_token = 125, ss-fp_pi_token = 142 +} ss-fp_token_type; + +typedef struct ss-fp_pcb_struct{ + ss-fp_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]; + ss-fp_vs_type vs[128]; + int ag_ap; + const char *error_message; + char read_flag; + char exit_flag; + unsigned char * pointer; + unsigned char * la_ptr; + const unsigned char *key_sp; + int save_index, key_state; +} ss-fp_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 +void init_ss-fp(void); +void ss-fp(void); +#endif +