Mercurial > ~dholland > hg > ag > index.cgi
diff tests/agcl/oldagsrc/good/pgg24-2.cpp @ 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/oldagsrc/good/pgg24-2.cpp Sat Dec 22 17:52:45 2007 -0500 @@ -0,0 +1,3128 @@ +/* + AnaGram Syntax Analyzer. + Copyright (c) Jerome T. Holland, 1989, 1990, 1991, 1992 + All Rights Reserved. +*/ + +//#define INCLUDE_LOGGING + +#include "assert.h" //ASSERT +#include "config.h" +#include "csexp.h" +#include "data.h" //DATA +#include "error.h" +#include "log.hpp" +#include "myalloc.h" +#include "rproc.h" +#include "rule.h" +#include "stk.h" //STK +#include "symbol.h" +#include "token.h" +#include "tree.h" +#include "tsd.h" +#include "ut.h" //UT +#include <ctype.h> //CTYPE +#include <stdio.h> //STDIO +#include <stdlib.h> //STDLIB +#include <string.h> //STRING + +#include "pgg24.h" //PGG + +#undef MODULE +#define MODULE 3 + + +/* + * AnaGram, A System for Syntax Directed Programming + * File generated by: ... + * + * AnaGram Parsing Engine + * Copyright 1993-2002 Parsifal Software. All Rights Reserved. + * + * This software is provided 'as-is', without any express or implied + * warranty. In no event will the authors be held liable for any damages + * arising from the use of this software. + * + * Permission is granted to anyone to use this software for any purpose, + * including commercial applications, and to alter it and redistribute it + * freely, subject to the following restrictions: + * + * 1. The origin of this software must not be misrepresented; you must not + * claim that you wrote the original software. If you use this software + * in a product, an acknowledgment in the product documentation would be + * appreciated but is not required. + * 2. Altered source versions must be plainly marked as such, and must not be + * misrepresented as being the original software. + * 3. This notice may not be removed or altered from any source distribution. + */ + +#ifndef PGG24-2_H +#include "pgg24-2.h" +#endif + +#ifndef PGG24-2_H +#error Mismatched header file +#endif + +#include <ctype.h> +#include <stdio.h> + +#define RULE_CONTEXT (&((PCB).cs[(PCB).ssx])) +#define ERROR_CONTEXT ((PCB).cs[(PCB).error_frame_ssx]) +#define CONTEXT ((PCB).cs[(PCB).ssx]) + + +#define CHANGE_REDUCTION(x) pgg_change_reduction(pgg_##x##_token) +int pgg_change_reduction(pgg_token_type); + +#define TOKEN_NAMES pgg_token_names +const char *const pgg_token_names[248] = { + "syntax definition", + "", + "\"->\"", + "", + "", + "", + "", + "','", + "", + "", + "", + "\"...\"", + "", + "'='", + "", + "'!'", + "", + "'{'", + "", + "'['", + "", + "'('", + "", + "'-'", + "", + "'+'", + "", + "']'", + "", + "'}'", + "", + "')'", + "", + "single quote", + "", + "'~'", + "", + "'|'", + "syntax definition", + "", + "", + "statement list", + "statement", + "", + "eof", + "production", + "definition", + "embedded c", + "configuration section", + "", + "left hand side", + "right hand side", + "", + "", + "", + "token name list", + "type definition", + "", + "symbol name", + "'$'", + "", + "wrapper type", + "wrapper list", + "", + "vp rule spec", + "", + "", + "reduction procedure", + "vp rules", + "grammar rule", + "", + "init grammar rule", + "rule element", + "parameter name", + "c expression", + "';'", + "type name", + "", + "", + "", + "\"::\"", + "", + "", + "", + "", + "template field head", + "'>'", + "'<'", + "", + "", + "'*'", + "", + "", + "letter", + "", + "", + "\"enum\"", + "blank char", + "c comment", + "continuation", + "comment", + "", + "carriage return", + "", + "newline", + "", + "vertical space", + "\"//\"", + "", + "", + "", + "character", + "signed number", + "'^'", + "", + "quoted character", + "char const", + "", + "", + "", + "decimal number", + "octal number", + "\"0x\"", + "\"0X\"", + "", + "hex number", + "", + "", + "'0'", + "", + "hex digit", + "", + "token", + "immediate action", + "set union", + "virtual production", + "set intersection", + "set difference", + "set complement", + "'&'", + "character set", + "", + "escape sequence", + "octal escape", + "", + "hex escape", + "character range", + "\"..\"", + "proc def", + "enum definition", + "enum statement", + "keyword string", + "keyword string head", + "string", + "double quote", + "", + "", + "", + "string char", + "simple string char", + "\"\\\\a\"", + "\"\\\\b\"", + "\"\\\\f\"", + "\"\\\\n\"", + "\"\\\\r\"", + "\"\\\\t\"", + "\"\\\\v\"", + "\"\\\\\\\\\"", + "\"\\\\?\"", + "\"\\\\\\'\"", + "\"\\\\\\\"\"", + "", + "backslash", + "", + "\"\\\\x\"", + "any digit", + "nonoctal digit", + "':'", + "", + "", + "configuration parameters", + "configuration parameter list", + "", + "configuration parameter", + "attribute statement", + "keyword kluge", + "\"distinguish\"", + "\"left\"", + "token list", + "\"right\"", + "\"nonassoc\"", + "\"sticky\"", + "\"subgrammar\"", + "\"hidden\"", + "", + "", + "\"disregard\"", + "\"extend\"", + "\"pcb\"", + "\"lexeme\"", + "\"reserve\"", + "\"keywords\"", + "\"rename\"", + "\"macro\"", + "macro name", + "\"wrapper\"", + "", + "tokens", + "'\\?'", + "\"}...\"", + "\"]...\"", + "\"?...\"", + "\"}/...\"", + "\"]/...\"", + "embedded c head", + "", + "", + "", + "", + "c code first", + "", + "", + "c character constant", + "c string constant", + "", + "simple c char", + "", + "", + "", + "", + "\"\\\\\\n\"", + "", + "\"*/\"", + "\"/*\"", + "", + "c literal elem", + "", + "", + "", + "", + "", + "", + "", + "", + "", + "", + "", + "", + +}; + + +#line - "pgg24-2.syn" + int null_warning(int n) { + extern void warning_here(const char *,...); + if (n == 0) log_error("Null character in string"); + return n; + } +#line - "pgg24-2.cpp" +#line - "pgg24-2.syn" +pgg_pcb_type pgcb; +#define PCB pgcb + +#define PARSER_STACK_OVERFLOW parse_stack_overflow() +#define SYNTAX_ERROR log_syntax_error() +#define GET_CONTEXT CONTEXT.y = PCB.line, CONTEXT.x = PCB.column; + +#define REDUCTION_TOKEN_ERROR reduction_token_error() + +extern AgStack< AgStack<RuleElement> > ruleElementStack; + +AgStack<CSegment> extensionStack; +AgStack<CSegment> cSegmentStack; +int nPrologueSegments; + +CSegment::CSegment() + : begin(PCB.pointer), end(PCB.pointer), line(PCB.line) +{ + LOGSECTION("CSegment::CSegment"); + // Nothing to do +} + +static class PggErrorHandler : public ConfigParam::ErrorHandler { + void badParam(const char *s){log_error(s);} +} pggErrorHandler; + + +void reduction_token_error(void) { +#ifdef INCLUDE_LOGGING + LOGSECTION("reduction_token_error"); + LOGV(PCB.sn) LCV(PCB.ssx) LCV(PCB.reduction_token); + for (int i = 0; i < PCB.ssx; i++) LOGV(i) LCV(PCB.ss[i]); +#endif + assert(0); +} + +extern AgString infile_name; +extern AgString errorReportFile; + +Error::Error(AgString msg, int contextFlag) + : file(errorReportFile), + line(contextFlag? ERROR_CONTEXT.y : PCB.line), + column(contextFlag? ERROR_CONTEXT.x : PCB.column), + key(warn), + message(msg) +{ + LOGSECTION("Error::Error(AgString, int)"); + LOGV(PCB.line) LCV(PCB.column) LCV(contextFlag) LCV(msg.pointer()); + LOGV(ERROR_CONTEXT.x) LCV(ERROR_CONTEXT.y); + // Nothing here +} + +Error::Error(int l, int c, AgString msg) + : file(errorReportFile), + line(l), + column(c), + key(warn), + message(msg) +{ + LOGSECTION("Error::Error(int, int, AgString)"); + // Nothing here +} + +extern tsd *rename_macro_list; +extern int parse_abort_flag; + +void parse_stack_overflow(void) { + reset_stk(); + log_error("Nesting too deep. Analysis aborted."); + errorList.top().setFatal(); + parse_abort_flag = 1; + PCB.exit_flag = AG_SEMANTIC_ERROR_CODE; +} + +extern int character_seen; +extern int enum_base; +extern unsigned char *input_base; +extern int precedence_level; +extern int syntax_error_flag; + + CharSetExpression *ss2(void); + + void acs(int); + void aws(int); + void atkn(Token); + void defineImmediateProc(Procedure p); + void definition_1(CharSetExpression *); + void definition_2(int); + void definition_3(int); + int form_element_1(CharSetExpression *); + int form_spec_2(int, int); + int form1(void); + int form2(void); + int head_list_1(int); + int head_list_2(int); +static int head_list_3(int); + void ics(void); + int identify_node(CharSetExpression *); + void iws(void); + int makeRule(const AgIndexedContainer<RuleElement> &); + int mid_line(int); + int null_warning(int); + int proc_spec_4(int); + void production(int); + void range(int, int); + void scs(int); +static void set_prec(int,int); + void sws(int); + int vp_form3(int); + int vp_s(void); + int vp_1(void); + int vp_2(void); + int vp_3(void); + int vp_4(void); + int vp_5(int); + int vp_6(int); + int vp_7(int); + int vp_8(int); + int vp_8a(int); + int vp_9(void); + int vp_10(void); + +int *disregard_list = NULL; +int n_disregard_list = 0; + +static void disregard(int tn) { + LOGSECTION("disregard"); + iws(); + if (n_disregard_list) { + int *p = disregard_list; + while (n_disregard_list--) aws(*p++); + DEALLOCATE(disregard_list); + } + xws(tn); + disregard_list = build_list(); + n_disregard_list = fis(); +} + +static void log_syntax_error(void) { + LOGSECTION("log_syntax_error"); + +#ifdef INCLUDE_LOGGING +{ + LOGV(PCB.sn) LCV(PCB.ssx) LCV(PCB.token_number); + for (int i = 0; i < PCB.ssx; i++) LOGV(i) LCV(PCB.ss[i]); +} +#endif + int flag = PCB.error_frame_token == pgg_c_comment_token || + PCB.error_frame_token == pgg_embedded_c_token; + LOGV(flag); + reset_stk(); + +#ifdef INCLUDE_LOGGING +{ + LOGV(PCB.sn) LCV(PCB.ssx) LCV(PCB.token_number); + for (int i = 0; i < PCB.ssx; i++) LOGV(i) LCV(PCB.ss[i]); +} +#endif + ssprintf("%s in %s", PCB.error_message, pgg_token_names[PCB.error_frame_token]); + LOGS(string_base); + errorList.push(Error(string_base, flag && PCB.token_number == pgg_eof_token)); + rcs(); +#ifdef INCLUDE_LOGGING +{ + LOGV(PCB.sn) LCV(PCB.ssx) LCV(PCB.token_number); + for (int i = 0; i < PCB.ssx; i++) LOGV(i) LCV(PCB.ss[i]); +} +#endif + LOGS("error logged"); + errorList.top().setFatal(); + LOGS("fatal flag set"); + syntax_error_flag++; +#ifdef INCLUDE_LOGGING +{ + LOGV(PCB.sn) LCV(PCB.ssx) LCV(PCB.token_number); + for (int i = 0; i < PCB.ssx; i++) LOGV(i) LCV(PCB.ss[i]); +} +#endif + if (errorList.size() < 50) return; + log_error("Too many errors. Parse aborted."); + errorList.top().setFatal(); + PCB.exit_flag = AG_SYNTAX_ERROR_CODE; +} + +static int head_list_3(int type) { + LOGSECTION("head_list_3"); + LOGV(type); + int i, n = tis(); + for (i = 0; i < n; i ++) { + Token token(list_base[i]); + int ptt = token->value_type; + LOGV(ptt) LCV(type); + if (ptt && ptt != type) { + ssprintf("Type Redefinition of T%03d: ", (int) token); + atkn(token); + log_error(); + } + token->value_type = type; +/* + if (ptt == 0 && token->rp_arg && type == void_token_type) { + //ssprintf("Void token, %s, used as parameter", dict_str(tkn_dict,token->token_name)); + ssprintf("Void token, %s, used as parameter", token->token_name->string.pointer()); + log_error(); + } +*/ + } + return type; +} + +static void set_prec(int left, int right){ + LOGSECTION("set_prec"); + int n = tis(); + precedence_level++; + while (n--) { + Token token(list_base[n]); + token->left_associative = left; + token->right_associative = right; + token->precedence_level = precedence_level; + token->operatorCandidate = 1; + } + rws(); +} + +static void set_sticky(void){ + LOGSECTION("set_sticky"); + int n = tis(); + while (n--) { + Token token(list_base[n]); + token->sticky = 1; + } + rws(); +} + +static void set_subgrammar(void){ + LOGSECTION("set_subgrammar"); + int n = tis(); + while (n--) { + Token token = list_base[n]; + token->subgrammar = 1; + } + rws(); +} + +void set_hidden(void) { + LOGSECTION("set_hidden"); + int *lb = list_base; + int n = tis(); + //while (n--) map_token_number[*lb++].fine_structure = 1; + while (n--) Token(*lb++)->fine_structure = 1; + rws(); +} + +void set_lexeme(void) { + LOGSECTION("set_lexeme"); + int n = tis(); + while (n--) { + Token token = list_base[n]; + token->lexeme = 1; + } + rws(); +} + +void set_reserved_words(void) { + LOGSECTION("set_reserved_words"); + int n = tis(); + while (n--) { + Token token(list_base[n]); + token->reserved_word = 1; + } + rws(); +} + +void parse(void) { + pgcb.pointer = input_base; + pgg(); +} +#line - "pgg24-2.cpp" + +#ifndef CONVERT_CASE +#define CONVERT_CASE(c) (c) +#endif +#ifndef TAB_SPACING +#define TAB_SPACING 8 +#endif + +#define ag_rp_1(t) (production(t)) + +#define ag_rp_2() (nPrologueSegments = 1) + +#define ag_rp_4(t) (production(t)) + +#define ag_rp_5(type) (iws(),type) + +#define ag_rp_6(type) (concat_list(),type) + +#define ag_rp_7() (0) + +#define ag_rp_8(d) (head_list_3(d)) + +#define ag_rp_9(x) (sws(head_list_2(x))) + +#define ag_rp_10(x) (aws(head_list_2(x))) + +#define ag_rp_11() (0) + +#define ag_rp_12() (1) + +#define ag_rp_13() (Cast::create()) + +#define ag_rp_14() (Cast::create().requireWrapper()) + +#define ag_rp_15(n) (sws(n)) + +#define ag_rp_16(n) (aws(n)) + +#define ag_rp_17(pn) (sws((iws(),vp_form3(pn)))) + +#define ag_rp_18(s) (vp_form3(s)) + +#define ag_rp_19(n) (sws(form_spec_2(form1(),n))) + +#define ag_rp_20(n) (sws(n)) + +#define ag_rp_21(n) (aws(n)) + +#define ag_rp_22(s) (form_spec_2(makeRule(ruleElementStack.pop()),s)) + +#define ag_rp_23(e, p) (ruleElementStack.top().push(RuleElement(e,p))) + +#define ag_rp_24(e, p) (ruleElementStack.top().push(RuleElement(e,p))) + +#define ag_rp_25() (ruleElementStack.push(AgStack<RuleElement>())) + +#define ag_rp_26() (0) + +#define ag_rp_27() (proc_spec_4(0)) + +#define ag_rp_28() (proc_spec_4(1)) + +#define ag_rp_29() (concat_string()) + +#define ag_rp_30() (sss("::")) + +#define ag_rp_31() (concat_string()) + +#define ag_rp_32() (ass("::")) + +#define ag_rp_33() (concat_string()) + +#define ag_rp_34() (concat_string()) + +#define ag_rp_35() (acs('>'), concat_string()) + +#define ag_rp_36() (acs('<')) + +#define ag_rp_37() (acs(','), concat_string()) + +#define ag_rp_38() (scs('(')) + +#define ag_rp_39() (concat_string(), acs(')')) + +#define ag_rp_40() (sss(" *")) + +#define ag_rp_41() (concat_string()) + +#define ag_rp_42() (concat_string()) + +#define ag_rp_43(c) (scs(c)) + +#define ag_rp_44(c) (acs(c)) + +#define ag_rp_45(c) (acs(' '), acs(c)) + +#define ag_rp_46(c) (sss("enum "), acs(c)) + +#define ag_rp_47(c) (acs(c)) + +#define ag_rp_48(c) (acs(' '), acs(c)) + +#define ag_rp_49(x) (x & 0x1f) + +#define ag_rp_50(c) ((character_seen=1),c) + +#define ag_rp_51(s, n) (s*n) + +#define ag_rp_52() (1) + +#define ag_rp_53() (-1) + +#define ag_rp_54(n) (n) + +#define ag_rp_55(n) (n) + +#define ag_rp_56(d) (d - '0') + +#define ag_rp_57(n, d) (10*n + d - '0') + +#define ag_rp_58() (0) + +#define ag_rp_59(n, d) (8*n + d - '0') + +#define ag_rp_60(d) (d) + +#define ag_rp_61(n, d) (16*n + d) + +#define ag_rp_62(d) (d-'0') + +#define ag_rp_63(d) ((d&7)+9) + +#define ag_rp_64(p) (vp_8a(mid_line(p))) + +#define ag_rp_65(n) (form_element_1(n)) + +#define ag_rp_66(u, i) (new CharSetUnion(u,i)) + +#define ag_rp_67(u, i) (new CharSetDifference(u,i)) + +#define ag_rp_68(i, n) (new CharSetIntersection(i,n)) + +#define ag_rp_69(n) (new CharSetComplement(n)) + +#define ag_rp_70(c) (new IndividualCode(c)) + +#define ag_rp_71(c) (new IndividualChar(c)) + +#define ag_rp_72() (ss2()) + +#define ag_rp_73(x) (x) + +#define ag_rp_74(l, r) ((character_seen=1),new CharRange(l,r)) + +#define ag_rp_75(l, r) (new CodeRange(l,r)) + +#define ag_rp_76(n) (definition_1(n)) + +#define ag_rp_77(p) (definition_2(p)) + +#define ag_rp_78(p) (defineImmediateProc(Procedure(p))) + +#define ag_rp_79() (definition_3(enum_base++)) + +#define ag_rp_80(n) (definition_3(enum_base = n), enum_base++) + +#define ag_rp_81(n) (definition_3(enum_base = n), enum_base++) + +#define ag_rp_82() (ics()) + +#define ag_rp_83(n) (null_warning(n)) + +#define ag_rp_84() ('\a') + +#define ag_rp_85() ('\b') + +#define ag_rp_86() ('\f') + +#define ag_rp_87() ('\n') + +#define ag_rp_88() ('\r') + +#define ag_rp_89() ('\t') + +#define ag_rp_90() ('\v') + +#define ag_rp_91() ('\\') + +#define ag_rp_92() ('\?') + +#define ag_rp_93() ('\'') + +#define ag_rp_94() ('"') + +#define ag_rp_95(n) (n&7) + +#define ag_rp_96(n, d) (n*8 + (d&7)) + +#define ag_rp_97(n, d) (n*8 + (d&7)) + +#define ag_rp_98(x) (x) + +#define ag_rp_99(c) (acs(c)) + +#define ag_rp_100(c) (acs(c)) + +#define ag_rp_101(c) (acs(c)) + +#define ag_rp_102(c) (acs(c)) + +#define ag_rp_103(c) (acs(c)) + +#define ag_rp_104(c) (acs(null_warning(c))) + +#define ag_rp_105(c) (acs(null_warning(c))) + +#define ag_rp_106(c) (acs(null_warning(c))) + +#define ag_rp_107(c) (acs(null_warning(c))) + +#define ag_rp_108() (0) + +#define ag_rp_109() (cVariableList << buildAgString()) + +#define ag_rp_110(c) (scs(c)) + +#define ag_rp_111(c) (acs(c)) + +#define ag_rp_112() (ConfigParam::set(1, pggErrorHandler)) + +#define ag_rp_113() (ConfigParam::set(0, pggErrorHandler)) + +#define ag_rp_114() (ConfigParam::set(pggErrorHandler)) + +#define ag_rp_115() (ConfigParam::set(pggErrorHandler)) + +#define ag_rp_116() (ConfigParam::set(pggErrorHandler)) + +#define ag_rp_117(n) (ConfigParam::set(n, pggErrorHandler)) + +#define ag_rp_118() (concat_string(), ConfigParam::set(1, pggErrorHandler)) + +#define ag_rp_119() (sss("distinguish ")) + +#define ag_rp_120() (set_prec(1,0)) + +#define ag_rp_121() (set_prec(0,1)) + +#define ag_rp_122() (set_prec(0,0)) + +#define ag_rp_123() (set_sticky()) + +#define ag_rp_124() (set_subgrammar()) + +#define ag_rp_125() (set_hidden()) + +#define ag_rp_126(t) (disregard(t)) + +#define ag_rp_127() (extensionStack.push(cSegmentStack.pop())) + +#define ag_rp_128() (set_lexeme()) + +#define ag_rp_129() (set_reserved_words()) + +#define ag_rp_130(oldName, newName) (at(rename_macro_list,oldName,newName)) + +#define ag_rp_131() ((PCB).pointer-input_base-1) + +#define ag_rp_132(n) (distinguishSets.push(ParseTree(n))) + +#define ag_rp_133(n) (distinguishSets.push(ParseTree(n))) + +#define ag_rp_134(t) (sws(t)) + +#define ag_rp_135(t) (aws(t)) + +#define ag_rp_136() (vp_s()) + +#define ag_rp_137() (vp_5(vp_s())) + +#define ag_rp_138() (vp_1()) + +#define ag_rp_139() (vp_2()) + +#define ag_rp_140() (vp_3()) + +#define ag_rp_141() (vp_4()) + +#define ag_rp_142(n) (vp_5(form_element_1(n))) + +#define ag_rp_143(n) (vp_6(form_element_1(n))) + +#define ag_rp_144(n) (vp_7(form_element_1(n))) + +#define ag_rp_145() (vp_9()) + +#define ag_rp_146() (vp_10()) + +#define ag_rp_147() (proc_spec_4(0)) + +#define ag_rp_148() (proc_spec_4(1)) + +#define ag_rp_149() (proc_spec_4(0)) + +#define ag_rp_150() (proc_spec_4(1)) + +#define ag_rp_151(y) (cSegmentStack.top().end = y) + +#define ag_rp_152() (cSegmentStack.push(CSegment())) + +#define ag_rp_153() (PCB.pointer) + +#define ag_rp_154() (PCB.pointer) + +#define ag_rp_155() (cSegmentStack.push(CSegment())) + +#define ag_rp_156() (cSegmentStack.top().end = PCB.pointer) + +static void ag_rp_157(void) { +#line - "pgg24-2.syn" +if (nest_comments) PCB.reduction_token = pgg_c_comment_head_token; +#line - "pgg24-2.cpp" +} + + +#define READ_COUNTS +#define WRITE_COUNTS +#undef V +#define V(i,t) (*t (&(PCB).vs[(PCB).ssx + i])) +#undef VS +#define VS(i) (PCB).vs[(PCB).ssx + i] + +#ifndef GET_CONTEXT +#define GET_CONTEXT CONTEXT = (PCB).input_context +#endif + +typedef enum { + ag_action_1, + ag_action_2, + ag_action_3, + ag_action_4, + ag_action_5, + ag_action_6, + ag_action_7, + ag_action_8, + ag_action_9, + ag_action_10, + ag_action_11, + ag_action_12 +} ag_parser_action; + + +#ifndef NULL_VALUE_INITIALIZER +#define NULL_VALUE_INITIALIZER = { 0 } +#endif + +static pgg_vs_type const ag_null_value NULL_VALUE_INITIALIZER; + +static const unsigned char ag_rpx[] = { + 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, + 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 1, 0, 2, 0, 3, 0, 4, 0, + 5, 0, 6, 0, 0, 0, 0, 0, 0, 0, 7, 8, 9, 10, 11, 12, 13, 14, + 0, 0, 15, 0, 16, 17, 0, 0, 0, 18, 19, 20, 0, 21, 22, 23, 24, 25, + 26, 27, 28, 0, 0, 0, 0, 29, 0, 30, 31, 32, 33, 0, 0, 34, 35, 36, + 37, 38, 39, 40, 0, 41, 0, 42, 43, 44, 45, 46, 47, 48, 0, 0, 0, 0, + 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, + 0, 0, 0, 49, 50, 51, 0, 0, 52, 53, 0, 54, 0, 0, 55, 56, 57, 58, + 59, 60, 61, 62, 63, 0, 64, 65, 0, 0, 66, 0, 67, 0, 68, 0, 69, 0, + 0, 0, 0, 0, 0, 70, 71, 72, 73, 74, 75, 76, 77, 78, 79, 80, 81, 0, + 0, 0, 0, 0, 0, 82, 0, 0, 83, 84, 85, 86, 87, 88, 89, 90, 91, 92, + 93, 94, 95, 96, 97, 0, 0, 98, 99,100,101,102,103,104,105,106,107,108, + 109,110,111, 0, 0, 0, 0, 0, 0, 0,112,113,114,115,116,117, 0,118, + 119,120,121,122,123,124,125, 0, 0,126,127,128,129,130, 0,131, 0, 0, + 0, 0, 0,132,133, 0,134,135,136,137,138,139,140,141,142,143,144,145, + 146,147,148,149,150,151, 0, 0, 0, 0, 0,152,153,154, 0, 0, 0, 0, + 0, 0, 0, 0, 0, 0, 0, 0, 0,155,156, 0, 0, 0, 0, 0, 0, 0, + 0, 0, 0,157 +}; + +static const unsigned char ag_key_itt[] = { + 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, + 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 1, 0, + 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, + 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, + 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, + 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, + 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, + 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, + 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, + 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, + 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, + 0 +}; + +static const unsigned short ag_key_pt[] = { + 0, 11, 0,147,0 +}; + +static const unsigned char ag_key_ch[] = { + 0, 42, 47,255, 47,255, 42, 47,255, 46,255, 46,255, 42, 47,255, 88,120, + 255, 46, 47,255,114,116,255,115,255,105,255,110,120,255,102,120,255,101, + 255,110,115,255,101,105,255,116,117,255, 46, 47,255, 45, 46, 47, 48, 58, + 63, 93,100,101,104,108,110,114,115,119,125,255, 47,255, 42, 47,255,114, + 116,255,115,255,105,255,110,120,255,102,120,255,101,255,110,115,255,101, + 105,255,116,117,255, 47,100,101,104,108,110,114,115,119,255, 42, 47,255, + 88,120,255, 47, 48, 58,255, 58,255, 42, 47,255, 46, 47,255, 46, 47,255, + 45, 46, 47, 58, 63, 93,125,255, 45, 47,255, 42, 47,255, 88,120,255, 47, + 48, 58, 92,125,255, 47,255, 47, 58,255,114,116,255,115,255,105,255,110, + 120,255,102,120,255,101,255,110,115,255,101,105,255,116,117,255, 47,100, + 101,104,108,110,114,115,119,255, 42, 47,255, 88,120,255, 47, 48, 58, 92, + 255, 88,120,255, 48,255, 42, 47,255, 45, 47,255, 42, 47,255, 88,120,255, + 47, 48,255, 88,120,255, 47, 48,255, 88,120,255, 47, 48, 58, 92,125,255, + 47, 58,255,114,116,255,115,255,105,255,110,120,255,102,120,255,101,255, + 110,115,255,101,105,255,116,117,255,100,101,104,108,110,114,115,119,255, + 42, 47,255, 46, 47,255, 46, 47,255, 47, 93,125,255, 42, 47,255, 47, 92, + 255, 92,255, 42, 47,255, 88,120,255, 47, 48, 58,125,255, 34, 39, 63, 92, + 97, 98,102,110,114,116,118,120,255, 92,255, 88,120,255, 48,125,255, 46, + 47,255, 46, 47,255, 47, 93,125,255, 46,255, 46,255, 46, 47,255, 46, 47, + 255, 46, 47, 63, 93,125,255, 46, 47,255, 46, 47,255, 46, 47, 63, 93,125, + 255, 46, 47, 63,255, 46, 47,255, 46, 47,255, 93,125,255, 46, 47,255, 93, + 255, 46, 47,255,125,255,125,255, 46,255, 46,255, 42, 47,255, 46, 47,255, + 46, 47,255, 46, 47, 63, 93,125,255, 47,107,255, 47,109,255, 47,112,255, + 88,120,255, 47, 48,255, 88,120,255, 48, 58,255, 47, 92,255, 42, 47,255, + 46, 47,255, 46, 47,255, 46, 47, 63, 93,125,255 +}; + +static const unsigned char ag_key_act[] = { + 0,0,0,4,2,4,3,3,4,5,4,6,4,0,0,4,0,0,4,3,3,4,3,3,4,2,4,2,4,3,3,4,3,3,4, + 2,4,3,3,4,2,3,4,3,3,4,3,3,4,3,2,2,2,3,3,2,2,2,3,2,3,2,2,3,2,4,3,4,0,0, + 4,3,3,4,2,4,2,4,3,3,4,3,3,4,2,4,3,3,4,2,3,4,3,3,4,2,2,2,3,2,3,2,2,3,4, + 0,0,4,0,0,4,2,2,3,4,3,4,0,0,4,3,3,4,3,3,4,3,7,2,3,3,2,2,4,3,3,4,0,0,4, + 0,0,4,2,2,3,3,3,4,3,4,3,3,4,3,3,4,2,4,2,4,3,3,4,3,3,4,2,4,3,3,4,2,3,4, + 3,3,4,3,2,2,3,2,3,2,2,3,4,0,0,4,0,0,4,2,2,3,3,4,0,0,4,2,4,0,0,4,3,2,4, + 0,0,4,0,0,4,2,2,4,0,0,4,3,2,4,0,0,4,3,2,3,3,3,4,3,3,4,3,3,4,2,4,2,4,3, + 3,4,3,3,4,2,4,3,3,4,2,3,4,3,3,4,2,2,3,2,3,2,2,3,4,0,0,4,3,3,4,3,3,4,2, + 2,2,4,0,0,4,2,3,4,3,4,0,0,4,0,0,4,2,2,3,3,4,0,0,0,0,0,0,0,0,0,0,0,0,4, + 2,4,0,0,4,2,3,4,3,3,4,3,3,4,3,2,2,4,5,4,6,4,3,3,4,3,3,4,2,3,3,2,2,4,3, + 3,4,3,3,4,7,3,3,2,2,4,7,3,3,4,3,3,4,3,3,4,2,2,4,3,3,4,2,4,3,3,4,2,4,3, + 4,5,4,6,4,0,0,4,3,3,4,3,3,4,2,2,3,2,2,4,3,3,4,3,3,4,3,3,4,0,0,4,3,2,4, + 0,0,4,2,3,4,3,3,4,0,0,4,3,3,4,3,3,4,7,2,3,2,2,4 +}; + +static const unsigned char ag_key_parm[] = { + 0,233,107, 0, 0, 0,232,233, 0, 0, 0, 2, 0,233,107, 0,123,122, + 0,210,213, 0,196,186, 0, 0, 0, 0, 0, 96,197, 0,187,199, 0, 0, + 0,202,200, 0, 0,189, 0,191,192, 0,209,212, 0, 2, 0, 0, 0, 80, + 211, 0, 0, 0,193, 0,190, 0, 0,205, 0, 0,107, 0,233,107, 0,196, + 186, 0, 0, 0, 0, 0, 96,197, 0,187,199, 0, 0, 0,202,200, 0, 0, + 189, 0,191,192, 0, 0, 0, 0,193, 0,190, 0, 0,205, 0,233,107, 0, + 123,122, 0, 0, 0, 80, 0, 80, 0,233,107, 0,210,213, 0,209,212, 0, + 2, 0, 0, 80,211, 0, 0, 0, 2,107, 0,233,107, 0,123,122, 0, 0, + 0, 80,230,209, 0,233, 0,107, 80, 0,196,186, 0, 0, 0, 0, 0, 96, + 197, 0,187,199, 0, 0, 0,202,200, 0, 0,189, 0,191,192, 0,107, 0, + 0,193, 0,190, 0, 0,205, 0,233,107, 0,123,122, 0, 0, 0, 80,230, + 0,123,122, 0, 0, 0,233,107, 0, 2, 0, 0,233,107, 0,123,122, 0, + 0, 0, 0,123,122, 0,107, 0, 0,123,122, 0,233, 0, 80,230,209, 0, + 233, 80, 0,196,186, 0, 0, 0, 0, 0, 96,197, 0,187,199, 0, 0, 0, + 202,200, 0, 0,189, 0,191,192, 0, 0, 0,193, 0,190, 0, 0,205, 0, + 233,107, 0,210,213, 0,209,212, 0, 0, 0, 0, 0,233,107, 0, 0,230, + 0,230, 0,233,107, 0,123,122, 0, 0, 0, 80,209, 0,170,169,168,167, + 160,161,162,163,164,165,166,174, 0, 0, 0,123,122, 0, 0,209, 0,210, + 213, 0,209,212, 0,107, 0, 0, 0, 0, 0, 2, 0,210,213, 0,209,212, + 0, 0,107,211, 0, 0, 0,210,213, 0,209,212, 0, 0,107,211, 0, 0, + 0, 0,107,211, 0,210,213, 0,209,212, 0, 0, 0, 0,210,213, 0, 0, + 0,209,212, 0, 0, 0,209, 0, 0, 0, 2, 0,233,107, 0,210,213, 0, + 209,212, 0, 0, 0,211, 0, 0, 0,233,201, 0,233,203, 0,233,198, 0, + 123,122, 0,233, 0, 0,123,122, 0, 0, 80, 0,233,230, 0,233,107, 0, + 210,213, 0,209,212, 0, 0, 0,211, 0, 0, 0 +}; + +static const unsigned short ag_key_jmp[] = { + 0, 0, 0, 0, 1, 0, 0, 2, 0, 0, 0, 9, 0, 0, 0, 0, 0, 0, + 0, 12, 15, 0, 19, 25, 0, 22, 0, 25, 0, 33, 36, 0, 47, 49, 0, 32, + 0, 61, 65, 0, 37, 70, 0, 74, 79, 0, 95, 98, 0, 4, 11, 13, 16, 6, + 8, 19, 27, 29, 41, 35, 53, 40, 43, 88, 46, 0,102, 0, 0, 0, 0,104, + 110, 0, 71, 0, 74, 0,118,121, 0,132,134, 0, 81, 0,146,150, 0, 86, + 155, 0,159,164, 0, 68, 76, 78,126, 84,138, 89, 92,173, 0, 0, 0, 0, + 0, 0, 0,105,108,180, 0,182, 0, 0, 0, 0,195,198, 0,202,205, 0, + 184,186,117,189,191,120,123, 0,209,211, 0, 0, 0, 0, 0, 0, 0,137, + 140,213,215,217, 0,221, 0,223,225, 0,229,235, 0,154, 0,157, 0,243, + 246, 0,257,259, 0,164, 0,271,275, 0,169,280, 0,284,289, 0,227,159, + 161,251,167,263,172,175,298, 0, 0, 0, 0, 0, 0, 0,188,191,305,307, + 0, 0, 0, 0,199, 0, 0, 0, 0,309,204, 0, 0, 0, 0, 0, 0, 0, + 210,213, 0, 0, 0, 0,311,219, 0, 0, 0, 0,313,225,315,317,319, 0, + 323,325, 0,327,333, 0,237, 0,240, 0,341,344, 0,355,357, 0,247, 0, + 369,373, 0,252,378, 0,382,387, 0,242,244,349,250,361,255,258,396, 0, + 0, 0, 0,403,406, 0,410,413, 0,270,273,276, 0, 0, 0, 0,283,417, + 0,419, 0, 0, 0, 0, 0, 0, 0,291,294,421,423, 0, 0, 0, 0, 0, + 0, 0, 0, 0, 0, 0, 0, 0, 0,302, 0, 0, 0, 0,317,427, 0,433, + 436, 0,440,443, 0,431,323,326, 0, 0, 0,333, 0,453,456, 0,460,463, + 0,335,447,449,337,340, 0,476,479, 0,483,486, 0,467,470,472,349,352, + 0,490,493,495, 0,499,502, 0,506,509, 0,365,368, 0,513,516, 0,374, + 0,520,523, 0,379, 0,527, 0, 0, 0,386, 0, 0, 0, 0,535,538, 0, + 542,545, 0,388,390,531,393,396, 0,549,551, 0,559,561, 0,566,568, 0, + 0, 0, 0,571,414, 0, 0, 0, 0,420,573, 0,575,577, 0, 0, 0, 0, + 586,589, 0,593,596, 0,579,429,582,432,435, 0 +}; + +static const unsigned short ag_key_index[] = { + 4, 6, 49, 66, 0, 0, 0, 95, 0, 0, 0, 0, 0,111,115, 4,126, 0, + 134, 95, 4,134,134, 66, 66, 66, 66, 0, 0, 0, 0,143,149,151, 0, 0, + 4,126,134,134,111, 0,178, 0, 0, 0, 0, 0, 0, 4, 0,194,202,207, + 216,222, 4, 4, 4,207, 66, 66, 0,228,149,149, 0,234,115, 66, 4,261, + 279, 0, 0, 0, 0, 0, 4,279,286,289,216,297,315,202,320,329,216,216, + 202, 0,315,216,202,343,202,355,361,202, 66,289, 66,216,202, 66, 4,207, + 228, 0,149, 4, 66, 0, 66, 0,149,149,149,149,149,149,149, 66, 66,149, + 149,149,149,149,149, 4, 0,149, 0, 66, 66, 0, 0, 0, 4,289, 0, 0, + 0,315,315,315,315,315,371,377,382,384,384,279, 0,399,399,399,399, 0, + 0,216,216,279,279,279,202,202,289,355,329,202, 0, 0, 0,234, 4,405, + 0,408,405,149,411,417, 0, 0,202, 0, 4, 0,149,423, 95, 0, 4, 0, + 0,426, 4,315,279,279,279,202,279,279,399,315,438,438,202,202,355,355, + 0, 4,329,279,149,115,149,149,202,149, 66, 66, 0, 0, 0,279, 0,149, + 0,149, 66, 0,202,279,202,115,149,202,315, 66,149, 0, 66 +}; + +static const unsigned char ag_key_ends[] = { +47,0, 42,0, 62,0, 58,0, 46,46,46,0, 46,46,0, 46,46,46,0, +101,103,97,114,100,0, 105,110,103,117,105,115,104,0, 117,109,0, +116,101,110,100,0, 105,100,100,101,110,0, 116,0, 101,109,101,0, +111,110,97,115,115,111,99,0, 97,109,101,0, 101,114,118,101,0, +103,104,116,0, 105,99,107,121,0, 98,103,114,97,109,109,97,114,0, +114,97,112,112,101,114,0, 46,46,0, 46,46,46,0, 47,0, +101,103,97,114,100,0, 105,110,103,117,105,115,104,0, 117,109,0, +116,101,110,100,0, 105,100,100,101,110,0, 116,0, 101,109,101,0, +111,110,97,115,115,111,99,0, 97,109,101,0, 101,114,118,101,0, +103,104,116,0, 105,99,107,121,0, 98,103,114,97,109,109,97,114,0, +114,97,112,112,101,114,0, 58,0, 58,0, 62,0, 46,46,0, 58,0, +46,46,46,0, 46,46,0, 46,46,46,0, 46,46,0, 46,46,46,0, 62,0, +47,0, 58,0, 10,0, 46,46,46,0, 42,0, 47,0, 58,0, 47,0, +101,103,97,114,100,0, 105,110,103,117,105,115,104,0, 117,109,0, +116,101,110,100,0, 105,100,100,101,110,0, 116,0, 101,109,101,0, +111,110,97,115,115,111,99,0, 97,109,101,0, 101,114,118,101,0, +103,104,116,0, 105,99,107,121,0, 98,103,114,97,109,109,97,114,0, +114,97,112,112,101,114,0, 58,0, 10,0, 62,0, 47,0, 42,0, 58,0, +10,0, 46,46,46,0, 42,0, 58,0, 101,103,97,114,100,0, +105,110,103,117,105,115,104,0, 117,109,0, 116,101,110,100,0, +105,100,100,101,110,0, 116,0, 101,109,101,0, +111,110,97,115,115,111,99,0, 97,109,101,0, 101,114,118,101,0, +103,104,116,0, 105,99,107,121,0, 98,103,114,97,109,109,97,114,0, +114,97,112,112,101,114,0, 46,46,0, 46,46,46,0, 46,46,0, +46,46,46,0, 10,0, 10,0, 58,0, 46,46,46,0, 46,46,46,0, 47,0, +46,46,0, 46,46,46,0, 46,46,0, 46,46,46,0, 47,0, 46,46,46,0, +46,46,0, 46,46,46,0, 46,46,0, 46,46,46,0, 46,46,0, 47,0, +46,46,46,0, 46,46,0, 46,46,46,0, 46,46,0, 46,46,46,0, 46,46,0, +47,0, 46,46,46,0, 46,46,0, 46,46,46,0, 46,46,0, 46,46,46,0, +46,46,0, 46,46,46,0, 46,46,0, 46,46,46,0, 46,46,46,0, +46,46,46,0, 46,46,0, 46,46,46,0, 46,46,0, 46,46,46,0, 42,0, +101,121,119,111,114,100,115,0, 42,0, 97,99,114,111,0, 42,0, +99,98,0, 42,0, 58,0, 42,0, 10,0, 46,46,0, 46,46,46,0, 46,46,0, +46,46,46,0, 46,46,0, 46,46,46,0, +}; + +#define AG_TCV(x) ag_tcv[(x)] + +static const unsigned char ag_tcv[] = { + 44,246,246,246,246,246,246,246,246, 97,104,106,106,102,246,246,246,246, + 246,246,246,246,246,246,246,246, 44,246,246,246,246,246, 97, 15,154,247, + 59,247,139, 33, 21, 31, 90, 25, 7, 23,247,247,128,244,244,244,244,244, + 244,244,245,245,177, 75, 87, 13, 86,208,247,131,131,131,131,131,131,243, + 243,243,243,243,243,243,243,243,243,243,243,243,243,243,243,243,243,243, + 243, 19,172, 27,113,243,247,131,131,131,131,131,131,243,243,243,243,243, + 243,243,243,243,243,243,243,243,243,243,243,243,243,243,243, 17, 37, 29, + 35,246,246,246,246,246,246,246,246,246,246,246,246,246,246,246,246,246, + 246,246,246,246,246,246,246,246,246,246,246,246,246,246,246,246,246,246, + 246,246,246,246,246,246,246,246,246,246,246,246,246,246,246,246,246,246, + 246,246,246,246,246,246,246,246,246,246,246,246,246,246,246,246,246,246, + 246,246,246,246,246,246,246,246,246,246,246,246,246,246,246,246,246,246, + 246,246,246,246,246,246,246,246,246,246,246,246,246,246,246,246,246,246, + 246,246,246,246,246,246,246,246,246,246,246,246,246,246,246,246,246,246, + 246,246,246,246 +}; + +#ifndef SYNTAX_ERROR +#define SYNTAX_ERROR fprintf(stderr,"%s, line %d, column %d\n", \ + (PCB).error_message, (PCB).line, (PCB).column) +#endif + +#ifndef FIRST_LINE +#define FIRST_LINE 1 +#endif + +#ifndef FIRST_COLUMN +#define FIRST_COLUMN 1 +#endif + +#ifndef PARSER_STACK_OVERFLOW +#define PARSER_STACK_OVERFLOW {fprintf(stderr, \ + "\nParser stack overflow, line %d, column %d\n",\ + (PCB).line, (PCB).column);} +#endif + +#ifndef REDUCTION_TOKEN_ERROR +#define REDUCTION_TOKEN_ERROR {fprintf(stderr, \ + "\nReduction token error, line %d, column %d\n", \ + (PCB).line, (PCB).column);} +#endif + + +#ifndef INPUT_CODE +#define INPUT_CODE(T) (T) +#endif + +typedef enum + {ag_accept_key, ag_set_key, ag_jmp_key, ag_end_key, ag_no_match_key, + ag_cf_accept_key, ag_cf_set_key, ag_cf_end_key} key_words; + +static void ag_get_key_word(int ag_k) { + int ag_save = (int) ((PCB).la_ptr - (PCB).pointer); + const unsigned char *ag_p; + int ag_ch; + while (1) { + switch (ag_key_act[ag_k]) { + case ag_cf_end_key: { + const unsigned char *sp = ag_key_ends + ag_key_jmp[ag_k]; + do { + if ((ag_ch = *sp++) == 0) { + int ag_k1 = ag_key_parm[ag_k]; + int ag_k2 = ag_key_pt[ag_k1]; + if (ag_key_itt[ag_k2 + CONVERT_CASE(*(PCB).la_ptr)]) goto ag_fail; + (PCB).token_number = (pgg_token_type) ag_key_pt[ag_k1 + 1]; + return; + } + } while (CONVERT_CASE(*(PCB).la_ptr++) == ag_ch); + goto ag_fail; + } + case ag_end_key: { + const unsigned char *sp = ag_key_ends + ag_key_jmp[ag_k]; + do { + if ((ag_ch = *sp++) == 0) { + (PCB).token_number = (pgg_token_type) ag_key_parm[ag_k]; + return; + } + } while (CONVERT_CASE(*(PCB).la_ptr++) == ag_ch); + } + case ag_no_match_key: +ag_fail: + (PCB).la_ptr = (PCB).pointer + ag_save; + return; + case ag_cf_set_key: { + int ag_k1 = ag_key_parm[ag_k]; + int ag_k2 = ag_key_pt[ag_k1]; + ag_k = ag_key_jmp[ag_k]; + if (ag_key_itt[ag_k2 + CONVERT_CASE(*(PCB).la_ptr)]) break; + ag_save = (int) ((PCB).la_ptr - (PCB).pointer); + (PCB).token_number = (pgg_token_type) ag_key_pt[ag_k1+1]; + break; + } + case ag_set_key: + ag_save = (int) ((PCB).la_ptr - (PCB).pointer); + (PCB).token_number = (pgg_token_type) ag_key_parm[ag_k]; + case ag_jmp_key: + ag_k = ag_key_jmp[ag_k]; + break; + case ag_accept_key: + (PCB).token_number = (pgg_token_type) ag_key_parm[ag_k]; + return; + case ag_cf_accept_key: { + int ag_k1 = ag_key_parm[ag_k]; + int ag_k2 = ag_key_pt[ag_k1]; + if (ag_key_itt[ag_k2 + CONVERT_CASE(*(PCB).la_ptr)]) + (PCB).la_ptr = (PCB).pointer + ag_save; + else (PCB).token_number = (pgg_token_type) ag_key_pt[ag_k1+1]; + return; + } + } + ag_ch = CONVERT_CASE(*(PCB).la_ptr++); + ag_p = &ag_key_ch[ag_k]; + if (ag_ch <= 255) while (*ag_p < ag_ch) ag_p++; + if (ag_ch > 255 || *ag_p != ag_ch) { + (PCB).la_ptr = (PCB).pointer + ag_save; + return; + } + ag_k = (int) (ag_p - ag_key_ch); + } +} + + +#ifndef AG_NEWLINE +#define AG_NEWLINE 10 +#endif + +#ifndef AG_RETURN +#define AG_RETURN 13 +#endif + +#ifndef AG_FORMFEED +#define AG_FORMFEED 12 +#endif + +#ifndef AG_TABCHAR +#define AG_TABCHAR 9 +#endif + +static void ag_track(void) { + int ag_k = (int) ((PCB).la_ptr - (PCB).pointer); + while (ag_k--) { + switch (*(PCB).pointer++) { + case AG_NEWLINE: + (PCB).column = 1, (PCB).line++; + case AG_RETURN: + case AG_FORMFEED: + break; + case AG_TABCHAR: + (PCB).column += (TAB_SPACING) - ((PCB).column - 1) % (TAB_SPACING); + break; + default: + (PCB).column++; + } + } +} + + +static void ag_prot(void) { + int ag_k; + ag_k = 128 - ++(PCB).btsx; + if (ag_k <= (PCB).ssx) { + (PCB).exit_flag = AG_STACK_ERROR_CODE; + PARSER_STACK_OVERFLOW; + return; + } + (PCB).bts[(PCB).btsx] = (PCB).sn; + (PCB).bts[ag_k] = (PCB).ssx; + (PCB).vs[ag_k] = (PCB).vs[(PCB).ssx]; + (PCB).ss[ag_k] = (PCB).ss[(PCB).ssx]; + (PCB).cs[ag_k] = (PCB).cs[(PCB).ssx]; +} + +static void ag_undo(void) { + if ((PCB).drt == -1) return; + while ((PCB).btsx) { + int ag_k = 128 - (PCB).btsx; + (PCB).sn = (PCB).bts[(PCB).btsx--]; + (PCB).ssx = (PCB).bts[ag_k]; + (PCB).vs[(PCB).ssx] = (PCB).vs[ag_k]; + (PCB).ss[(PCB).ssx] = (PCB).ss[ag_k]; + (PCB).cs[(PCB).ssx] = (PCB).cs[ag_k]; + } + (PCB).token_number = (pgg_token_type) (PCB).drt; + (PCB).ssx = (PCB).dssx; + (PCB).sn = (PCB).dsn; + (PCB).drt = -1; +} + + + +static const int ag_rtt[] = { + 98,231, 0 +}; + +static const unsigned char ag_tstt[] = { +243,233,131,107,104,102,97,21,19,17,0,3,4,5,38,98,231, +247,246,245,244,243,233,232,208,177,172,154,139,131,128,113,106,104,102,97, + 90,87,86,75,59,37,35,33,31,29,27,25,23,21,19,17,15,13,7,0,98,231, +233,97,0,3,98,231, +243,131,107,104,102,21,19,17,0,39,40,100,103, +247,246,245,244,243,208,177,172,154,139,131,128,113,106,104,102,97,90,87,86, + 75,59,37,35,33,31,29,27,25,23,21,19,17,15,13,7,0,109,110, +104,0, +104,102,0,103, +243,233,205,202,200,199,197,196,193,192,191,190,189,187,186,131,107,106,104, + 102,97,96,35,27,21,19,17,0,3,98,100,103,105,231, +243,131,21,19,17,0,20,41,45,46,47,48,50,55,56,57,58,92,214, +247,246,245,244,243,208,177,172,154,139,131,128,113,106,97,90,87,86,75,59, + 37,35,33,31,29,27,25,23,21,19,17,15,13,7,0, +104,0, +104,102,0,103, +104,0, +245,244,243,233,131,128,123,122,113,107,104,102,97,90,80,35,33,25,23,21,0,3, + 4,8,9,98,99,100,101,103,231, +243,131,80,0,58,60,76,92, +247,246,245,244,243,233,208,177,172,154,139,131,128,113,107,106,104,102,97, + 90,87,86,75,59,37,35,33,31,29,27,25,23,21,19,15,13,7,0,103,216,217,218, +245,244,243,233,213,212,211,210,209,208,177,139,131,128,107,104,102,97,90, + 87,86,80,59,44,37,31,29,27,25,23,21,13,11,7,2,0,3,4,5,98,231, +243,131,0,55,57,58,92, +7,0,6, +243,233,205,202,200,199,197,196,193,192,191,190,189,187,186,131,107,104,102, + 97,96,35,27,0,3,4,5,98,180,231, +247,246,245,244,243,233,208,177,172,154,139,131,128,113,107,106,97,90,87,86, + 75,59,37,35,33,31,29,27,25,23,21,19,15,13,7,0,98,100,215,219,222,223, + 231, +59,13,0,12, +2,0,1,51, +107,104,102,0,39,100,103, +107,104,102,0,39,100,103, +107,104,102,0,39,100,103, +107,104,102,0,39,100,103, +243,131,44,21,19,17,0,20,42,43,45,46,47,48,49,50,55,56,57,58,92,214, +104,0, +104,0, +104,102,0,101,103, +247,246,245,244,243,233,230,209,208,177,172,154,139,131,128,123,122,113,107, + 106,104,102,97,90,87,86,80,59,37,35,33,31,29,27,25,23,21,19,17,15,13,7, + 0,3,98,99,100,101,103,231, +243,233,131,97,0,81, +107,104,102,90,87,86,80,31,29,27,21,7,0,77,78,85, +31,0, +104,0, +247,246,245,244,243,233,208,177,172,154,139,131,128,113,107,106,104,102,97, + 90,87,86,75,59,37,35,33,31,29,27,25,23,21,19,15,13,7,0,103,216, +245,244,243,233,131,128,97,0,3,98,231, +59,0, +7,0,6, +245,244,243,233,154,131,128,123,122,113,107,104,102,97,80,35,33,29,25,23,21, + 19,17,15,0,3,4,8,9,98,99,100,101,103,231, +243,131,0,57,58,92, +243,205,202,200,199,197,196,193,192,191,190,189,187,186,131,107,104,102,96, + 35,27,0,39,40,100,103, +27,0,26, +247,246,245,244,243,208,177,172,154,139,131,128,113,106,97,90,87,86,75,59, + 37,35,33,31,29,27,25,23,21,19,17,15,13,7,0,237,238,239, +247,246,245,244,243,208,177,172,154,139,131,128,113,106,97,90,87,86,75,59, + 37,35,33,31,29,27,25,23,21,19,17,15,13,7,0,240,241,242, +154,0, +33,0, +104,102,0,103, +247,246,245,244,243,233,208,177,172,154,139,131,128,113,107,106,104,102,97, + 90,87,86,75,59,37,35,33,31,29,27,25,23,21,19,17,15,13,7,0,220, +29,0,28, +247,246,245,244,243,233,230,208,177,172,154,139,131,128,123,122,113,107,106, + 104,102,97,90,87,86,80,59,37,35,33,31,27,25,23,21,19,17,15,13,7,0,3,4,8, + 9,98,99,100,101,103,231, +245,244,243,154,131,128,123,122,113,35,33,25,23,21,19,17,15,0,14,16,18,20, + 22,24,34,58,92,111,112,115,117,119,134,135,136,137,138,140,146,148,151, + 152, +233,107,104,102,97,44,7,2,0,3,4,5,98,231, +245,244,243,233,154,131,128,123,122,113,107,104,102,97,44,37,35,33,25,23,21, + 19,17,15,13,0,3,4,5,98,231, +245,244,243,154,131,128,123,122,113,107,104,102,44,37,35,33,25,23,21,19,17, + 15,13,0,12,54,67,69,70,71, +243,233,131,107,106,104,102,97,44,21,19,17,0,3,98,100,103,105,231, +243,233,131,107,106,104,102,97,44,21,19,17,0,3,98,100,103,105,231, +243,233,131,107,106,104,102,97,44,21,19,17,0,3,98,100,103,105,231, +243,233,131,107,106,104,102,97,44,37,21,19,17,2,0,1,3,36,51,52,53,98,100, + 103,105,231, +107,104,102,44,0,39,100,103, +107,104,102,44,0,39,100,103, +44,0, +233,97,0,3,4,98,231, +243,233,131,97,0,3,4,5,98,231, +243,233,131,97,0,82, +90,21,0,20,79,83,84,88,89,91, +243,233,131,97,80,0,3,4,5,98,231, +243,131,80,0,58,60,76,92, +107,104,102,90,86,31,29,27,21,7,0, +243,233,131,107,104,102,97,0,3,4,8,9,98,99,100,101,103,231, +243,205,202,200,199,197,196,193,192,191,190,189,187,186,131,96,35,27,0,34, + 58,92,95,150,181,182,183,184,185,194, +233,213,212,210,209,177,107,104,102,97,44,37,29,27,13,7,0,3,4,5,98,231, +247,246,245,244,243,208,177,172,154,139,131,128,113,106,104,102,97,90,87,86, + 75,59,37,35,33,31,29,27,25,23,21,19,17,15,13,7,0,236, +247,246,245,244,243,208,177,172,139,131,128,113,106,97,90,87,86,75,59,37,35, + 33,31,29,27,25,23,21,19,17,15,13,7,0,237, +247,246,245,244,243,208,177,172,154,139,131,128,113,106,104,102,97,90,87,86, + 75,59,37,35,33,31,29,27,25,23,21,19,17,15,13,7,0,236, +247,246,245,244,243,208,177,172,154,139,131,128,113,106,97,90,87,86,75,59, + 37,35,31,29,27,25,23,21,19,17,15,13,7,0,240, +104,0, +247,246,245,244,243,233,208,177,172,154,139,131,128,113,107,106,104,102,97, + 90,87,86,75,59,37,35,33,31,27,25,23,21,19,17,15,13,7,0,98,100,222,223, + 224,231, +233,213,212,210,209,177,107,104,102,97,44,37,29,27,13,7,0,3,4,5,98,231, +247,246,245,244,243,233,230,208,177,172,154,139,131,128,113,107,106,104,102, + 97,90,87,86,59,37,35,33,31,27,25,23,21,19,17,15,13,7,0,3,4,8,9,98,99, + 100,101,103,231, +247,246,245,244,243,230,208,177,172,154,139,131,128,113,106,90,87,86,59,37, + 35,33,31,27,25,23,21,19,17,15,13,7,0,47,74,214,226, +245,244,243,233,154,131,128,123,122,113,107,104,102,97,35,33,25,23,21,19,17, + 15,0,3,4,8,9,98,99,100,101,103,231, +245,244,243,233,209,154,131,128,123,122,113,107,104,102,97,80,37,35,33,29, + 25,23,21,19,17,15,13,0,3,4,8,9,98,99,100,101,103,231, +247,246,245,244,243,208,177,174,172,170,169,168,167,166,165,164,163,162,161, + 160,139,131,128,113,106,97,90,87,86,75,59,37,35,33,31,29,27,25,23,21,19, + 17,15,13,7,0,142,143,144,145,153,155,156,157,158,171,173, +245,244,243,154,131,128,123,122,113,35,33,25,23,21,19,17,15,0,63,64,69,71, +245,244,243,209,154,131,128,123,122,113,37,35,33,29,25,23,21,19,17,15,13,0, + 12,63,64,66,67,68,69,71, +208,0, +245,244,243,233,131,128,123,122,113,107,104,102,97,35,33,25,23,21,0,3,4,8,9, + 98,99,100,101,103,231, +245,244,243,233,131,128,123,122,113,107,104,102,97,35,33,25,23,21,0,3,4,8,9, + 98,99,100,101,103,231, +245,244,128,123,122,0,118,120,121,124, +247,245,244,243,208,177,172,154,139,131,128,113,90,87,86,75,59,37,35,33,31, + 29,27,25,23,21,19,17,15,13,7,0, +247,246,245,244,243,208,177,174,172,170,169,168,167,166,165,164,163,162,161, + 160,154,139,131,128,113,106,97,90,87,86,75,59,37,35,31,29,27,25,23,21, + 19,17,15,13,7,0,116,142,143,144,145,171,173, +245,244,243,233,131,128,123,122,113,107,104,102,97,35,33,25,23,21,0,3,4,8,9, + 98,99,100,101,103,231, +245,244,243,131,128,123,122,113,35,33,25,23,21,0,20,22,24,34,58,92,111,112, + 115,117,119,134,136,137,138,140,146, +147,0, +245,244,243,131,128,123,122,113,35,33,25,23,21,0,20,22,24,34,58,92,111,112, + 115,117,119,138,140,146, +139,0, +211,208,25,23,11,0,10,22,24, +245,244,243,154,131,128,123,122,113,35,33,25,23,21,19,17,15,0,14,16,18,20, + 22,24,34,58,72,92,111,112,115,117,119,132,133,134,135,136,137,138,140, + 146,151,152, +107,104,102,44,37,13,7,0,6,12,67, +247,246,245,244,243,230,208,177,172,154,139,131,128,113,106,90,87,86,59,37, + 35,33,31,27,25,23,21,19,17,15,13,7,0,47,74,214,226, +37,0,36,52, +245,244,243,233,154,131,128,123,122,113,107,104,102,97,35,33,25,23,21,19,17, + 15,0,3,4,8,9,98,99,100,101,103,231, +245,244,243,154,131,128,123,122,113,35,33,25,23,21,19,17,15,0,69,70,71, +37,0,36,52, +243,233,131,107,106,104,102,97,44,21,19,17,0,3,98,100,103,105,231, +243,233,131,107,106,104,102,97,44,37,21,19,17,2,0,1,3,36,51,52,53,98,100, + 103,105,231, +233,97,0,3,98,231, +243,131,0,58,92, +243,233,131,97,0,3,4,5,98,231, +243,233,131,107,104,102,97,90,86,31,29,27,21,7,0,3,4,5,98,231, +243,131,0,58,92, +90,21,0,20,79,83,84,88,89,91, +90,21,0,20,84,88,89,91, +86,7,0, +233,97,0,3,4,98,231, +233,97,17,0,3,4,5,98,231, +233,97,0,3,4,98,231, +233,97,0,3,4,98,231, +233,97,0,3,4,98,188,231, +233,97,0,3,4,98,231, +233,97,0,3,4,98,231, +107,104,102,29,7,0,6,99,100,101,103,195,206, +107,104,102,29,7,0,6,99,100,101,103,195,206, +233,97,0,3,4,98,188,231, +233,97,0,3,4,98,188,231, +233,97,0,3,4,98,188,231, +233,97,0,3,4,98,188,231, +233,97,0,3,4,98,188,231, +233,97,0,3,4,98,188,231, +233,107,104,102,97,0,3,4,8,98,99,100,101,103,231, +243,131,0,58,92, +245,244,243,233,131,128,97,13,0,3,4,5,98,231, +243,131,0,58,92, +13,0,12, +107,104,102,27,0,39,40,100,103, +154,0, +33,0, +104,102,0,103, +247,246,245,244,243,233,208,177,172,154,139,131,128,113,107,106,104,102,97, + 90,87,86,75,59,37,35,33,31,29,27,25,23,21,19,17,15,13,7,0,220, +247,246,245,244,243,230,208,177,172,154,139,131,128,113,106,90,87,86,59,37, + 35,33,31,27,25,23,21,19,15,13,7,0,222,223,227,228, +75,0, +244,128,0, +245,244,131,128,0,125,130, +244,128,0, +244,128,0, +245,131,0, +245,244,131,128,0, +247,246,243,208,177,174,172,170,169,168,167,166,165,164,163,162,161,160,154, + 139,113,106,97,90,87,86,75,59,37,35,33,31,29,27,25,23,21,19,17,15,13,7, + 0,142,143,144,145,158,171,173, +213,212,210,209,37,29,27,13,7,0,6,12,67, +213,210,37,27,0,26,36,65, +212,37,0,36,65, +37,0,36,65, +209,29,0,28, +233,213,212,210,209,177,107,104,102,97,44,37,29,27,13,7,0,3,4,5,98,231, +245,244,131,128,0,125,130, +244,128,0, +245,244,128,0, +233,213,212,211,210,209,208,177,147,139,107,104,102,97,44,37,31,29,27,25,23, + 13,11,7,0,3,4,5,98,231, +233,213,212,211,210,209,208,177,147,139,107,104,102,97,44,37,31,29,27,25,23, + 13,11,7,0,3,4,5,98,231, +33,23,0,32, +31,25,23,0,22,24,30, +245,244,233,128,123,122,113,107,104,102,97,25,23,0,3,4,8,9,98,99,100,101, + 103,231, +245,244,243,233,131,128,123,122,113,107,104,102,97,35,33,25,23,21,0,3,4,8,9, + 98,99,100,101,103,231, +233,213,212,210,209,177,107,104,102,97,44,37,29,27,13,7,0,3,4,5,98,231, +233,213,212,210,209,177,107,104,102,97,44,37,29,27,13,7,0,3,4,5,98,231, +233,213,212,210,209,177,107,104,102,97,44,37,29,27,13,7,0,3,4,5,98,231, +245,244,243,131,128,123,122,113,35,33,25,23,21,0,20,22,24,34,58,92,111,112, + 115,117,119,136,138,140,146, +245,244,243,131,128,123,122,113,35,33,25,23,21,0,20,22,24,34,58,92,111,112, + 115,117,119,136,138,140,146, +247,246,245,244,243,230,208,177,172,154,139,131,128,113,106,90,87,86,59,37, + 35,33,31,27,25,23,21,19,17,15,13,7,0,47,74,214,226, +211,208,25,23,11,0,10,22,24, +213,212,210,209,177,107,104,102,44,37,29,27,13,7,0,73, +245,244,243,154,131,128,123,122,113,35,33,25,23,21,19,17,15,0,14,16,18,20, + 22,24,34,58,72,92,111,112,115,117,119,132,133,134,135,136,137,138,140, + 146,151,152, +75,0, +243,131,0,58,92, +31,0,30, +243,233,131,97,80,0,3,4,5,98,231, +233,107,104,102,97,90,86,31,29,27,21,7,0,3,4,5,98,231, +233,201,97,0,3,98,231, +17,0,16, +233,203,97,0,3,98,231, +233,201,97,0,3,98,231, +233,97,17,0,3,16,98,231, +233,198,97,0,3,98,231, +245,244,243,233,154,131,128,123,122,113,97,35,33,25,23,21,19,17,0,3,16,18, + 20,22,24,34,58,92,98,111,112,115,117,119,132,134,135,136,137,138,140, + 146,151,152,231, +29,0,28, +243,131,0,58,92,149, +245,244,243,131,128,123,122,113,35,33,29,25,23,21,0,20,22,24,34,58,92,111, + 112,115,117,119,134,136,137,138,140,146, +17,0,16, +245,244,243,233,131,128,107,104,102,97,17,0,3,98,99,100,101,103,231, +13,0,12, +245,244,243,233,131,128,97,0,3,98,231, +245,244,243,154,131,128,123,122,80,25,23,0,22,24,58,60,76,92,112,117,119, + 151,152, +243,233,205,202,200,199,197,196,193,192,191,190,189,187,186,131,107,106,104, + 102,97,96,35,27,0,3,34,58,92,95,98,100,103,105,150,183,184,185,194,231, +104,0, +247,246,245,244,243,233,208,177,172,154,139,131,128,113,107,106,104,102,97, + 90,87,86,75,59,37,35,33,31,29,27,25,23,21,19,17,15,13,7,0,98,100,222, + 223,224,231, +154,0, +33,0, +247,246,245,244,243,233,230,208,177,172,154,139,131,128,113,106,97,90,87,86, + 59,37,35,33,31,27,25,23,21,19,15,13,7,0,3,98,222,223,228,231, +233,107,104,102,97,44,0,3,4,5,98,231, +245,244,131,128,0,130, +233,213,212,210,209,208,177,107,104,102,97,44,37,29,27,13,7,0,3,4,5,98,231, +233,213,212,210,209,177,107,104,102,97,44,37,29,27,13,7,0,3,4,5,98,231, +233,213,212,210,209,177,107,104,102,97,44,37,29,27,13,7,0,3,4,5,98,231, +245,244,243,154,131,128,123,122,113,35,33,25,23,21,19,17,15,0,64,69,71, +233,213,212,210,209,177,107,104,102,97,44,37,29,27,13,7,0,3,4,5,98,231, +233,213,212,210,209,177,107,104,102,97,44,37,29,27,13,7,0,3,4,5,98,231, +245,244,131,128,0,130, +247,246,245,244,243,208,177,174,172,170,169,168,167,166,165,164,163,162,161, + 160,154,139,131,128,113,106,97,90,87,86,75,59,37,35,31,29,27,25,23,21, + 19,17,15,13,7,0,116,142,143,144,145,171,173, +233,213,212,211,210,209,208,177,139,107,104,102,97,44,37,31,29,27,25,23,13, + 11,7,0,3,4,5,98,231, +233,213,212,211,210,209,208,177,139,107,104,102,97,86,44,37,31,29,27,25,23, + 13,11,7,0,3,4,5,98,231, +245,244,128,123,122,113,25,23,0,22,24,111,112,117,119, +245,244,243,131,128,123,122,113,35,33,25,23,21,0,20,22,24,34,58,92,111,112, + 115,117,119,138,140,146, +139,0, +139,0, +75,0, +243,233,131,107,104,102,97,0,3,4,8,9,98,99,100,101,103,231, +213,212,210,209,177,107,104,102,44,37,29,27,13,7,0,73, +233,213,212,210,209,107,104,102,97,44,37,29,27,0,3,4,5,98,231, +233,97,0,3,4,98,231, +243,131,80,0,58,60,61,62,76,92, +233,97,0,3,4,98,231, +233,97,0,3,4,98,188,231, +245,244,243,154,131,128,123,122,113,35,33,25,23,21,19,17,0,16,18,20,22,24, + 34,58,92,111,112,115,117,119,132,134,135,136,137,138,140,146,151,152, + 207, +233,97,17,0,3,4,5,98,231, +13,0,12, +25,23,0,22,24, +243,131,0,58,92,149, +154,0,151,152, +33,0,32, +233,213,212,210,209,177,107,104,102,97,44,37,29,27,13,7,0,3,4,5,98,231, +243,131,0,178,179, +233,97,17,0,3,16,98,231, +29,7,0,6,28, +243,233,131,97,0,3,98,204,231, +107,104,102,29,7,0,6,99,100,101,103,195,206, +17,0,47,214, +245,244,128,123,122,113,33,25,23,0,22,24,111,112,115,117,119, +245,244,243,233,213,212,210,209,131,128,107,104,102,97,44,37,29,27,13,7,0,3, + 4,5,98,231, +245,244,243,131,128,123,122,113,35,33,25,23,21,0,20,22,24,34,58,92,111,112, + 115,117,119,134,136,137,138,140,146, +243,131,80,0,58,60,61,76,92, +245,244,243,233,131,128,97,0,3,4,98,231, +245,244,243,154,131,128,123,122,113,35,33,29,25,23,21,19,17,0,16,18,20,22, + 24,34,58,92,111,112,115,117,119,132,134,135,136,137,138,140,146,151,152, +247,246,245,244,243,208,177,174,172,170,169,168,167,166,165,164,163,162,161, + 160,154,139,131,128,113,106,97,90,87,86,75,59,37,35,31,29,27,25,23,21, + 19,17,15,13,7,0,116,142,143,144,145,171,173, +25,23,0,22,24, +243,233,131,97,0,3,98,204,231, +33,0,32, +245,244,243,131,128,0, + +}; + + +static unsigned const char ag_astt[4088] = { + 5,1,5,8,8,8,1,5,5,5,7,1,1,1,0,1,1,3,3,3,3,3,1,3,3,3,3,3,3,3,3,3,3,3,3,3,3, + 3,3,3,3,3,3,3,3,3,3,3,3,3,3,3,3,3,3,7,2,1,1,9,5,3,3,1,8,8,1,8,1,8,8,8,7,1, + 1,1,1,1,1,1,1,1,1,1,1,1,1,1,1,1,1,5,5,1,1,1,1,1,1,1,1,1,1,1,1,1,1,1,1,1,1, + 1,1,7,1,3,3,7,8,1,7,1,5,1,5,5,5,5,5,5,5,5,5,5,5,5,5,5,1,9,8,1,9,5,5,5,5,5, + 5,7,3,3,1,1,3,1,2,2,1,1,1,7,1,1,1,1,1,1,1,1,1,2,1,1,1,9,9,9,9,9,9,9,9,9,9, + 9,9,9,9,9,9,9,9,9,9,9,9,9,9,9,9,9,9,9,9,9,9,9,9,5,3,7,8,1,7,1,3,7,5,5,5,1, + 5,5,5,5,5,1,8,1,1,5,5,5,5,5,5,5,7,1,1,3,3,1,3,1,3,1,1,2,2,1,7,1,1,1,1,5,5, + 5,5,5,5,5,5,5,5,5,5,5,5,5,5,8,1,5,5,5,5,5,5,5,5,5,5,5,5,5,5,5,5,5,5,5,7,1, + 1,1,2,10,10,10,1,5,5,5,5,5,5,5,5,10,10,5,5,5,1,5,5,5,5,5,5,5,5,5,5,5,5,5,5, + 5,5,5,7,1,1,3,1,1,2,2,7,1,2,1,1,1,4,1,5,1,5,5,5,5,5,5,5,5,5,5,5,5,5,5,8,8, + 8,1,5,5,5,7,1,1,1,1,1,1,1,1,1,1,1,1,1,1,1,1,1,1,1,1,1,1,1,1,1,1,1,1,1,1,1, + 1,4,1,1,1,1,1,1,1,1,7,1,1,1,1,1,1,1,1,1,4,1,1,4,1,3,1,8,1,7,1,1,1,1,8,1,7, + 1,1,1,1,8,1,7,1,1,1,1,8,1,7,1,1,1,2,2,8,1,1,1,7,1,1,1,1,1,1,1,1,1,1,1,2,1, + 1,1,3,7,1,7,8,1,7,3,1,5,5,5,5,5,1,5,5,5,5,5,5,5,5,5,5,5,5,1,5,8,1,9,5,5,5, + 5,5,5,5,5,5,5,5,5,5,5,5,5,5,5,5,7,3,3,3,1,3,1,1,4,4,4,4,7,1,5,5,5,8,1,5,1, + 5,5,5,8,5,7,1,1,1,1,7,3,7,5,5,5,5,5,5,5,5,5,5,5,5,5,5,5,5,8,1,5,5,5,5,5,5, + 5,5,5,5,5,5,5,5,5,5,5,5,5,7,1,3,2,2,2,1,2,2,9,5,3,3,1,1,4,1,4,1,5,5,5,1,5, + 5,5,5,5,5,1,8,1,1,5,5,5,5,5,5,5,5,5,5,7,1,1,3,3,1,3,1,3,1,1,2,2,7,2,1,1,8, + 8,8,8,8,8,8,8,8,8,8,8,8,8,8,1,8,1,8,8,5,7,1,1,1,1,1,7,3,1,1,1,1,1,1,1,1,5, + 1,1,1,1,1,1,1,1,1,1,1,1,1,1,1,1,1,1,1,1,1,1,1,1,1,7,1,1,3,1,1,1,1,1,1,1,1, + 1,1,1,1,1,1,1,1,1,1,1,1,1,1,5,1,1,1,1,1,1,1,1,1,1,1,7,1,1,3,3,7,3,7,8,1,7, + 1,8,8,8,8,8,8,8,8,8,8,8,8,8,8,8,8,8,8,8,8,8,8,8,8,8,8,8,8,5,8,8,8,8,8,8,8, + 8,8,7,1,1,7,2,5,5,5,5,5,1,5,5,5,5,5,5,5,5,5,5,5,1,5,8,1,1,5,5,5,5,5,5,5,5, + 5,5,5,5,5,5,5,5,5,5,7,1,1,3,3,1,3,1,3,1,1,5,5,2,2,2,5,5,5,1,1,1,1,1,1,1,1, + 1,7,1,1,1,1,2,2,1,2,1,1,1,2,1,2,1,2,1,1,1,1,1,2,1,1,1,5,5,5,1,5,5,5,7,1,1, + 2,1,1,5,5,5,1,5,5,5,5,5,5,5,5,5,1,5,5,5,5,5,5,5,5,5,5,5,7,1,1,3,1,1,4,4,4, + 4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,1,7,1,1,2,1,2,1,5,1,5,1,9,8,1,9,5,5, + 5,5,7,3,3,1,1,3,1,4,1,4,1,9,8,1,9,4,4,4,4,7,3,3,1,1,3,1,5,1,5,1,9,8,1,9,5, + 5,5,5,7,3,3,1,1,3,1,4,1,4,1,9,8,1,9,4,1,4,4,4,1,7,1,3,1,2,1,1,3,1,1,3,1,1, + 8,1,5,7,1,1,1,1,8,1,4,7,1,1,1,3,7,1,1,5,1,1,1,1,8,1,8,1,7,1,1,1,1,1,4,4,4, + 4,7,1,1,1,7,2,2,1,2,1,1,1,5,1,5,1,5,7,1,1,2,1,1,2,2,1,7,1,1,1,1,5,5,5,5,5, + 5,5,5,5,5,7,5,1,5,1,8,1,1,7,1,1,2,2,1,2,1,2,1,1,2,1,1,1,1,1,1,1,1,1,1,1,1, + 1,2,1,1,5,7,1,1,1,1,1,1,3,1,1,1,1,1,5,5,5,5,5,5,5,5,1,5,5,5,5,5,5,7,1,1,3, + 1,1,3,3,3,3,3,3,3,3,3,3,3,3,3,3,3,3,3,3,3,3,3,3,3,3,3,3,3,3,3,3,3,3,3,3,3, + 3,7,3,9,9,9,9,9,9,9,1,9,9,9,9,9,9,9,9,9,9,9,9,9,9,9,9,9,9,9,9,9,9,9,9,9,5, + 3,3,3,3,3,3,3,3,3,3,3,3,3,3,3,3,3,3,3,3,3,3,3,3,3,3,3,3,3,3,3,3,3,3,3,3,3, + 7,3,9,9,9,9,9,9,9,1,9,9,9,9,9,9,9,9,9,9,9,9,9,9,9,9,9,9,9,9,9,9,9,9,9,5,3, + 3,7,9,9,9,9,9,1,9,9,9,1,9,9,9,9,1,9,9,9,9,9,9,9,9,9,9,9,1,9,9,9,9,9,9,1,9, + 9,9,4,3,1,1,1,3,1,1,5,5,5,5,5,5,5,5,1,5,5,5,5,5,5,7,1,1,3,1,1,5,5,5,5,5,1, + 5,5,5,5,5,5,5,5,5,1,5,8,1,1,5,5,5,5,5,5,5,5,5,5,5,5,5,5,5,5,5,7,1,1,3,3,1, + 3,1,3,1,1,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,1,4,4,4, + 7,2,1,1,1,5,5,5,1,5,5,5,5,5,5,1,8,1,1,5,5,5,5,5,5,5,5,7,1,1,3,3,1,3,1,3,1, + 1,5,5,5,1,5,5,5,5,5,5,5,1,8,1,1,5,5,5,5,5,5,5,5,5,5,5,5,7,1,1,3,3,1,3,1,3, + 1,1,2,2,2,2,2,2,2,1,1,2,2,2,2,2,2,2,2,2,2,2,2,2,2,2,2,2,2,2,2,2,2,2,2,2,2, + 2,2,2,2,2,2,2,2,2,2,7,2,2,2,2,1,1,1,1,2,1,1,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4, + 4,4,7,1,2,1,1,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,1,7,1,1,2,1,2,1,1,1, + 1,4,5,5,5,1,5,5,5,5,5,1,8,1,1,5,5,5,5,5,7,1,1,3,3,1,3,1,3,1,1,5,5,5,1,5,5, + 5,5,5,1,8,1,1,5,5,5,5,5,7,1,1,3,3,1,3,1,3,1,1,2,2,2,1,1,7,1,1,1,1,1,1,1,1, + 1,1,1,1,1,1,1,1,1,1,1,1,1,1,1,1,1,1,1,1,1,1,1,1,1,1,1,7,1,1,1,1,1,1,1,1,1, + 2,2,2,2,2,2,2,2,2,2,2,1,1,1,1,1,1,1,1,1,1,1,1,1,1,1,1,1,1,1,1,1,1,1,1,1,7, + 1,1,1,1,1,1,1,5,5,5,1,5,5,5,5,5,1,8,1,1,5,5,5,5,5,7,1,1,3,3,1,3,1,3,1,1,5, + 5,2,2,5,5,5,1,1,1,1,1,1,7,1,2,2,1,2,1,1,1,2,1,2,1,1,1,1,1,1,1,4,5,5,2,2,5, + 5,5,1,1,1,1,1,1,7,1,2,2,1,2,1,1,1,2,1,2,2,2,2,1,5,1,1,1,1,1,4,2,1,1,5,5,2, + 2,2,5,5,5,1,1,1,1,1,1,1,1,1,7,1,1,1,1,2,2,1,2,1,1,1,1,2,1,2,1,2,1,1,1,1,1, + 1,1,1,1,4,4,4,4,4,1,1,7,1,1,2,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4, + 4,4,4,4,4,4,1,4,4,4,7,2,1,1,1,1,5,1,3,5,5,5,1,5,5,5,5,5,5,1,8,1,1,5,5,5,5, + 5,5,5,5,7,1,1,3,3,1,3,1,3,1,1,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,7,1,2,1,1, + 5,1,3,5,1,5,1,9,8,1,9,5,5,5,5,7,3,3,1,1,3,1,4,1,4,1,9,8,1,9,4,1,4,4,4,1,7, + 1,3,1,2,1,1,3,1,1,3,1,1,9,5,3,3,1,2,2,7,2,1,8,1,8,1,7,1,1,1,1,1,5,1,5,5,5, + 5,1,5,5,5,5,5,5,5,7,1,1,2,1,1,2,2,5,2,1,1,1,7,2,1,1,1,1,1,1,1,1,5,2,2,1,1, + 2,1,1,7,1,1,7,1,1,1,1,1,1,8,7,1,1,1,1,1,1,1,7,1,1,1,1,1,1,7,1,1,1,1,1,1,7, + 1,1,1,2,1,1,1,7,1,1,1,1,1,1,7,1,1,1,1,1,8,1,8,1,7,1,1,1,1,1,3,1,1,8,1,8,1, + 7,1,1,1,1,1,3,1,1,1,7,1,1,1,2,1,1,1,7,1,1,1,2,1,1,1,7,1,1,1,2,1,1,1,7,1,1, + 1,2,1,1,1,7,1,1,1,2,1,1,1,7,1,1,1,2,1,1,1,8,1,1,7,1,1,1,1,1,1,1,1,1,2,2,7, + 2,1,10,10,10,1,10,10,1,8,7,1,1,1,1,1,2,2,7,2,1,1,4,1,1,8,1,5,7,1,3,1,1,3,7, + 3,7,8,1,7,1,8,8,8,8,8,8,8,8,8,8,8,8,8,8,8,8,8,8,8,8,8,8,8,8,8,8,8,8,8,8,8, + 8,8,8,8,8,8,8,7,1,1,1,1,1,1,1,1,1,1,1,1,1,1,1,1,1,1,1,1,1,1,1,1,1,1,1,1,1, + 1,1,1,7,1,1,1,1,1,7,2,2,7,2,2,2,2,7,1,2,2,2,5,2,2,5,2,2,5,10,10,10,10,5,2, + 2,2,2,2,1,1,2,2,2,2,2,2,2,2,2,2,2,1,2,2,2,2,2,2,2,2,2,2,2,2,2,2,2,2,2,2,2, + 2,2,2,2,7,2,2,2,2,2,1,1,4,4,4,4,4,4,4,1,1,7,1,1,2,1,1,1,1,7,2,1,3,1,1,5,1, + 3,1,5,1,3,1,1,7,2,1,5,5,5,5,5,5,5,5,1,5,5,5,5,5,5,7,1,1,2,1,1,2,2,2,2,7,1, + 2,10,10,4,10,10,10,5,1,5,5,5,5,5,5,5,5,5,5,5,5,1,5,5,5,5,5,5,5,5,5,5,7,1,1, + 2,1,1,1,5,5,5,5,5,5,5,5,5,5,5,5,1,5,5,5,5,5,5,5,5,5,5,7,1,1,2,1,1,1,1,7,2, + 1,1,1,7,1,1,2,8,8,1,8,8,8,8,1,8,1,1,8,8,7,1,1,1,1,1,1,1,1,1,1,8,8,8,1,8,8, + 8,8,8,1,8,1,1,8,8,8,8,8,7,1,1,1,1,1,1,1,1,1,1,1,5,5,5,5,5,5,5,5,1,5,5,5,5, + 5,5,7,1,1,3,1,1,1,5,5,5,5,5,5,5,5,1,5,5,5,5,5,5,7,1,1,2,1,1,1,5,5,5,5,5,5, + 5,5,1,5,5,5,5,5,5,7,1,1,2,1,1,5,5,2,2,5,5,5,1,1,1,1,1,1,7,1,2,2,1,2,1,1,1, + 2,1,2,1,1,1,1,5,5,2,2,5,5,5,1,1,1,1,1,1,7,1,2,2,1,2,1,1,1,2,1,2,1,1,1,1,4, + 4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,1,4,4,4,7,2,1,1,1,1, + 1,1,1,1,4,2,1,1,4,4,4,4,1,4,4,4,4,4,4,4,4,4,7,2,5,5,2,2,2,5,5,5,1,1,1,1,1, + 1,1,1,1,7,1,1,1,1,2,2,1,2,1,1,1,1,2,1,2,1,2,1,1,1,1,1,1,1,1,1,1,7,2,2,7,2, + 1,1,7,2,5,1,5,1,5,7,1,1,2,1,1,1,5,5,5,1,5,5,5,5,5,5,5,7,1,1,2,1,1,1,1,9,4, + 3,3,1,1,7,1,1,1,9,7,3,3,1,1,1,9,7,3,3,1,1,9,1,7,3,1,3,1,1,1,9,7,3,3,1,5,5, + 2,1,2,2,5,5,5,1,9,1,1,1,1,1,1,1,7,3,1,1,1,2,2,1,2,1,3,1,1,2,1,2,2,1,2,1,1, + 1,1,1,1,1,1,1,7,3,2,2,5,1,1,3,5,5,2,2,5,5,5,1,1,1,5,1,1,1,7,1,2,2,1,2,1,1, + 1,2,1,2,1,1,1,1,1,1,1,7,1,2,2,2,1,2,2,1,8,1,9,5,7,3,3,3,1,3,1,1,1,7,1,2,2, + 2,1,2,2,9,5,3,3,1,5,5,2,2,2,5,5,5,1,1,1,7,2,2,1,2,1,1,2,1,2,2,1,2,1,1,1,1, + 1,1,1,1,1,1,1,1,1,1,2,1,9,8,1,9,1,1,5,7,3,1,1,1,1,3,1,1,3,1,3,3,1,1,1,3,7, + 9,9,9,9,9,1,9,9,9,1,9,9,9,9,1,9,9,9,9,9,9,9,9,9,9,9,1,9,3,9,9,9,9,9,1,9,9, + 9,7,3,1,1,1,3,1,3,7,3,7,9,9,9,9,9,1,9,9,9,9,1,9,9,9,9,9,9,9,9,9,9,9,9,1,9, + 9,9,9,9,9,9,9,9,4,3,3,1,1,3,1,1,5,5,5,1,5,7,1,1,2,1,1,2,2,2,2,4,2,1,5,5,5, + 5,5,5,5,5,5,1,5,5,5,5,5,5,7,1,1,3,1,1,1,5,5,5,5,5,5,5,5,1,5,5,5,5,5,5,7,1, + 1,2,1,1,1,5,5,5,5,5,5,5,5,1,5,5,5,5,5,5,7,1,1,2,1,1,4,4,4,4,4,4,4,4,4,4,4, + 4,4,4,4,4,4,7,2,1,1,1,5,5,5,5,5,5,5,5,1,5,5,5,5,5,5,7,1,1,2,1,1,1,5,5,5,5, + 5,5,5,5,1,5,5,5,5,5,5,7,1,1,2,1,1,2,2,2,2,4,2,1,1,1,1,1,1,1,1,1,2,2,2,2,2, + 2,2,2,2,2,2,1,1,1,1,1,1,1,1,1,1,1,1,1,1,1,1,1,1,1,1,1,1,1,1,1,7,1,1,1,1,1, + 1,1,1,5,5,5,5,5,5,5,5,5,5,5,1,5,5,5,5,5,5,5,5,5,5,7,1,1,3,1,1,1,5,5,5,5,5, + 5,5,5,5,5,5,1,5,5,5,5,5,5,5,5,5,5,5,7,1,1,3,1,1,5,5,5,5,5,1,1,1,7,2,2,2,2, + 1,2,5,5,2,2,5,5,5,1,1,1,1,1,1,7,1,2,2,1,2,1,1,1,2,1,2,2,2,2,1,4,1,4,1,7,8, + 1,8,1,8,1,1,7,1,1,1,1,1,1,1,1,1,1,4,4,4,4,1,4,4,4,4,4,4,4,4,4,7,2,1,5,5,5, + 5,5,5,5,1,5,5,5,5,7,1,1,2,1,1,1,1,7,1,1,1,1,2,2,1,7,1,2,1,1,1,1,1,1,7,1,1, + 1,1,1,1,7,1,1,1,2,1,5,5,2,2,2,5,5,5,1,1,1,1,1,1,1,1,7,1,1,1,2,2,1,2,1,1,1, + 2,1,2,2,1,2,1,1,1,1,1,1,1,1,1,1,8,7,1,1,1,1,1,1,4,1,1,1,4,1,1,2,2,7,1,1,3, + 2,7,2,1,1,7,2,1,5,5,5,5,5,5,5,5,1,5,5,5,5,5,5,7,1,1,2,1,1,2,2,7,2,1,1,9,1, + 7,3,1,3,1,1,1,7,1,3,2,1,2,9,7,3,3,1,1,1,8,1,8,1,7,1,1,1,1,1,3,1,1,7,2,1,5, + 5,5,5,5,1,1,1,1,7,2,2,2,2,2,1,2,10,10,10,1,5,5,5,5,10,10,5,5,5,1,5,5,5,5,5, + 5,7,1,1,3,1,1,5,5,2,2,5,5,5,1,1,1,1,1,1,7,1,2,2,1,2,1,1,1,2,1,2,1,1,1,1,1, + 1,2,2,1,7,1,2,3,1,1,9,9,9,1,9,9,1,7,1,1,1,1,5,5,2,2,2,5,5,5,1,1,1,5,1,1,1, + 1,1,7,1,1,1,2,2,1,2,1,1,1,2,1,2,2,1,2,1,1,1,1,1,1,1,1,1,1,1,1,1,1,1,1,2,2, + 2,2,2,2,2,2,2,2,2,1,1,1,1,1,1,1,1,1,1,1,1,1,1,1,1,1,1,1,1,1,1,1,1,1,7,1,1, + 1,1,1,1,1,1,1,4,1,1,2,1,2,9,7,3,3,1,1,1,7,2,9,9,9,9,9,4 +}; + + +static const unsigned short ag_pstt[] = { +3,1,3,3,3,3,2,3,3,3,0,2,2,3,0,2,1, +308,308,308,308,308,1,306,308,308,308,308,308,308,308,308,308,308,308,308, + 308,308,308,308,308,308,308,308,308,308,308,308,308,308,308,308,308,308, + 308,1,309,1, +1,2,4,2,2,1, +8,8,4,5,5,8,8,8,3,7,8,6,5, +9,9,9,9,9,9,9,9,9,9,9,9,9,9,125,125,9,9,9,9,9,9,9,9,9,9,9,9,9,9,9,9,9,9,9,9, + 4,9,127, +120,5, +10,10,6,10, +24,1,24,24,24,24,24,24,24,24,24,24,24,24,24,24,4,122,12,12,121,24,24,24,24, + 24,24,7,121,121,11,12,121,1, +98,98,13,19,15,8,14,27,26,25,24,23,22,18,17,48,21,16,20, +124,124,124,124,124,124,124,124,124,124,124,124,124,124,124,124,124,124,124, + 124,124,124,124,124,124,124,124,124,124,124,124,124,124,124,126, +119,10, +28,28,11,28, +117,12, +6,6,6,1,6,6,6,6,6,4,29,29,31,6,6,6,6,6,6,6,13,31,31,14,14,31,14,30,14,29,1, +98,98,32,14,33,34,33,16, +279,279,279,279,279,279,279,279,279,279,279,279,279,279,279,279,35,35,279, + 279,279,279,279,279,279,279,279,279,279,279,279,279,279,279,279,279,279, + 15,35,36,36,281, +99,99,99,1,3,3,3,3,3,3,3,3,99,99,3,3,3,37,3,3,3,3,3,3,3,3,3,3,3,3,3,3,3,3,3, + 16,37,37,104,37,1, +98,98,17,39,48,38,16, +40,46,41, +3,1,3,3,3,3,3,3,3,3,3,3,3,3,3,3,42,42,42,2,3,3,3,19,2,2,42,2,43,1, +49,49,49,49,49,1,49,49,49,44,49,49,49,49,4,49,49,49,49,49,49,49,49,49,45,49, + 282,49,49,49,49,49,49,49,49,20,49,48,50,49,47,46,1, +53,51,50,52, +54,36,55,37, +4,5,5,23,56,6,5, +4,5,5,24,57,6,5, +4,5,5,25,58,6,5, +4,5,5,26,59,6,5, +98,98,62,13,19,15,27,14,62,62,61,60,60,60,60,22,18,17,48,21,16,20, +118,28, +63,29, +29,29,30,110,29, +107,107,107,107,107,1,107,107,107,107,107,107,107,107,107,107,107,107,4,107, + 29,29,2,107,107,107,107,107,107,107,107,107,107,107,107,107,107,107,107, + 107,107,107,31,2,2,108,30,108,29,1, +81,81,81,81,32,64, +75,75,75,66,67,75,65,75,75,75,66,75,33,69,66,68, +70,34, +276,35, +280,280,280,280,280,280,280,280,280,280,280,280,280,280,280,280,35,35,280, + 280,280,280,280,280,280,280,280,280,280,280,280,280,280,280,280,280,280, + 36,35,278, +100,100,100,1,100,100,2,4,2,2,1, +53,50, +40,47,41, +6,6,6,1,6,6,6,6,6,6,4,29,29,31,6,6,6,6,6,6,6,6,6,6,40,31,31,8,8,31,8,30,8, + 29,1, +98,98,41,49,38,16, +71,71,71,71,71,71,71,71,71,71,71,71,71,71,71,4,5,5,71,71,23,42,7,71,6,5, +72,43,220, +74,74,74,74,74,74,74,73,315,74,74,74,74,74,74,74,74,74,74,74,74,74,74,74,74, + 74,74,74,74,74,74,74,74,74,44,74,74,317, +76,76,76,76,76,76,76,75,76,76,76,76,76,76,76,76,76,76,76,76,76,76,323,76,76, + 76,76,76,76,76,76,76,76,76,45,76,76,325, +288,46, +287,47, +77,77,48,77, +78,78,78,78,78,78,78,78,78,78,78,78,78,78,78,78,78,78,78,78,78,78,78,78,78, + 78,78,78,289,78,78,78,78,78,78,78,78,78,49,78, +79,50,275, +6,6,6,6,6,1,6,6,6,6,6,6,6,6,6,6,6,4,6,29,29,31,6,6,6,6,6,6,6,6,6,6,6,6,6,6, + 6,6,6,6,51,31,31,10,10,31,10,30,10,29,1, +132,132,98,185,98,132,132,132,91,93,92,88,89,13,82,83,80,52,81,86,85,94,135, + 134,96,169,16,95,95,168,90,134,98,174,97,98,97,97,97,175,87,84, +1,3,3,3,2,3,3,3,53,2,2,51,2,1, +3,3,3,1,3,3,3,3,3,3,3,3,3,2,3,3,3,3,3,3,3,3,3,3,3,54,2,2,5,2,1, +71,71,71,71,71,71,71,71,71,72,72,72,72,72,71,71,71,71,71,71,71,71,51,55,101, + 102,64,100,65,99, +31,1,31,4,122,12,12,121,31,31,31,31,56,121,121,11,12,121,1, +30,1,30,4,122,12,12,121,30,30,30,30,57,121,121,11,12,121,1, +29,1,29,4,122,12,12,121,29,29,29,29,58,121,121,11,12,121,1, +28,1,28,4,122,12,12,121,28,103,28,28,28,54,59,55,121,104,38,105,105,121,11, + 12,121,1, +4,5,5,35,60,106,6,5, +4,5,5,34,61,107,6,5, +27,62, +1,108,114,108,108,108,1, +109,1,109,2,64,2,2,109,2,1, +83,83,83,83,65,110, +111,13,66,91,79,114,79,113,112,114, +3,1,3,2,3,67,2,2,89,2,1, +98,98,32,68,33,115,33,16, +76,76,76,78,76,76,76,76,78,76,69, +6,1,6,4,29,29,31,70,31,31,52,52,31,52,30,52,29,1, +98,117,118,119,120,121,122,125,126,127,128,129,130,116,98,131,93,221,71,134, + 135,16,133,123,136,223,136,136,132,124, +1,3,3,3,3,3,3,3,3,2,3,3,3,3,3,3,72,2,2,17,2,1, +312,312,312,312,312,312,312,312,312,312,312,312,312,312,312,312,312,312,312, + 312,312,312,312,312,312,312,312,312,312,312,312,312,312,312,312,312,73, + 312, +314,314,314,314,314,314,314,73,314,314,314,314,314,314,314,314,314,314,314, + 314,314,314,314,314,314,314,314,314,314,314,314,314,314,316,314, +320,320,320,320,320,320,320,320,320,320,320,320,320,320,320,320,320,320,320, + 320,320,320,320,320,320,320,320,320,320,320,320,320,320,320,320,320,75, + 320, +322,322,322,322,322,322,322,75,322,322,322,322,322,322,322,322,322,322,322, + 322,322,322,322,322,322,322,322,322,322,322,322,322,322,324,322, +286,77, +290,290,290,290,290,1,290,290,290,44,290,290,290,290,4,290,290,290,290,290, + 290,290,290,290,290,290,45,290,290,290,290,290,290,140,290,290,290,283, + 290,139,138,137,290,1, +1,3,3,3,3,3,3,3,3,2,3,3,3,3,3,3,79,2,2,18,2,1, +6,6,6,6,6,1,6,6,6,6,6,6,6,6,6,4,6,29,29,31,6,6,6,6,6,6,6,6,6,6,6,6,6,6,6,6, + 6,80,31,31,11,11,31,11,30,11,29,1, +297,297,297,297,297,297,297,297,297,297,297,297,297,297,297,297,297,297,297, + 297,297,297,297,297,297,297,297,297,15,297,297,297,81,271,142,20,141, +6,6,6,1,6,6,6,6,6,6,4,29,29,31,6,6,6,6,6,6,6,6,82,31,31,13,13,31,13,30,13, + 29,1, +6,6,6,1,6,6,6,6,6,6,6,4,29,29,31,6,6,6,6,6,6,6,6,6,6,6,6,83,31,31,12,12,31, + 12,30,12,29,1, +206,206,207,207,206,206,206,144,143,199,198,197,196,195,194,193,192,191,190, + 189,206,207,207,206,206,206,206,206,206,206,206,206,206,206,206,206,206, + 206,206,206,206,206,206,206,206,84,206,211,188,213,149,148,147,149,206, + 146,145, +71,71,71,71,71,71,71,71,71,71,71,71,71,71,71,71,71,85,151,56,150,99, +71,71,71,72,71,71,71,71,71,71,72,71,71,72,71,71,71,71,71,71,51,86,101,152, + 56,153,59,154,150,99, +155,260, +6,6,6,1,6,6,6,6,6,4,29,29,31,6,6,6,6,6,88,31,31,16,16,31,16,30,16,29,1, +6,6,6,1,6,6,6,6,6,4,29,29,31,6,6,6,6,6,89,31,31,15,15,31,15,30,15,29,1, +141,141,143,156,156,90,159,158,157,156, +160,160,160,160,160,160,160,160,160,160,160,160,160,160,160,160,160,160,160, + 160,160,160,160,160,160,160,160,160,160,160,160,91, +161,161,161,161,161,161,161,144,143,199,198,197,196,195,194,193,192,191,190, + 189,161,161,161,161,161,161,161,161,161,161,161,161,161,161,161,161,161, + 161,161,161,161,161,161,161,161,92,161,161,161,161,161,146,145, +6,6,6,1,6,6,6,6,6,4,29,29,31,6,6,6,6,6,93,31,31,21,21,31,21,30,21,29,1, +132,132,98,98,132,132,132,91,93,92,88,89,13,94,94,135,134,96,169,16,95,95, + 168,90,134,162,97,162,97,97,97, +163,167, +132,132,98,98,132,132,132,91,93,92,88,89,13,96,94,135,134,96,169,16,95,95, + 168,90,134,160,160,160, +164,153, +166,167,88,89,165,173,268,168,169, +132,132,98,185,98,132,132,132,91,93,92,88,89,13,82,83,80,99,170,86,85,94, + 135,134,96,169,172,16,95,95,168,90,134,172,150,171,172,97,171,97,97,97, + 87,84, +72,72,72,72,72,51,40,100,173,101,68, +297,297,297,297,297,297,297,297,297,297,297,297,297,297,297,297,297,297,297, + 297,297,297,297,297,297,297,297,297,15,297,297,297,101,73,174,20,141, +103,42,104,66, +6,6,6,1,6,6,6,6,6,6,4,29,29,31,6,6,6,6,6,6,6,6,103,31,31,22,22,31,22,30,22, + 29,1, +71,71,71,71,71,71,71,71,71,71,71,71,71,71,71,71,71,104,100,67,99, +103,41,104,40, +33,1,33,4,122,12,12,121,33,33,33,33,106,121,121,11,12,121,1, +32,1,32,4,122,12,12,121,32,103,32,32,32,54,107,55,121,104,38,105,105,121,11, + 12,121,1, +1,2,115,2,2,1, +98,98,109,82,16, +175,1,175,2,110,2,2,175,2,1, +3,1,3,3,3,3,2,3,3,3,3,3,3,3,111,2,2,93,2,1, +98,98,94,95,16, +111,13,113,91,176,114,176,113,112,114, +111,13,85,91,87,113,112,97, +178,177,115, +1,179,116,179,179,179,1, +1,2,180,117,2,2,180,2,1, +1,181,118,181,181,181,1, +1,182,119,182,182,182,1, +1,183,120,183,183,183,245,1, +1,184,121,184,184,184,1, +1,185,122,185,185,185,1, +4,29,29,186,40,123,187,186,30,186,29,242,186, +4,29,29,186,40,124,188,186,30,186,29,241,186, +1,183,125,183,183,183,240,1, +1,183,126,183,183,183,239,1, +1,183,127,183,183,183,238,1, +1,183,128,183,183,183,237,1, +1,183,129,183,183,183,236,1, +1,183,130,183,183,183,235,1, +1,4,29,29,190,131,190,190,189,190,189,30,189,29,1, +98,98,132,233,16, +102,102,102,1,102,102,192,191,133,192,192,191,192,1, +98,98,134,227,16, +51,226,193, +4,5,5,23,136,194,222,6,5, +296,137, +295,138, +195,195,139,195, +196,196,196,196,196,196,196,196,196,196,196,196,196,196,196,196,196,196,196, + 196,196,196,196,196,196,196,196,196,196,196,196,196,196,196,196,196,196, + 196,140,196, +199,199,199,199,199,199,199,199,199,44,199,199,199,199,199,199,199,199,199, + 199,199,45,199,199,199,199,199,199,199,199,199,141,198,197,199,199, +200,142, +200,200,143, +147,147,148,147,144,201,145, +202,202,204, +201,201,203, +210,210,183, +209,209,209,209,182, +208,208,208,208,208,144,143,199,198,197,196,195,194,193,192,191,190,189,202, + 208,208,208,208,208,208,208,208,208,208,208,208,208,208,208,208,208,208, + 208,208,208,208,208,149,208,212,188,214,208,146,145, +72,72,72,72,72,72,72,51,40,150,173,101,63, +203,204,103,72,151,264,205,57, +206,103,62,205,57, +103,61,205,60, +207,79,154,262, +1,3,3,3,3,3,3,3,3,2,3,3,3,3,3,3,155,2,2,261,2,1, +147,147,148,147,156,208,145, +144,144,137, +142,142,142,136, +1,3,3,3,3,3,3,3,3,3,3,3,3,2,3,3,3,3,3,3,3,3,3,3,159,2,2,131,2,1, +1,3,3,3,3,3,3,3,3,3,3,3,3,2,3,3,3,3,3,3,3,3,3,3,160,2,2,129,2,1, +210,209,161,130, +211,88,89,162,168,169,170, +212,212,1,212,212,212,212,4,29,29,31,212,212,163,31,31,212,212,31,212,30, + 212,29,1, +213,213,213,1,213,213,213,213,213,4,29,29,31,213,213,213,213,213,164,31,31, + 213,213,31,213,30,213,29,1, +1,3,3,3,3,3,3,3,3,2,3,3,3,3,3,3,165,2,2,9,2,1, +1,3,3,3,3,3,3,3,3,2,3,3,3,3,3,3,166,2,2,267,2,1, +1,3,3,3,3,3,3,3,3,2,3,3,3,3,3,3,167,2,2,266,2,1, +132,132,98,98,132,132,132,91,93,92,88,89,13,168,94,135,134,96,169,16,95,95, + 168,90,134,214,214,214,214, +132,132,98,98,132,132,132,91,93,92,88,89,13,169,94,135,134,96,169,16,95,95, + 168,90,134,215,215,215,215, +297,297,297,297,297,297,297,297,297,297,297,297,297,297,297,297,297,297,297, + 297,297,297,297,297,297,297,297,297,15,297,297,297,170,273,216,20,141, +166,167,88,89,165,151,268,168,169, +215,215,215,215,217,215,215,215,215,215,215,215,215,215,172,69, +132,132,98,185,98,132,132,132,91,93,92,88,89,13,82,83,80,173,170,86,85,94, + 135,134,96,169,218,16,95,95,168,90,134,218,150,171,218,97,171,97,97,97, + 87,84, +219,174, +98,98,175,84,16, +211,176,92, +3,1,3,2,3,177,2,2,90,2,1, +1,3,3,3,2,3,3,3,3,3,3,3,178,2,2,88,2,1, +1,220,2,234,2,2,1, +83,180,221, +1,222,2,181,2,2,1, +1,223,2,182,2,2,1, +1,2,83,183,2,224,2,1, +1,225,2,184,2,2,1, +132,132,98,1,185,98,132,132,132,91,2,93,92,88,89,13,82,83,185,2,86,85,94, + 135,134,96,169,16,2,95,95,168,90,134,243,171,243,97,171,97,97,97,87,84, + 1, +79,186,254, +98,98,252,226,16,180, +132,132,98,98,132,132,132,91,93,92,252,88,89,13,188,94,135,134,96,169,16,95, + 95,168,90,134,227,97,227,97,97,97, +83,189,228, +101,101,101,1,101,101,4,29,29,2,107,190,2,2,108,30,108,29,1, +51,191,229, +103,103,103,1,103,103,2,4,2,2,1, +132,132,98,185,98,132,132,132,32,88,89,193,135,134,33,228,33,16,231,90,134, + 229,84, +98,1,117,118,119,120,121,122,125,126,127,128,129,130,116,98,4,122,12,12,121, + 131,93,24,194,121,134,135,16,133,121,11,12,121,123,225,225,132,124,1, +294,195, +290,290,290,290,290,1,290,290,290,44,290,290,290,290,4,290,290,290,290,290, + 290,290,290,290,290,290,45,290,292,290,290,290,290,290,140,290,290,290, + 196,290,139,138,137,290,1, +305,197, +304,198, +300,300,300,300,300,1,300,300,300,300,44,300,300,300,300,300,301,300,300, + 300,300,300,300,45,300,300,300,300,300,300,300,300,300,298,301,301,198, + 197,300,1, +1,3,3,3,2,3,200,2,2,272,2,1, +147,147,148,147,205,146, +1,3,3,3,3,3,3,3,3,3,2,3,3,3,3,3,3,202,2,2,181,2,1, +1,3,3,3,3,3,3,3,3,2,3,3,3,3,3,3,203,2,2,270,2,1, +1,3,3,3,3,3,3,3,3,2,3,3,3,3,3,3,204,2,2,265,2,1, +71,71,71,71,71,71,71,71,71,71,71,71,71,71,71,71,71,205,58,150,99, +1,3,3,3,3,3,3,3,3,2,3,3,3,3,3,3,206,2,2,269,2,1, +1,3,3,3,3,3,3,3,3,2,3,3,3,3,3,3,207,2,2,263,2,1, +147,147,148,147,140,146, +230,230,230,230,230,230,230,144,143,199,198,197,196,195,194,193,192,191,190, + 189,230,230,230,230,230,230,230,230,230,230,230,230,230,230,230,230,230, + 230,230,230,230,230,230,230,230,209,230,230,230,230,230,146,145, +1,3,3,3,3,3,3,3,3,3,3,3,2,3,3,3,3,3,3,3,3,3,3,210,2,2,20,2,1, +1,3,3,3,3,3,3,3,3,3,3,3,2,3,3,3,3,3,3,3,3,3,3,3,211,2,2,19,2,1, +132,132,132,132,132,91,88,89,212,135,134,172,172,90,134, +132,132,98,98,132,132,132,91,93,92,88,89,13,213,94,135,134,96,169,16,95,95, + 168,90,134,158,158,158, +164,156, +164,154, +231,216, +232,1,232,4,29,29,31,217,31,31,232,232,31,232,30,232,29,1, +215,215,215,215,217,215,215,215,215,215,215,215,215,215,218,70, +1,3,3,3,3,3,3,3,2,3,3,3,3,219,2,2,74,2,1, +1,233,220,233,233,233,1, +98,98,32,221,33,53,234,234,33,16, +1,235,222,235,235,235,1, +1,183,223,183,183,183,246,1, +132,132,98,185,98,132,132,132,91,93,92,88,89,13,82,83,224,86,85,94,135,134, + 96,169,16,95,95,168,90,134,258,171,258,97,171,97,97,97,87,84,236, +1,2,237,225,2,2,237,2,1, +51,176,238, +88,89,256,168,169, +98,98,228,226,16,179, +185,229,230,84, +210,230,171, +1,3,3,3,3,3,3,3,3,2,3,3,3,3,3,3,231,2,2,274,2,1, +217,217,232,216,239, +1,2,83,233,2,240,2,1, +79,40,234,241,248, +249,1,249,2,235,2,2,242,1, +4,29,29,186,40,236,243,186,30,186,29,257,186, +15,237,244,20, +132,132,132,132,132,91,244,88,89,238,135,134,177,177,178,90,134, +218,218,218,1,3,3,3,3,218,218,3,3,3,2,3,3,3,3,3,3,239,2,2,219,2,1, +132,132,98,98,132,132,132,91,93,92,88,89,13,240,94,135,134,96,169,16,95,95, + 168,90,134,245,97,245,97,97,97, +98,98,32,241,33,53,55,33,16, +250,250,250,1,250,250,246,242,246,246,246,1, +132,132,98,185,98,132,132,132,91,93,92,252,88,89,13,82,83,243,86,85,94,135, + 134,96,169,16,95,95,168,90,134,259,171,259,97,171,97,97,97,87,84, +247,247,247,247,247,247,247,144,143,199,198,197,196,195,194,193,192,191,190, + 189,247,247,247,247,247,247,247,247,247,247,247,247,247,247,247,247,247, + 247,247,247,247,247,247,247,247,244,247,247,247,247,247,146,145, +88,89,255,168,169, +249,1,249,2,246,2,2,248,1, +210,247,130, +250,250,250,250,250,247, + +}; + + +static const unsigned short ag_sbt[] = { + 0, 17, 58, 64, 77, 116, 118, 122, 156, 175, 210, 212, 216, 218, + 249, 257, 299, 340, 347, 350, 380, 423, 427, 431, 438, 445, 452, 459, + 481, 483, 485, 490, 540, 546, 562, 564, 566, 606, 617, 619, 622, 657, + 663, 689, 692, 730, 768, 770, 772, 776, 816, 819, 870, 912, 926, 957, + 987,1006,1025,1044,1070,1078,1086,1088,1095,1105,1111,1121,1132,1140, + 1151,1169,1199,1221,1259,1294,1332,1367,1369,1413,1435,1483,1520,1553, + 1591,1648,1670,1700,1702,1731,1760,1770,1802,1855,1884,1915,1917,1945, + 1947,1956,2000,2011,2048,2052,2085,2106,2110,2129,2155,2161,2166,2176, + 2196,2201,2211,2219,2222,2229,2238,2245,2252,2260,2267,2274,2287,2300, + 2308,2316,2324,2332,2340,2348,2363,2368,2382,2387,2390,2399,2401,2403, + 2407,2447,2483,2485,2488,2495,2498,2501,2504,2509,2559,2572,2580,2585, + 2589,2593,2615,2622,2625,2629,2659,2689,2693,2700,2724,2753,2775,2797, + 2819,2848,2877,2914,2923,2939,2983,2985,2990,2993,3004,3022,3029,3032, + 3039,3046,3054,3061,3106,3109,3115,3147,3150,3169,3172,3183,3206,3246, + 3248,3293,3295,3297,3337,3349,3355,3378,3400,3422,3443,3465,3487,3493, + 3546,3575,3605,3620,3648,3650,3652,3654,3672,3688,3707,3714,3724,3731, + 3739,3780,3789,3792,3797,3803,3807,3810,3832,3837,3845,3850,3859,3872, + 3876,3893,3919,3950,3959,3971,4012,4065,4070,4079,4082,4088 +}; + + +static const unsigned short ag_sbe[] = { + 10, 55, 60, 72, 113, 117, 120, 149, 161, 209, 211, 214, 217, 238, + 252, 294, 334, 342, 348, 373, 415, 425, 428, 434, 441, 448, 455, 465, + 482, 484, 487, 532, 544, 558, 563, 565, 603, 613, 618, 620, 646, 659, + 684, 690, 726, 764, 769, 771, 774, 814, 817, 859, 887, 920, 951, 980, + 999,1018,1037,1058,1074,1082,1087,1090,1099,1109,1113,1126,1135,1150, + 1158,1187,1215,1257,1292,1330,1365,1368,1406,1429,1472,1515,1542,1580, + 1636,1665,1691,1701,1720,1749,1765,1801,1847,1873,1897,1916,1930,1946, + 1952,1973,2007,2043,2049,2074,2102,2107,2122,2143,2157,2163,2170,2190, + 2198,2203,2213,2221,2224,2232,2240,2247,2254,2262,2269,2279,2292,2302, + 2310,2318,2326,2334,2342,2353,2365,2376,2384,2388,2394,2400,2402,2405, + 2445,2478,2484,2487,2492,2497,2500,2503,2508,2551,2568,2576,2582,2586, + 2591,2609,2619,2624,2628,2653,2683,2691,2696,2713,2742,2769,2791,2813, + 2832,2861,2909,2919,2937,2956,2984,2987,2991,2998,3016,3025,3030,3035, + 3042,3049,3057,3079,3107,3111,3129,3148,3161,3170,3179,3194,3230,3247, + 3286,3294,3296,3330,3343,3353,3372,3394,3416,3439,3459,3481,3491,3538, + 3569,3599,3613,3633,3649,3651,3653,3661,3686,3701,3709,3717,3726,3733, + 3755,3783,3790,3794,3799,3804,3808,3826,3834,3840,3847,3854,3864,3873, + 3885,3913,3932,3953,3966,3988,4057,4067,4074,4080,4087,4088 +}; + + +static const unsigned char ag_fl[] = { + 1,1,2,0,1,2,0,1,2,2,2,2,2,2,2,2,2,2,2,2,2,2,2,0,1,0,1,5,2,2,2,2,3,3,1, + 1,1,2,3,1,2,3,2,1,1,1,1,2,1,3,1,3,4,1,1,3,1,2,2,1,2,1,1,2,1,1,2,2,2,3, + 4,0,0,2,4,1,2,0,1,3,1,0,4,0,5,1,1,2,4,2,4,1,3,2,1,2,1,2,1,2,3,3,2,3,2, + 1,1,1,2,1,2,1,0,1,2,3,1,2,3,3,2,2,2,1,2,0,1,2,1,3,3,3,0,1,1,1,1,1,1,1, + 2,1,2,1,2,1,2,1,1,1,1,1,1,1,3,1,3,1,4,1,2,1,1,1,1,1,1,1,1,1,3,5,4,3,3, + 3,1,3,3,4,3,4,1,1,1,1,1,1,1,1,1,1,1,1,1,1,1,1,1,1,2,2,2,1,1,2,1,1,2,2, + 2,1,2,1,2,0,3,1,2,2,3,0,2,3,1,3,1,2,3,3,4,3,1,2,2,2,2,2,2,2,2,2,2,3,5, + 2,4,7,5,1,2,0,1,1,2,6,3,4,1,3,1,3,3,4,3,4,3,3,2,4,4,2,4,2,4,3,2,1,2,0, + 1,2,0,2,1,1,3,2,2,0,2,1,3,1,3,2,2,0,2,1,2,2,1,1,2,2,2,1,2,2,1,1,2,1,2, + 0,1,2,1,1,2,1,2,0,1,2,1 +}; + +static const unsigned char ag_ptt[] = { + 0, 4, 4, 5, 5, 1, 9, 9, 6, 10, 12, 14, 16, 18, 20, 22, 24, 26, + 28, 30, 32, 34, 36, 40, 40, 43, 43, 38, 41, 41, 41, 41, 41, 41, 42, 42, + 45, 45, 45, 53, 53, 45, 51, 49, 49, 49, 50, 50, 55, 55, 57, 57, 56, 61, + 62, 62, 63, 63, 65, 66, 66, 68, 68, 64, 54, 54, 54, 52, 70, 69, 69, 71, + 67, 67, 67, 60, 60, 78, 78, 60, 76, 81, 76, 82, 76, 79, 79, 79, 77, 85, + 85, 88, 84, 89, 91, 91, 83, 83, 92, 92, 92, 95, 95, 95, 58, 3, 3, 8, + 8, 8, 99, 99,103,103,101,101,105,105,105, 39, 39, 39, 39,109,109,110, + 110,100,111,111,115,112,119,119,117,117,118,118,124,124,118,120,120,121, + 121,125,125,130,130, 72, 72,132,132,134,134,134,137,136,136,138,138,116, + 116,116,116,116,140,140,140,140,140,146,146, 46, 46, 46,149,149,149,150, + 150,151,153,153,153,152,158,158,158,142,142,142,142,142,142,142,142,142, + 142,142,171,173,144,143,143,145,155,155,155,155,155,156,156,157,157, 73, + 73,179,179,178, 48,182,182,180,181,181,183,183,183,183,183,183,183,183, + 185,184,184,184,184,184,184,184,184,184,184,184,184,184,184,204,204,206, + 206,206,195,194,194,188,207,207,135,135,135,135,135,135,135,135,135,135, + 135,148,148,133,133, 47,216,217,217,218,218,214,215,215,219,219,219,219, + 219,220,220,224,224,224,224,224,224,226, 74,227,227,227,228,228,228,228, + 98,231,231, 98,237,237,237,238,238,239,239,223,240,240,240,241,241,242, + 242,222,236 +}; + +static const unsigned char *ag_valid(int ag_k) { + const unsigned char *ag_tp = &ag_tstt[ag_sbt[(PCB).sn+1]]; + while (*--ag_tp != (unsigned char) ag_k) if (*ag_tp == 0) return NULL; + return ag_tp; +} + +int pgg_change_reduction(pgg_token_type ag_k) { + if (!ag_valid(ag_k)) return 0; + (PCB).reduction_token = ag_k; + return 1; +} + +static void ag_default(const int *ag_tp) { + (PCB).ag_dsn = (PCB).sn; + (PCB).ag_dtl = ag_tp; + while (!ag_valid((pgg_token_type) *ag_tp)) ag_tp++; + (PCB).reduction_token = (pgg_token_type) *ag_tp; +} + + + +static void ag_ra(void) +{ + switch(ag_rpx[(PCB).ag_ap]) { + case 1: ag_rp_1(V(0,(int *))); break; + case 2: ag_rp_2(); break; + case 3: ag_rp_1(V(1,(int *))); break; + case 4: ag_rp_4(V(0,(int *))); break; + case 5: V(0,(int *)) = ag_rp_5(V(0,(int *))); break; + case 6: V(0,(int *)) = ag_rp_6(V(0,(int *))); break; + case 7: V(0,(int *)) = ag_rp_7(); break; + case 8: V(0,(int *)) = ag_rp_8(V(0,(int *))); break; + case 9: ag_rp_9(V(0,(int *))); break; + case 10: ag_rp_10(V(2,(int *))); break; + case 11: V(0,(int *)) = ag_rp_11(); break; + case 12: V(0,(int *)) = ag_rp_12(); break; + case 13: V(0,(int *)) = ag_rp_13(); break; + case 14: ag_rp_14(); break; + case 15: ag_rp_15(V(0,(int *))); break; + case 16: ag_rp_16(V(1,(int *))); break; + case 17: ag_rp_17(V(0,(int *))); break; + case 18: V(0,(int *)) = ag_rp_18(V(1,(int *))); break; + case 19: ag_rp_19(V(0,(int *))); break; + case 20: ag_rp_20(V(0,(int *))); break; + case 21: ag_rp_21(V(1,(int *))); break; + case 22: V(0,(int *)) = ag_rp_22(V(1,(int *))); break; + case 23: ag_rp_23(V(1,(int *)), V(2,(int *))); break; + case 24: ag_rp_24(V(2,(int *)), V(3,(int *))); break; + case 25: ag_rp_25(); break; + case 26: V(0,(int *)) = ag_rp_26(); break; + case 27: V(0,(int *)) = ag_rp_27(); break; + case 28: V(0,(int *)) = ag_rp_28(); break; + case 29: ag_rp_29(); break; + case 30: ag_rp_30(); break; + case 31: ag_rp_31(); break; + case 32: ag_rp_32(); break; + case 33: ag_rp_33(); break; + case 34: ag_rp_34(); break; + case 35: ag_rp_35(); break; + case 36: ag_rp_36(); break; + case 37: ag_rp_37(); break; + case 38: ag_rp_38(); break; + case 39: ag_rp_39(); break; + case 40: ag_rp_40(); break; + case 41: ag_rp_41(); break; + case 42: ag_rp_42(); break; + case 43: ag_rp_43(V(0,(int *))); break; + case 44: ag_rp_44(V(1,(int *))); break; + case 45: ag_rp_45(V(2,(int *))); break; + case 46: ag_rp_46(V(2,(int *))); break; + case 47: ag_rp_47(V(1,(int *))); break; + case 48: ag_rp_48(V(2,(int *))); break; + case 49: V(0,(int *)) = ag_rp_49(V(1,(int *))); break; + case 50: V(0,(int *)) = ag_rp_50(V(1,(int *))); break; + case 51: V(0,(int *)) = ag_rp_51(V(0,(int *)), V(1,(int *))); break; + case 52: V(0,(int *)) = ag_rp_52(); break; + case 53: V(0,(int *)) = ag_rp_53(); break; + case 54: V(0,(int *)) = ag_rp_54(V(0,(int *))); break; + case 55: V(0,(int *)) = ag_rp_55(V(1,(int *))); break; + case 56: V(0,(int *)) = ag_rp_56(V(0,(int *))); break; + case 57: V(0,(int *)) = ag_rp_57(V(0,(int *)), V(1,(int *))); break; + case 58: V(0,(int *)) = ag_rp_58(); break; + case 59: V(0,(int *)) = ag_rp_59(V(0,(int *)), V(1,(int *))); break; + case 60: V(0,(int *)) = ag_rp_60(V(0,(int *))); break; + case 61: V(0,(int *)) = ag_rp_61(V(0,(int *)), V(1,(int *))); break; + case 62: V(0,(int *)) = ag_rp_62(V(0,(int *))); break; + case 63: V(0,(int *)) = ag_rp_63(V(0,(int *))); break; + case 64: V(0,(int *)) = ag_rp_64(V(0,(int *))); break; + case 65: V(0,(int *)) = ag_rp_65(V(0,(CharSetExpression * *))); break; + case 66: V(0,(CharSetExpression * *)) = ag_rp_66(V(0,(CharSetExpression * *)), V(2,(CharSetExpression * *))); break; + case 67: V(0,(CharSetExpression * *)) = ag_rp_67(V(0,(CharSetExpression * *)), V(2,(CharSetExpression * *))); break; + case 68: V(0,(CharSetExpression * *)) = ag_rp_68(V(0,(CharSetExpression * *)), V(3,(CharSetExpression * *))); break; + case 69: V(0,(CharSetExpression * *)) = ag_rp_69(V(1,(CharSetExpression * *))); break; + case 70: V(0,(CharSetExpression * *)) = ag_rp_70(V(0,(int *))); break; + case 71: V(0,(CharSetExpression * *)) = ag_rp_71(V(0,(int *))); break; + case 72: V(0,(CharSetExpression * *)) = ag_rp_72(); break; + case 73: V(0,(CharSetExpression * *)) = ag_rp_73(V(1,(CharSetExpression * *))); break; + case 74: V(0,(CharSetExpression * *)) = ag_rp_74(V(1,(int *)), V(3,(int *))); break; + case 75: V(0,(CharSetExpression * *)) = ag_rp_75(V(0,(int *)), V(3,(int *))); break; + case 76: ag_rp_76(V(2,(CharSetExpression * *))); break; + case 77: ag_rp_77(V(2,(int *))); break; + case 78: ag_rp_78(V(2,(int *))); break; + case 79: ag_rp_79(); break; + case 80: ag_rp_80(V(2,(int *))); break; + case 81: ag_rp_81(V(2,(int *))); break; + case 82: ag_rp_82(); break; + case 83: V(0,(int *)) = ag_rp_83(V(0,(int *))); break; + case 84: V(0,(int *)) = ag_rp_84(); break; + case 85: V(0,(int *)) = ag_rp_85(); break; + case 86: V(0,(int *)) = ag_rp_86(); break; + case 87: V(0,(int *)) = ag_rp_87(); break; + case 88: V(0,(int *)) = ag_rp_88(); break; + case 89: V(0,(int *)) = ag_rp_89(); break; + case 90: V(0,(int *)) = ag_rp_90(); break; + case 91: V(0,(int *)) = ag_rp_91(); break; + case 92: V(0,(int *)) = ag_rp_92(); break; + case 93: V(0,(int *)) = ag_rp_93(); break; + case 94: V(0,(int *)) = ag_rp_94(); break; + case 95: V(0,(int *)) = ag_rp_95(V(1,(int *))); break; + case 96: V(0,(int *)) = ag_rp_96(V(0,(int *)), V(1,(int *))); break; + case 97: V(0,(int *)) = ag_rp_97(V(0,(int *)), V(1,(int *))); break; + case 98: V(0,(int *)) = ag_rp_98(V(1,(int *))); break; + case 99: ag_rp_99(V(0,(int *))); break; + case 100: ag_rp_100(V(0,(int *))); break; + case 101: ag_rp_101(V(1,(int *))); break; + case 102: ag_rp_102(V(1,(int *))); break; + case 103: ag_rp_103(V(1,(int *))); break; + case 104: ag_rp_104(V(0,(int *))); break; + case 105: ag_rp_105(V(1,(int *))); break; + case 106: ag_rp_106(V(0,(int *))); break; + case 107: ag_rp_107(V(1,(int *))); break; + case 108: V(0,(int *)) = ag_rp_108(); break; + case 109: V(0,(int *)) = ag_rp_109(); break; + case 110: ag_rp_110(V(0,(int *))); break; + case 111: ag_rp_111(V(1,(int *))); break; + case 112: ag_rp_112(); break; + case 113: ag_rp_113(); break; + case 114: ag_rp_114(); break; + case 115: ag_rp_115(); break; + case 116: ag_rp_116(); break; + case 117: ag_rp_117(V(2,(int *))); break; + case 118: ag_rp_118(); break; + case 119: ag_rp_119(); break; + case 120: ag_rp_120(); break; + case 121: ag_rp_121(); break; + case 122: ag_rp_122(); break; + case 123: ag_rp_123(); break; + case 124: ag_rp_124(); break; + case 125: ag_rp_125(); break; + case 126: ag_rp_126(V(2,(int *))); break; + case 127: ag_rp_127(); break; + case 128: ag_rp_128(); break; + case 129: ag_rp_129(); break; + case 130: ag_rp_130(V(4,(int *)), V(6,(int *))); break; + case 131: V(0,(int *)) = ag_rp_131(); break; + case 132: ag_rp_132(V(5,(CharSetExpression * *))); break; + case 133: ag_rp_133(V(2,(CharSetExpression * *))); break; + case 134: ag_rp_134(V(0,(int *))); break; + case 135: ag_rp_135(V(2,(int *))); break; + case 136: V(0,(int *)) = ag_rp_136(); break; + case 137: V(0,(int *)) = ag_rp_137(); break; + case 138: V(0,(int *)) = ag_rp_138(); break; + case 139: V(0,(int *)) = ag_rp_139(); break; + case 140: V(0,(int *)) = ag_rp_140(); break; + case 141: V(0,(int *)) = ag_rp_141(); break; + case 142: V(0,(int *)) = ag_rp_142(V(0,(CharSetExpression * *))); break; + case 143: V(0,(int *)) = ag_rp_143(V(0,(CharSetExpression * *))); break; + case 144: V(0,(int *)) = ag_rp_144(V(0,(CharSetExpression * *))); break; + case 145: V(0,(int *)) = ag_rp_145(); break; + case 146: V(0,(int *)) = ag_rp_146(); break; + case 147: V(0,(int *)) = ag_rp_147(); break; + case 148: V(0,(int *)) = ag_rp_148(); break; + case 149: V(0,(int *)) = ag_rp_149(); break; + case 150: V(0,(int *)) = ag_rp_150(); break; + case 151: ag_rp_151(V(1,(unsigned char * *))); break; + case 152: ag_rp_152(); break; + case 153: V(0,(unsigned char * *)) = ag_rp_153(); break; + case 154: V(0,(unsigned char * *)) = ag_rp_154(); break; + case 155: ag_rp_155(); break; + case 156: ag_rp_156(); break; + case 157: ag_default(&ag_rtt[0]); ag_rp_157(); break; + } + (PCB).la_ptr = (PCB).pointer; +} + + +static const unsigned char ag_ctn[] = { + 0,0, 98,1, 0,0, 0,0,100,1, 0,0, 0,0, 0,0, 0,0, 0,0, 0,0, 0,0, + 0,0, 0,0, 56,1,214,1, 58,1, 50,1, 55,1, 48,1, 47,1, 0,0, 45,1, 41,1, + 41,1, 41,1, 41,1, 41,1, 0,0, 0,0, 99,1, 0,0, 76,1, 0,0, 56,2, 0,0, + 0,0, 0,0, 0,0, 55,1, 0,0, 55,2,180,1, 48,2,223,1,222,1,219,1,219,1, + 219,1, 0,0, 47,2, 0,0, 46,2, 0,0, 51,1, 51,1, 0,0, 0,0, 0,0, 0,0, + 41,2, 45,1, 0,0, 0,0, 76,2, 76,2, 0,0, 85,1, 0,0, 0,0, 56,3,180,2, + 0,0, 0,0, 0,0, 0,0, 0,0,219,2, 0,0, 0,0, 0,0,148,1,135,1, 0,0, + 151,1,135,1,135,1,135,1, 0,0, 0,0,112,1,111,1,140,1, 0,0,140,1,146,1, + 138,1,136,1,134,1, 69,1, 0,0, 67,1, 0,0, 0,0, 0,0, 0,0, 0,0, 0,0, + 0,0, 76,3, 76,3, 0,0, 0,0, 0,0, 0,0, 0,0,183,1,184,1,184,1,184,1, + 184,1,184,1,184,1,184,1,184,1,184,1,184,1,184,1,184,1,184,1,184,1,183,1, + 183,1,183,1,183,1,183,1, 0,0, 0,0, 0,0, 0,0, 0,0, 74,1,148,2,143,1, + 145,1, 0,0,143,1,153,1,153,1,153,1, 64,1, 0,0, 68,1, 68,1,135,2,135,2, + 0,0,121,1,120,1,112,2,111,2,140,2,137,1,146,2,136,2, 0,0,135,2,135,2, + 137,2,137,2,133,1,135,1, 69,2, 69,2, 67,2, 76,4, 0,0, 85,3, 0,0, 0,0, + 184,2, 0,0, 0,0,188,1, 0,0, 0,0, 0,0,150,2,184,2,150,2, 0,0,183,2, + 0,0,183,2, 0,0, 0,0, 0,0, 0,0, 0,0, 0,0,148,3,125,1,151,3,135,3, + 135,3, 0,0,135,3,135,3,125,1,146,3, 0,0, 0,0,146,3,136,3,136,1,136,1, + 133,2, 73,1, 69,3, 67,3,184,3,184,3,184,3,184,3,188,2,184,3,149,1,137,1, + 150,3,183,3,146,4,133,3, 73,2, 0,0, 62,1, 0,0,207,1,184,4,149,2, 0,0, + 184,5, 62,2,204,1,207,2,115,1,137,1, 0,0,115,2,204,1 +}; + +#ifndef MISSING_FORMAT +#define MISSING_FORMAT "Missing %s" +#endif +#ifndef UNEXPECTED_FORMAT +#define UNEXPECTED_FORMAT "Unexpected %s" +#endif +#ifndef UNNAMED_TOKEN +#define UNNAMED_TOKEN "input" +#endif + + +static void ag_diagnose(void) { + int ag_snd = (PCB).sn; + int ag_k = ag_sbt[ag_snd]; + + if (*TOKEN_NAMES[ag_tstt[ag_k]] && ag_astt[ag_k + 1] == ag_action_8) { + sprintf((PCB).ag_msg, MISSING_FORMAT, TOKEN_NAMES[ag_tstt[ag_k]]); + } + else if (ag_astt[ag_sbe[(PCB).sn]] == ag_action_8 + && (ag_k = (int) ag_sbe[(PCB).sn] + 1) == (int) ag_sbt[(PCB).sn+1] - 1 + && *TOKEN_NAMES[ag_tstt[ag_k]]) { + sprintf((PCB).ag_msg, MISSING_FORMAT, TOKEN_NAMES[ag_tstt[ag_k]]); + } + else if ((PCB).token_number && *TOKEN_NAMES[(PCB).token_number]) { + sprintf((PCB).ag_msg, UNEXPECTED_FORMAT, TOKEN_NAMES[(PCB).token_number]); + } + else if (isprint(INPUT_CODE((*(PCB).pointer))) && INPUT_CODE((*(PCB).pointer)) != '\\') { + char buf[20]; + sprintf(buf, "\'%c\'", (char) INPUT_CODE((*(PCB).pointer))); + sprintf((PCB).ag_msg, UNEXPECTED_FORMAT, buf); + } + else sprintf((PCB).ag_msg, UNEXPECTED_FORMAT, UNNAMED_TOKEN); + (PCB).error_message = (PCB).ag_msg; + + +{ + int ag_sx, ag_t; + + ag_sx = (PCB).ssx; + (PCB).ss[ag_sx] = (PCB).sn; + do { + while (ag_sx && ag_ctn[2*(ag_snd = (PCB).ss[ag_sx])] == 0) ag_sx--; + if (ag_sx) { + ag_t = ag_ctn[2*ag_snd]; + ag_sx -= ag_ctn[2*ag_snd +1]; + ag_snd = (PCB).ss[ag_sx]; + } + else { + ag_snd = 0; + ag_t = ag_ptt[0]; + } + } while (ag_sx && *TOKEN_NAMES[ag_t]==0); + if (*TOKEN_NAMES[ag_t] == 0) ag_t = 0; + (PCB).error_frame_ssx = ag_sx; + (PCB).error_frame_token = (pgg_token_type) ag_t; +} + + +} +static int ag_action_1_r_proc(void); +static int ag_action_2_r_proc(void); +static int ag_action_3_r_proc(void); +static int ag_action_4_r_proc(void); +static int ag_action_1_s_proc(void); +static int ag_action_3_s_proc(void); +static int ag_action_1_proc(void); +static int ag_action_2_proc(void); +static int ag_action_3_proc(void); +static int ag_action_4_proc(void); +static int ag_action_5_proc(void); +static int ag_action_6_proc(void); +static int ag_action_7_proc(void); +static int ag_action_8_proc(void); +static int ag_action_9_proc(void); +static int ag_action_10_proc(void); +static int ag_action_11_proc(void); +static int ag_action_8_proc(void); + + +static int (*const ag_r_procs_scan[])(void) = { + ag_action_1_r_proc, + ag_action_2_r_proc, + ag_action_3_r_proc, + ag_action_4_r_proc +}; + +static int (*const ag_s_procs_scan[])(void) = { + ag_action_1_s_proc, + ag_action_2_r_proc, + ag_action_3_s_proc, + ag_action_4_r_proc +}; + +static int (*const ag_gt_procs_scan[])(void) = { + ag_action_1_proc, + ag_action_2_proc, + ag_action_3_proc, + ag_action_4_proc, + ag_action_5_proc, + ag_action_6_proc, + ag_action_7_proc, + ag_action_8_proc, + ag_action_9_proc, + ag_action_10_proc, + ag_action_11_proc, + ag_action_8_proc +}; + + +static int ag_rns(int ag_t, int *ag_sx, int ag_snd) { + while (1) { + int ag_act, ag_k = ag_sbt[ag_snd], ag_lim = ag_sbt[ag_snd+1]; + int ag_p; + + while (ag_k < ag_lim && ag_tstt[ag_k] != ag_t) ag_k++; + if (ag_k == ag_lim) break; + ag_act = ag_astt[ag_k]; + ag_p = ag_pstt[ag_k]; + if (ag_act == ag_action_2) return ag_p; + if (ag_act == ag_action_10 || ag_act == ag_action_11) { + (*ag_sx)--; + return ag_snd; + } + if (ag_act != ag_action_3 && + ag_act != ag_action_4) break; + *ag_sx -= (ag_fl[ag_p] - 1); + ag_snd = (PCB).ss[*ag_sx]; + ag_t = ag_ptt[ag_p]; + } + return 0; +} + +static int ag_jns(int ag_t) { + int ag_k; + + ag_k = ag_sbt[(PCB).sn]; + while (ag_tstt[ag_k] != ag_t && ag_tstt[ag_k]) ag_k++; + while (1) { + int ag_p = ag_pstt[ag_k]; + int ag_sd; + + switch (ag_astt[ag_k]) { + case ag_action_2: + GET_CONTEXT; + (PCB).ss[(PCB).ssx] = (PCB).sn; + return ag_p; + case ag_action_10: + case ag_action_11: + return (PCB).ss[(PCB).ssx--]; + case ag_action_9: + GET_CONTEXT; + (PCB).ss[(PCB).ssx] = (PCB).sn; + (PCB).ssx++; + (PCB).sn = ag_p; + ag_k = ag_sbt[(PCB).sn]; + while (ag_tstt[ag_k] != ag_t && ag_tstt[ag_k]) ag_k++; + continue; + case ag_action_3: + case ag_action_4: + ag_sd = ag_fl[ag_p] - 1; + if (ag_sd) (PCB).sn = (PCB).ss[(PCB).ssx -= ag_sd]; + else GET_CONTEXT; + (PCB).ss[(PCB).ssx] = (PCB).sn; + ag_t = ag_ptt[ag_p]; + ag_k = ag_sbt[(PCB).sn+1]; + while (ag_tstt[--ag_k] != ag_t); + continue; + case ag_action_5: + case ag_action_6: + if (ag_fl[ag_p]) break; + (PCB).sn = ag_rns(ag_ptt[ag_p],&(PCB).ssx, (PCB).sn); + (PCB).ss[++(PCB).ssx] = (PCB).sn; + ag_k = ag_sbt[(PCB).sn]; + while (ag_tstt[ag_k] != ag_t && ag_tstt[ag_k]) ag_k++; + continue; + } + break; + } + return 0; +} + + +static int ag_atx(int ag_t, int *ag_sx, int ag_snd) { + int ag_k, ag_f; + int ag_save_btsx = (PCB).btsx; + int ag_flag = 1; + + while (1) { + int ag_a; + + (PCB).bts[128 - ++(PCB).btsx] = *ag_sx; + (PCB).ss[128 - (PCB).btsx] = (PCB).ss[*ag_sx]; + (PCB).ss[*ag_sx] = ag_snd; + ag_k = ag_sbt[ag_snd]; + while (ag_tstt[ag_k] != ag_t && ag_tstt[ag_k]) ag_k++; + ag_a = ag_astt[ag_k]; + if (ag_a == ag_action_2 || + ag_a == ag_action_3 || + ag_a == ag_action_10 || + ag_a == ag_action_11 || + ag_a == ag_action_1 || + ag_a == ag_action_4) break; + if ((ag_a == ag_action_5 || + ag_a == ag_action_6) && + (ag_k = ag_fl[ag_f = ag_pstt[ag_k]]) == 0) { + ag_snd = ag_rns(ag_ptt[ag_f],ag_sx, (PCB).ss[*ag_sx]); + (*ag_sx)++; + continue; + } + if (ag_a == ag_action_9) { + ag_snd = ag_pstt[ag_k]; + (*ag_sx)++; + continue; + } + ag_flag = 0; + break; + } + while ((PCB).btsx > ag_save_btsx) { + *ag_sx = (PCB).bts[128 - (PCB).btsx]; + (PCB).ss[*ag_sx] = (PCB).ss[128 - (PCB).btsx--]; + } + return ag_flag; +} + + +static int ag_tst_tkn(void) { + int ag_rk, ag_sx, ag_snd = (PCB).sn; + + (PCB).token_number = (pgg_token_type) AG_TCV(INPUT_CODE(*(PCB).la_ptr)); + (PCB).la_ptr++; + if (ag_key_index[(PCB).sn]) { + unsigned ag_k = ag_key_index[(PCB).sn]; + int ag_ch = CONVERT_CASE(INPUT_CODE(*(PCB).pointer)); + if (ag_ch <= 255) { + while (ag_key_ch[ag_k] < ag_ch) ag_k++; + if (ag_key_ch[ag_k] == ag_ch) ag_get_key_word(ag_k); + } + } + for (ag_rk = 0; ag_rk < (PCB).ag_lrss; ag_rk += 2) { + ag_sx = (PCB).ag_rss[ag_rk]; + if (ag_sx > (PCB).ssx || ag_sx > (PCB).ag_min_depth) continue; + (PCB).sn = (PCB).ag_rss[ag_rk + 1]; + if (ag_atx((PCB).token_number, &ag_sx, (PCB).sn)) break; + } + (PCB).sn = ag_snd; + return ag_rk; +} + +static void ag_set_error_procs(void); + +static void ag_auto_resynch(void) { + int ag_sx, ag_rk; + int ag_rk1, ag_rk2, ag_tk1; + (PCB).ss[(PCB).ssx] = (PCB).sn; + if ((PCB).ag_error_depth && (PCB).ag_min_depth >= (PCB).ag_error_depth) { + (PCB).ssx = (PCB).ag_error_depth; + (PCB).sn = (PCB).ss[(PCB).ssx]; + } + else { + ag_diagnose(); + SYNTAX_ERROR; + if ((PCB).exit_flag != AG_RUNNING_CODE) return; + (PCB).ag_error_depth = (PCB).ag_min_depth = 0; + (PCB).ag_lrss = 0; + (PCB).ss[ag_sx = (PCB).ssx] = (PCB).sn; + (PCB).ag_min_depth = (PCB).ag_rss[(PCB).ag_lrss++] = ag_sx; + (PCB).ag_rss[(PCB).ag_lrss++] = (PCB).sn; + while (ag_sx && (PCB).ag_lrss < 2*128) { + int ag_t = 0, ag_x, ag_s, ag_sxs = ag_sx; + + while (ag_sx && (ag_t = ag_ctn[2*(PCB).sn]) == 0) (PCB).sn = (PCB).ss[--ag_sx]; + if (ag_t) (PCB).sn = (PCB).ss[ag_sx -= ag_ctn[2*(PCB).sn +1]]; + else { + if (ag_sx == 0) (PCB).sn = 0; + ag_t = ag_ptt[0]; + } + if ((ag_s = ag_rns(ag_t, &ag_sx, (PCB).sn)) == 0) break; + for (ag_x = 0; ag_x < (PCB).ag_lrss; ag_x += 2) + if ((PCB).ag_rss[ag_x] == ag_sx + 1 && (PCB).ag_rss[ag_x+1] == ag_s) break; + if (ag_x == (PCB).ag_lrss) { + (PCB).ag_rss[(PCB).ag_lrss++] = ++ag_sx; + (PCB).ag_rss[(PCB).ag_lrss++] = (PCB).sn = ag_s; + } + else if (ag_sx >= ag_sxs) ag_sx--; + } + ag_set_error_procs(); + } + (PCB).la_ptr = (PCB).pointer; + if ((PCB).ssx > (PCB).ag_min_depth) (PCB).ag_min_depth = (PCB).ssx; + while (1) { + ag_rk1 = ag_tst_tkn(); + if ((PCB).token_number == 44) + {(PCB).exit_flag = AG_SYNTAX_ERROR_CODE; return;} + if (ag_rk1 < (PCB).ag_lrss) break; + {(PCB).la_ptr = (PCB).pointer + 1; ag_track();} + } + ag_tk1 = (PCB).token_number; + ag_track(); + ag_rk2 = ag_tst_tkn(); + if (ag_rk2 < ag_rk1) {ag_rk = ag_rk2; ag_track();} + else {ag_rk = ag_rk1; (PCB).token_number = (pgg_token_type) ag_tk1; (PCB).la_ptr = (PCB).pointer;} + (PCB).ag_min_depth = (PCB).ssx = (PCB).ag_rss[ag_rk++]; + (PCB).sn = (PCB).ss[(PCB).ssx] = (PCB).ag_rss[ag_rk]; + (PCB).sn = ag_jns((PCB).token_number); + if ((PCB).ag_error_depth == 0 || (PCB).ag_error_depth > (PCB).ssx) + (PCB).ag_error_depth = (PCB).ssx; + if (++(PCB).ssx >= 128) { + (PCB).exit_flag = AG_STACK_ERROR_CODE; + PARSER_STACK_OVERFLOW; + return; + } + GET_CONTEXT; + (PCB).ss[(PCB).ssx] = (PCB).sn; + (PCB).ag_tmp_depth = (PCB).ag_min_depth; + (PCB).la_ptr = (PCB).pointer; + return; +} + + +static int ag_action_10_proc(void) { + int ag_t = (PCB).token_number; + (PCB).btsx = 0, (PCB).drt = -1; + do { + ag_track(); + (PCB).token_number = (pgg_token_type) AG_TCV(INPUT_CODE(*(PCB).la_ptr)); + (PCB).la_ptr++; + if (ag_key_index[(PCB).sn]) { + unsigned ag_k = ag_key_index[(PCB).sn]; + int ag_ch = CONVERT_CASE(INPUT_CODE(*(PCB).pointer)); + if (ag_ch <= 255) { + while (ag_key_ch[ag_k] < ag_ch) ag_k++; + if (ag_key_ch[ag_k] == ag_ch) ag_get_key_word(ag_k); + } + } + } while ((PCB).token_number == (pgg_token_type) ag_t); + (PCB).la_ptr = (PCB).pointer; + return 1; +} + +static int ag_action_11_proc(void) { + int ag_t = (PCB).token_number; + + (PCB).btsx = 0, (PCB).drt = -1; + do { + (*(int *) &(PCB).vs[(PCB).ssx]) = *(PCB).pointer; + (PCB).ssx--; + ag_track(); + ag_ra(); + if ((PCB).exit_flag != AG_RUNNING_CODE) return 0; + (PCB).ssx++; + (PCB).token_number = (pgg_token_type) AG_TCV(INPUT_CODE(*(PCB).la_ptr)); + (PCB).la_ptr++; + if (ag_key_index[(PCB).sn]) { + unsigned ag_k = ag_key_index[(PCB).sn]; + int ag_ch = CONVERT_CASE(INPUT_CODE(*(PCB).pointer)); + if (ag_ch <= 255) { + while (ag_key_ch[ag_k] < ag_ch) ag_k++; + if (ag_key_ch[ag_k] == ag_ch) ag_get_key_word(ag_k); + } + } + } + while ((PCB).token_number == (pgg_token_type) ag_t); + (PCB).la_ptr = (PCB).pointer; + return 1; +} + +static int ag_action_3_r_proc(void) { + int ag_sd = ag_fl[(PCB).ag_ap] - 1; + if (ag_sd) (PCB).sn = (PCB).ss[(PCB).ssx -= ag_sd]; + (PCB).btsx = 0, (PCB).drt = -1; + (PCB).reduction_token = (pgg_token_type) ag_ptt[(PCB).ag_ap]; + ag_ra(); + return (PCB).exit_flag == AG_RUNNING_CODE; +} + +static int ag_action_3_s_proc(void) { + int ag_sd = ag_fl[(PCB).ag_ap] - 1; + if (ag_sd) (PCB).sn = (PCB).ss[(PCB).ssx -= ag_sd]; + (PCB).btsx = 0, (PCB).drt = -1; + (PCB).reduction_token = (pgg_token_type) ag_ptt[(PCB).ag_ap]; + ag_ra(); + return (PCB).exit_flag == AG_RUNNING_CODE; +} + +static int ag_action_4_r_proc(void) { + int ag_sd = ag_fl[(PCB).ag_ap] - 1; + if (ag_sd) (PCB).sn = (PCB).ss[(PCB).ssx -= ag_sd]; + (PCB).reduction_token = (pgg_token_type) ag_ptt[(PCB).ag_ap]; + return 1; +} + +static int ag_action_2_proc(void) { + (PCB).btsx = 0, (PCB).drt = -1; + if ((PCB).ssx >= 128) { + (PCB).exit_flag = AG_STACK_ERROR_CODE; + PARSER_STACK_OVERFLOW; + } + (*(int *) &(PCB).vs[(PCB).ssx]) = *(PCB).pointer; + GET_CONTEXT; + (PCB).ss[(PCB).ssx] = (PCB).sn; + (PCB).ssx++; + (PCB).sn = (PCB).ag_ap; + ag_track(); + return 0; +} + +static int ag_action_9_proc(void) { + if ((PCB).drt == -1) { + (PCB).drt=(PCB).token_number; + (PCB).dssx=(PCB).ssx; + (PCB).dsn=(PCB).sn; + } + ag_prot(); + (PCB).vs[(PCB).ssx] = ag_null_value; + GET_CONTEXT; + (PCB).ss[(PCB).ssx] = (PCB).sn; + (PCB).ssx++; + (PCB).sn = (PCB).ag_ap; + (PCB).la_ptr = (PCB).pointer; + return (PCB).exit_flag == AG_RUNNING_CODE; +} + +static int ag_action_2_r_proc(void) { + (PCB).ssx++; + (PCB).sn = (PCB).ag_ap; + return 0; +} + +static int ag_action_7_proc(void) { + --(PCB).ssx; + (PCB).la_ptr = (PCB).pointer; + (PCB).exit_flag = AG_SUCCESS_CODE; + return 0; +} + +static int ag_action_1_proc(void) { + ag_track(); + (PCB).exit_flag = AG_SUCCESS_CODE; + return 0; +} + +static int ag_action_1_r_proc(void) { + (PCB).exit_flag = AG_SUCCESS_CODE; + return 0; +} + +static int ag_action_1_s_proc(void) { + (PCB).exit_flag = AG_SUCCESS_CODE; + return 0; +} + +static int ag_action_4_proc(void) { + int ag_sd = ag_fl[(PCB).ag_ap] - 1; + (PCB).reduction_token = (pgg_token_type) ag_ptt[(PCB).ag_ap]; + (PCB).btsx = 0, (PCB).drt = -1; + (*(int *) &(PCB).vs[(PCB).ssx]) = *(PCB).pointer; + if (ag_sd) (PCB).sn = (PCB).ss[(PCB).ssx -= ag_sd]; + else GET_CONTEXT; + (PCB).ss[(PCB).ssx] = (PCB).sn; + ag_track(); + while ((PCB).exit_flag == AG_RUNNING_CODE) { + unsigned ag_t1 = ag_sbe[(PCB).sn] + 1; + unsigned ag_t2 = ag_sbt[(PCB).sn+1] - 1; + do { + unsigned ag_tx = (ag_t1 + ag_t2)/2; + if (ag_tstt[ag_tx] < (unsigned char)(PCB).reduction_token) ag_t1 = ag_tx + 1; + else ag_t2 = ag_tx; + } while (ag_t1 < ag_t2); + if (ag_tstt[ag_t1] != (PCB).reduction_token) { + (PCB).exit_flag = AG_REDUCTION_ERROR_CODE; + REDUCTION_TOKEN_ERROR; break;} + (PCB).ag_ap = ag_pstt[ag_t1]; + if ((*(PCB).s_procs[ag_astt[ag_t1]])() == 0) break; + } + return 0; +} + +static int ag_action_3_proc(void) { + int ag_sd = ag_fl[(PCB).ag_ap] - 1; + (PCB).btsx = 0, (PCB).drt = -1; + (*(int *) &(PCB).vs[(PCB).ssx]) = *(PCB).pointer; + if (ag_sd) (PCB).sn = (PCB).ss[(PCB).ssx -= ag_sd]; + else GET_CONTEXT; + (PCB).ss[(PCB).ssx] = (PCB).sn; + ag_track(); + (PCB).reduction_token = (pgg_token_type) ag_ptt[(PCB).ag_ap]; + ag_ra(); + while ((PCB).exit_flag == AG_RUNNING_CODE) { + unsigned ag_t1 = ag_sbe[(PCB).sn] + 1; + unsigned ag_t2 = ag_sbt[(PCB).sn+1] - 1; + do { + unsigned ag_tx = (ag_t1 + ag_t2)/2; + if (ag_tstt[ag_tx] < (unsigned char)(PCB).reduction_token) ag_t1 = ag_tx + 1; + else ag_t2 = ag_tx; + } while (ag_t1 < ag_t2); + if (ag_tstt[ag_t1] != (PCB).reduction_token) { + (PCB).exit_flag = AG_REDUCTION_ERROR_CODE; + REDUCTION_TOKEN_ERROR; break;} + (PCB).ag_ap = ag_pstt[ag_t1]; + if ((*(PCB).s_procs[ag_astt[ag_t1]])() == 0) break; + } + return 0; +} + +static int ag_action_8_proc(void) { + ag_undo(); + (PCB).la_ptr = (PCB).pointer; + ag_auto_resynch(); + return (PCB).exit_flag == AG_RUNNING_CODE; +} + +static int ag_action_5_proc(void) { + int ag_sd = ag_fl[(PCB).ag_ap]; + (PCB).btsx = 0, (PCB).drt = -1; + if (ag_sd) (PCB).sn = (PCB).ss[(PCB).ssx -= ag_sd]; + else { + GET_CONTEXT; + (PCB).ss[(PCB).ssx] = (PCB).sn; + } + (PCB).la_ptr = (PCB).pointer; + (PCB).reduction_token = (pgg_token_type) ag_ptt[(PCB).ag_ap]; + ag_ra(); + while ((PCB).exit_flag == AG_RUNNING_CODE) { + unsigned ag_t1 = ag_sbe[(PCB).sn] + 1; + unsigned ag_t2 = ag_sbt[(PCB).sn+1] - 1; + do { + unsigned ag_tx = (ag_t1 + ag_t2)/2; + if (ag_tstt[ag_tx] < (unsigned char)(PCB).reduction_token) ag_t1 = ag_tx + 1; + else ag_t2 = ag_tx; + } while (ag_t1 < ag_t2); + if (ag_tstt[ag_t1] != (PCB).reduction_token) { + (PCB).exit_flag = AG_REDUCTION_ERROR_CODE; + REDUCTION_TOKEN_ERROR; break;} + (PCB).ag_ap = ag_pstt[ag_t1]; + if ((*(PCB).r_procs[ag_astt[ag_t1]])() == 0) break; + } + return (PCB).exit_flag == AG_RUNNING_CODE; +} + +static int ag_action_6_proc(void) { + int ag_sd = ag_fl[(PCB).ag_ap]; + (PCB).reduction_token = (pgg_token_type) ag_ptt[(PCB).ag_ap]; + if ((PCB).drt == -1) { + (PCB).drt=(PCB).token_number; + (PCB).dssx=(PCB).ssx; + (PCB).dsn=(PCB).sn; + } + if (ag_sd) { + (PCB).sn = (PCB).ss[(PCB).ssx -= ag_sd]; + } + else { + ag_prot(); + (PCB).vs[(PCB).ssx] = ag_null_value; + GET_CONTEXT; + (PCB).ss[(PCB).ssx] = (PCB).sn; + } + (PCB).la_ptr = (PCB).pointer; + while ((PCB).exit_flag == AG_RUNNING_CODE) { + unsigned ag_t1 = ag_sbe[(PCB).sn] + 1; + unsigned ag_t2 = ag_sbt[(PCB).sn+1] - 1; + do { + unsigned ag_tx = (ag_t1 + ag_t2)/2; + if (ag_tstt[ag_tx] < (unsigned char)(PCB).reduction_token) ag_t1 = ag_tx + 1; + else ag_t2 = ag_tx; + } while (ag_t1 < ag_t2); + if (ag_tstt[ag_t1] != (PCB).reduction_token) { + (PCB).exit_flag = AG_REDUCTION_ERROR_CODE; + REDUCTION_TOKEN_ERROR; break;} + (PCB).ag_ap = ag_pstt[ag_t1]; + if ((*(PCB).r_procs[ag_astt[ag_t1]])() == 0) break; + } + return (PCB).exit_flag == AG_RUNNING_CODE; +} + + +static void ag_check_depth(int ag_fl) { + int ag_sx = (PCB).ssx - ag_fl; + if ((PCB).ag_error_depth && ag_sx < (PCB).ag_tmp_depth) (PCB).ag_tmp_depth = ag_sx; +} + +static int ag_action_3_er_proc(void) { + ag_check_depth(ag_fl[(PCB).ag_ap] - 1); + return ag_action_4_r_proc(); +} + +static int ag_action_2_e_proc(void) { + ag_action_2_proc(); + (PCB).ag_min_depth = (PCB).ag_tmp_depth; + return 0; +} + +static int ag_action_4_e_proc(void) { + ag_check_depth(ag_fl[(PCB).ag_ap] - 1); + (PCB).ag_min_depth = (PCB).ag_tmp_depth; + return ag_action_4_proc(); +} + +static int ag_action_6_e_proc(void) { + ag_check_depth(ag_fl[(PCB).ag_ap]); + return ag_action_6_proc(); +} + +static int ag_action_11_e_proc(void) { + return ag_action_10_proc(); +} + +static int (*ag_r_procs_error[])(void) = { + ag_action_1_r_proc, + ag_action_2_r_proc, + ag_action_3_er_proc, + ag_action_3_er_proc +}; + +static int (*ag_s_procs_error[])(void) = { + ag_action_1_s_proc, + ag_action_2_r_proc, + ag_action_3_er_proc, + ag_action_3_er_proc +}; + +static int (*ag_gt_procs_error[])(void) = { + ag_action_1_proc, + ag_action_2_e_proc, + ag_action_4_e_proc, + ag_action_4_e_proc, + ag_action_6_e_proc, + ag_action_6_e_proc, + ag_action_7_proc, + ag_action_8_proc, + ag_action_9_proc, + ag_action_10_proc, + ag_action_11_e_proc, + ag_action_8_proc +}; + +static void ag_set_error_procs(void) { + (PCB).gt_procs = ag_gt_procs_error; + (PCB).r_procs = ag_r_procs_error; + (PCB).s_procs = ag_s_procs_error; +} + + +void init_pgg(void) { + (PCB).la_ptr = (PCB).pointer; + (PCB).gt_procs = ag_gt_procs_scan; + (PCB).r_procs = ag_r_procs_scan; + (PCB).s_procs = ag_s_procs_scan; + (PCB).ag_error_depth = (PCB).ag_min_depth = (PCB).ag_tmp_depth = 0; + (PCB).ag_resynch_active = 0; + (PCB).ss[0] = (PCB).sn = (PCB).ssx = 0; + (PCB).exit_flag = AG_RUNNING_CODE; + (PCB).line = FIRST_LINE; + (PCB).column = FIRST_COLUMN; + (PCB).btsx = 0, (PCB).drt = -1; +} + +void pgg(void) { + init_pgg(); + (PCB).exit_flag = AG_RUNNING_CODE; + while ((PCB).exit_flag == AG_RUNNING_CODE) { + unsigned ag_t1 = ag_sbt[(PCB).sn]; + if (ag_tstt[ag_t1]) { + unsigned ag_t2 = ag_sbe[(PCB).sn] - 1; + (PCB).token_number = (pgg_token_type) AG_TCV(INPUT_CODE(*(PCB).la_ptr)); + (PCB).la_ptr++; + if (ag_key_index[(PCB).sn]) { + unsigned ag_k = ag_key_index[(PCB).sn]; + int ag_ch = CONVERT_CASE(INPUT_CODE(*(PCB).pointer)); + if (ag_ch <= 255) { + while (ag_key_ch[ag_k] < ag_ch) ag_k++; + if (ag_key_ch[ag_k] == ag_ch) ag_get_key_word(ag_k); + } + } + do { + unsigned ag_tx = (ag_t1 + ag_t2)/2; + if (ag_tstt[ag_tx] > (unsigned char)(PCB).token_number) + ag_t1 = ag_tx + 1; + else ag_t2 = ag_tx; + } while (ag_t1 < ag_t2); + if (ag_tstt[ag_t1] != (unsigned char)(PCB).token_number) + ag_t1 = ag_sbe[(PCB).sn]; + } + (PCB).ag_ap = ag_pstt[ag_t1]; + (*(PCB).gt_procs[ag_astt[ag_t1]])(); + } +} + +