diff tests/agcl/examples/good/mas.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/mas.h	Sat Dec 22 17:52:45 2007 -0500
@@ -0,0 +1,60 @@
+#ifndef MAS_H
+#define MAS_H
+
+typedef union {
+  long alignment;
+  char ag_vt_4[sizeof(token)];
+  char ag_vt_5[sizeof(unsigned)];
+} mas_vs_type;
+
+typedef enum {
+  mas_space_token = 1, mas_grammar_token, mas_parse_unit_token,
+  mas_eof_token = 6, mas_parameter_expansion_token = 8,
+  mas_simple_parse_unit_token, mas_concatenation_token, mas_macro_token,
+  mas_parameter_name_token = 14, mas_variable_token, mas_simple_macro_token,
+  mas_macro_arg_list_token = 18, mas_defined_token = 20,
+  mas_macro_name_token, mas_NAME_token, mas_left_side_token,
+  mas_right_side_token, mas_CONCAT_token, mas_not_parameter_token,
+  mas_arg_elements_token, mas_initial_arg_element_token = 29,
+  mas_nested_elements_token = 31, mas_arg_element_token
+} mas_token_type;
+
+typedef struct mas_pcb_struct{
+  mas_token_type token_number, reduction_token, error_frame_token;
+  int input_code;
+  token input_value;
+  int line, column;
+  int ssx, sn, error_frame_ssx;
+  int drt, dssx, dsn;
+  int ss[128];
+  mas_vs_type vs[128];
+  int ag_ap;
+  const char *error_message;
+  char read_flag;
+  char exit_flag;
+  token * pointer;
+  token * la_ptr;
+  char ag_msg[82];
+  const  int *ag_dtl;
+  int ag_dsn;
+} mas_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_mas(void);
+void mas(void);
+#endif
+