view tests/agcl/parsifal/good/xmlp8.cpp @ 18:562c313f14f4

some minor updates for 2022
author David A. Holland
date Tue, 31 May 2022 02:03:50 -0400
parents 13d2b8934445
children
line wrap: on
line source

/*
 * XML Syntax
 * Transcribed from
 *    Extensible Markup Language (XML) 1.0
 *    W3C Recommendation 10-February-1998
 *    http://www.w3.org/TR/1998/REC-xml-19980210
 *
 * Transcription Copyright © Parsifal Software, 1999.
 *
 * Revision 1 fixed definition of [4] NameChar
 *
 * Revision 2, begun 1/24/00
 *
 * Fixed problem with mixed content declaration [51]
 * Fixed missing S in [52]
 * Removed unnecessary "sticky" statement
*/

#include "xmldef8.h"
#include <stdio.h>


/*
 * 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 XMLP8_H
#include "xmlp8.h"
#endif

#ifndef XMLP8_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])


#ifndef PCB_TYPE
#define PCB_TYPE parse_pcb_type
#endif


#define PCB (*pcb_pointer)
#define PCB_DECL PCB_TYPE *pcb_pointer
#define PCB_POINTER pcb_pointer
static void ag_delete_wrappers(PCB_DECL);
#ifndef DELETE_WRAPPERS
#define DELETE_WRAPPERS ag_delete_wrappers(PCB_POINTER)
#endif

/*  Line -, xmlp8.syn */
  #define GET_CONTEXT CONTEXT = Context(PCB.line, PCB.column)

  typedef parse_pcb_struct Pcb;

  parse_pcb_struct::parse_pcb_struct()
    : tokenType(Pcb::none), dtdPresent(0)
  {
    // Nothing to do
  }

  void parse_pcb_struct::spaceChar(int c) {
    if (c == '\r') c = '\n';
    if (textStack.size()) tokenType = textType;
    spaceStack.concat(c);
  }

  void parse_pcb_struct::textChar(int c) {
    if (spaceStack.size()) tokenType=spaceType;
    textStack.concat((char)c);
  }

  void parse_pcb_struct::normalize(AgString &s) {
    char *readPointer = s;
    char *writePointer = readPointer;
    if (readPointer == NULL) return;
    while (*readPointer && strchr("\t\r\n ",*readPointer)) readPointer++;
    while (*readPointer) {
      while (*readPointer && strchr("\t\r\n ",*readPointer) == NULL) *writePointer++ = *readPointer++;
      while (*readPointer && strchr("\t\r\n ",*readPointer)) readPointer++;
      if (*readPointer) *writePointer++ = ' ';
    }
    *writePointer = 0;
  }

  void parse_pcb_struct::checkAttributes(const Context &context, const AgString &name, Symtab &map) {
    if (!dtdPresent) return;
    Element &element = elementMap[name];
    AgBaseStack<Attribute> &attributeList = element.attributeList;
    int i;
    for (i = 0; i < attributeList.size(); i++) {
      Attribute &attribute = attributeList[i];
      switch (attribute.def.presence) {
        case Default::REQUIRED: {
          const char *value = map.findValue(attribute.name);
          if (value) continue;
          map[attribute.name] = "VALUE NOT SPECIFIED";
          char buf[200];
          sprintf(buf, "Required attribute '%s' is missing", (const char *)attribute.name);
          warningList.push(Warning(context, buf));
          break;
        }
        case Default::DEFAULT: {
          const char *value = map[attribute.name];
          if (value == 0) value = attribute.def.value;
          if (attribute.def.fixed && attribute.def.value == value) continue;
          char buf[200];
          sprintf(buf, "Value of fixed attribute '%s' does not match default value ",
              (const char *) attribute.name);
          warningList.push(Warning(context, buf));
          break;
        }
      }
    }
    for (i = 0; i < attributeList.size(); i++) {
      Attribute &attribute = attributeList[i];
      if (attribute.type != Attribute::CDATA) normalize(map[attribute.name]);
    }
  }

  int parse_pcb_struct::warnAttval(const Context &context, const char *value, const AttvalPair &p) {
    if (value == NULL) return 0;
    char buf[200];
    sprintf(buf, "Value of '%s' ignored. Previously specified as '%s'",
            (const char *) p.name, value);
    warningList.push(Warning(context, buf));
    return 1;
  }

  void parse_pcb_struct::startTag(const Context &context, const AgString &name, AttvalList &list) {
    Symtab map;
    for (int i = 0; i < list.size(); i++) {
      AgString &value = map[list[i].name];
      if (warnAttval(context, value, list[i])) continue;
      value = list[i].value;
    }
    currentTagName = name;
    checkAttributes(context, name, map);
    currentMap = map;
    tagStack.push(name);
    mapStack.push(map);
    tokenType = startType;
  }

  void parse_pcb_struct::emptyTag(const Context &context, const AgString &name, AttvalList &list) {
    Symtab map;
    for (int i = 0; i < list.size(); i++) {
      AgString &value = map[list[i].name];
      if (warnAttval(context, value, list[i])) continue;
      map[list[i].name] = list[i].value;
    }
    checkAttributes(context, name, map);
    currentTagName = name;
    currentMap = map;
    tokenType = emptyType;
  }

  void parse_pcb_struct::endTag(const AgString &name) {
    currentTagName = name;
    currentMap = mapStack.pop();
    if (name != tagStack.pop()) {
      error_message = "Element nesting error";
      exit_flag = AG_SEMANTIC_ERROR_CODE;
      tokenType = errorType;
      return;
    }
    tokenType = endType;
  }
  void parse_pcb_struct::registerAttributes(const AgString &name, const AgBaseStack<Attribute> &attributeList) {
    Element &element = elementMap[name];
    if (element.name.size() == 0) element.name = name;
    int i;
    for (i = 0; i < attributeList.size(); i++) {
      AgString attributeName = attributeList[i].name;
      int &index = element.attributeIndex[attributeName];
      if (index != -1) {
        Attribute &attribute = element.attributeList[index];
        Context previous = attribute.context;
        char buf[200];
        sprintf(buf, "Redefinition of '%s::%s' ignored. Defined at line %d, column %d",
                (const char *) name,
                (const char *) attributeName, previous.line, previous.column);
        warningList.push(Warning(attributeList[i].context, buf));
        continue;
      }
      index = element.attributeList.size();
      element.attributeList.push(attributeList[i]);
    }
  }

#ifndef CONVERT_CASE
#define CONVERT_CASE(c) (c)
#endif
#ifndef TAB_SPACING
#define TAB_SPACING 8
#endif

static inline AgString ag_rp_1(PCB_DECL, int c) {
/* Line -, xmlp8.syn */
  return AgString().concat(c);
}

static inline AgString ag_rp_2(PCB_DECL, AgString &s, int c) {
/* Line -, xmlp8.syn */
  return s.concat(c);
}

static inline AgString ag_rp_3(PCB_DECL, AgString &s) {
/* Line -, xmlp8.syn */
  return s;
}

static inline AgString ag_rp_4(PCB_DECL, AgString &s) {
/* Line -, xmlp8.syn */
  return s;
}

static inline AgString ag_rp_5(PCB_DECL) {
/* Line -, xmlp8.syn */
  return AgString();
}

static inline AgString ag_rp_6(PCB_DECL, AgString &s, int c) {
/* Line -, xmlp8.syn */
  return s.concat(c);
}

static inline AgString ag_rp_7(PCB_DECL, AgString &s) {
/* Line -, xmlp8.syn */
  return s.concat(' ');
}

static inline AgString ag_rp_8(PCB_DECL, AgString &s, int c) {
/* Line -, xmlp8.syn */
  return s.concat(c);
}

static inline AgString ag_rp_9(PCB_DECL, AgString &s) {
/* Line -, xmlp8.syn */
  return s;
}

static inline AgString ag_rp_10(PCB_DECL) {
/* Line -, xmlp8.syn */
  return AgString();
}

static inline AgString ag_rp_11(PCB_DECL, AgString &s, int c) {
/* Line -, xmlp8.syn */
  return s.concat(c);
}

static inline AgString ag_rp_12(PCB_DECL, AgString &s) {
/* Line -, xmlp8.syn */
  return s.concat(' ');
}

static inline AgString ag_rp_13(PCB_DECL, AgString &s, int c) {
/* Line -, xmlp8.syn */
  return s.concat(c);
}

static inline AgString ag_rp_14(PCB_DECL, AgString &s) {
/* Line -, xmlp8.syn */
  return s;
}

static inline void ag_rp_15(PCB_DECL, AgString &t) {
/* Line -, xmlp8.syn */
  PCB.tokenType = Pcb::commentType, PCB.commentString = t;
}

static inline AgString ag_rp_16(PCB_DECL) {
/* Line -, xmlp8.syn */
  return AgString();
}

static inline AgString ag_rp_17(PCB_DECL, AgString &s, int c) {
/* Line -, xmlp8.syn */
  return s.concat(c);
}

static inline void ag_rp_18(PCB_DECL, int c) {
/* Line -, xmlp8.syn */
  PCB.textChar(c);
}

static inline void ag_rp_19(PCB_DECL) {
/* Line -, xmlp8.syn */
  PCB.spaceChar('\n');
}

static inline void ag_rp_20(PCB_DECL, int c) {
/* Line -, xmlp8.syn */
  PCB.spaceChar(c);
}

static inline void ag_rp_21(PCB_DECL, AgString &n) {
/* Line -, xmlp8.syn */
  PCB.dtdPresent=1;
}

static inline void ag_rp_22(PCB_DECL, AgString &n, AttvalList &l) {
/* Line -, xmlp8.syn */
  PCB.startTag(CONTEXT, n, l);
}

static inline AttvalList ag_rp_23(PCB_DECL) {
/* Line -, xmlp8.syn */
  return AttvalList();
}

static inline AttvalList ag_rp_24(PCB_DECL, AttvalList &list, AttvalPair &a) {
/* Line -, xmlp8.syn */
  return list.push(a);
}

static inline AttvalPair ag_rp_25(PCB_DECL, AgString &n, AgString &s) {
/* Line -, xmlp8.syn */
  return AttvalPair(n, s, CONTEXT);
}

static inline void ag_rp_26(PCB_DECL, AgString &n) {
/* Line -, xmlp8.syn */
  PCB.endTag(n);
}

static inline void ag_rp_27(PCB_DECL, int c) {
/* Line -, xmlp8.syn */
  PCB.textChar(c);
}

static inline void ag_rp_28(PCB_DECL, int c) {
/* Line -, xmlp8.syn */
  PCB.textChar(c);
}

static inline void ag_rp_29(PCB_DECL, int c) {
/* Line -, xmlp8.syn */
  PCB.spaceChar(c);
}

static inline void ag_rp_30(PCB_DECL) {
/* Line -, xmlp8.syn */
  PCB.spaceChar('\n');
}

static inline void ag_rp_31(PCB_DECL, AgString &n, AttvalList &l) {
/* Line -, xmlp8.syn */
  PCB.emptyTag(CONTEXT, n, l);
}

static inline void ag_rp_32(PCB_DECL, AgString &n, AttributeList &l) {
/* Line -, xmlp8.syn */
  PCB.registerAttributes(n, l);
}

static inline AttributeList ag_rp_33(PCB_DECL, Attribute &a) {
/* Line -, xmlp8.syn */
  return AttributeList().push(a);
}

static inline AttributeList ag_rp_34(PCB_DECL, AttributeList &l, Attribute &a) {
/* Line -, xmlp8.syn */
  return l.push(a);
}

static inline Attribute ag_rp_35(PCB_DECL, AgString &n, Attribute::Type t, Default &d) {
/* Line -, xmlp8.syn */
  return Attribute(RULE_CONTEXT[1], n, t, d);
}

static inline Attribute::Type ag_rp_36(PCB_DECL) {
/* Line -, xmlp8.syn */
  return Attribute::CDATA;
}

static inline Attribute::Type ag_rp_37(PCB_DECL) {
/* Line -, xmlp8.syn */
  return Attribute::ID;
}

static inline Attribute::Type ag_rp_38(PCB_DECL) {
/* Line -, xmlp8.syn */
  return Attribute::IDREF;
}

static inline Attribute::Type ag_rp_39(PCB_DECL) {
/* Line -, xmlp8.syn */
  return Attribute::IDREFS;
}

static inline Attribute::Type ag_rp_40(PCB_DECL) {
/* Line -, xmlp8.syn */
  return Attribute::ENTITY;
}

static inline Attribute::Type ag_rp_41(PCB_DECL) {
/* Line -, xmlp8.syn */
  return Attribute::ENTITIES;
}

static inline Attribute::Type ag_rp_42(PCB_DECL) {
/* Line -, xmlp8.syn */
  return Attribute::NMTOKEN;
}

static inline Attribute::Type ag_rp_43(PCB_DECL) {
/* Line -, xmlp8.syn */
  return Attribute::NMTOKENS;
}

static inline Attribute::Type ag_rp_44(PCB_DECL) {
/* Line -, xmlp8.syn */
  return Attribute::NOTATION;
}

static inline Attribute::Type ag_rp_45(PCB_DECL) {
/* Line -, xmlp8.syn */
  return Attribute::ENUMERATION;
}

static inline Default ag_rp_46(PCB_DECL) {
/* Line -, xmlp8.syn */
  return Default(Default::REQUIRED);
}

static inline Default ag_rp_47(PCB_DECL) {
/* Line -, xmlp8.syn */
  return Default();
}

static inline Default ag_rp_48(PCB_DECL, AgString &v) {
/* Line -, xmlp8.syn */
  return Default(v);
}

static inline Default ag_rp_49(PCB_DECL, AgString &v) {
/* Line -, xmlp8.syn */
  return Default(v,1);
}

static inline int ag_rp_50(PCB_DECL, int d) {
/* Line -, xmlp8.syn */
  return d-'0';
}

static inline int ag_rp_51(PCB_DECL, int n, int d) {
/* Line -, xmlp8.syn */
  return 10*n + d-'0';
}

static inline int ag_rp_52(PCB_DECL, int d) {
/* Line -, xmlp8.syn */
  return d-'0';
}

static inline int ag_rp_53(PCB_DECL, int n, int d) {
/* Line -, xmlp8.syn */
  return 16*n + d;
}

static inline int ag_rp_54(PCB_DECL, int n, int d) {
/* Line -, xmlp8.syn */
  return 16*n + (d&7) + 9;
}

static inline int ag_rp_55(PCB_DECL, AgString &s) {
/* Line -, xmlp8.syn */
  return PCB.currentEntityName = s, PCB.tokenType = Pcb::entityRefType;
}


#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 const char ag_wdf[] = {
  0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 5, 0, 5, 0, 0, 5, 0, 0, 0, 0,
  0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 6, 0, 0, 5, 0, 0, 0, 0, 0, 0,
  0, 0, 0, 5, 0, 0, 5, 0, 0, 0, 0, 0, 0, 0, 0, 0, 5, 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, 5, 0, 5, 5, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 5, 5, 5, 5,
  0, 0, 0, 0, 8, 0, 5, 0, 0, 0, 0, 0, 0, 0, 0, 5, 0, 0, 0, 0, 0, 0, 0,
  0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 5, 0, 0, 0, 0, 0, 0,
  0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 5, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0,
  0, 0, 5, 0, 5, 0, 0, 0, 0, 0, 5, 0, 0, 0, 0, 0, 0, 0, 5
};

#undef  VW
#define VW(i,t) *(t) (&(PCB).vs[(PCB).ssx + (i)])
#undef  VNO
#define VNO new(&(PCB).vs[(PCB).ssx])
#undef  VRO
#define VRO(to,v) ag_replace_object((to) &(PCB).vs[(PCB).ssx], v)
#undef  VWD
#define VWD(i,t) ag_delete_object((t) &(PCB).vs[(PCB).ssx + (i)]);
#undef  VDO
#define VDO(to, v) ag_delete_object((to) &(PCB).vs[(PCB).ssx], v)

template <class NewObject, class OldObject>
static inline void ag_replace_object(AgObjectWrapper<OldObject> *p, const NewObject &o) {
  delete p;
  new(p) AgObjectWrapper<NewObject >(o);
}

template <class Object>
static inline void ag_delete_object(AgObjectWrapper<Object> *p) {
  delete p;
}

template <class NewObject, class OldObject>
static inline const NewObject &ag_delete_object(AgObjectWrapper<OldObject> *p, const NewObject &o) {
  delete p;
  return o;
}


#undef AG_WRAP_4
#define AG_WRAP_4 AgObjectWrapper<AttvalPair >
#undef AG_WRAP_5
#define AG_WRAP_5 AgObjectWrapper<AgString >
#undef AG_WRAP_6
#define AG_WRAP_6 AgObjectWrapper<AttvalList >
#undef AG_WRAP_7
#define AG_WRAP_7 AgObjectWrapper<Attribute >
#undef AG_WRAP_8
#define AG_WRAP_8 AgObjectWrapper<AttributeList >
#undef AG_WRAP_9
#define AG_WRAP_9 AgObjectWrapper<Default >

static void ag_delete_wrappers(PCB_DECL) {
  int sn = (PCB).sn;
  int sx = (PCB).ssx;
  while (sx--) {
    switch (ag_wdf[sn]) {
      case 4: ag_delete_object((AG_WRAP_4 *) &(PCB).vs[sx]); break;
      case 5: ag_delete_object((AG_WRAP_5 *) &(PCB).vs[sx]); break;
      case 6: ag_delete_object((AG_WRAP_6 *) &(PCB).vs[sx]); break;
      case 7: ag_delete_object((AG_WRAP_7 *) &(PCB).vs[sx]); break;
      case 8: ag_delete_object((AG_WRAP_8 *) &(PCB).vs[sx]); break;
      case 9: ag_delete_object((AG_WRAP_9 *) &(PCB).vs[sx]); break;
      default: break;
    }
    sn = (PCB).ss[sx];
  }
}

static parse_vs_type const ag_null_value NULL_VALUE_INITIALIZER;

static const unsigned char ag_rpx[] = {
    0,  0,  0,  0,  0,  0,  0,  0,  0,  1,  2,  3,  4,  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,  5,  6,  7,  8,  9, 10, 11, 12, 13, 14, 15, 16,  0,  0,  0,  0,
    0,  0,  0,  0,  0,  0,  0,  0,  0,  0,  0,  0,  0,  0,  0,  0, 17, 18,
   19,  0,  0,  0,  0,  0,  0,  0,  0,  0,  3,  0,  0, 20, 21, 22,  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, 23,  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, 24, 25, 26, 27, 28,  0,  0,  0,  0, 29, 30,
    0, 31, 32,  0,  0,  0, 33,  4,  0,  0,  0,  0,  0,  0,  0,  0,  0,  0,
    0,  3,  0,  0,  0,  0,  0,  0,  0,  0,  0,  0,  0,  0,  0,  4, 34,  0,
    0,  0,  0,  0,  0,  0, 35, 36, 37, 38,  0,  0,  0, 39, 40, 41, 42, 43,
   44, 45, 46, 47, 48,  4,  0,  0,  0,  0, 34,  0,  0,  0,  0,  0,  0, 49,
   50, 51, 52,  0,  0,  0,  0,  0,  0,  0,  0,  0,  0,  0,  0,  0,  0,  0,
    0,  0, 53, 54, 55, 56, 57,  0,  0, 58, 59,  0,  0,  4, 60,  0,  0,  0,
    0,  0,  0,  0,  0,  0, 34,  0,  0,  0,  0,  0,  0,  0,  0,  0,  0,  0,
    0,  0,  0,  0,  0,  0,  4
};

static const unsigned char ag_key_itt[] = {
 0
};

static const unsigned short ag_key_pt[] = {
0
};

static const unsigned char ag_key_ch[] = {
    0, 45, 68,255,120,255, 33, 63,255, 60,255, 45, 68,255, 33, 63,255, 60,
  255,110,121,255, 70, 73, 80, 82,255,110,121,255, 73, 89,255, 84,255, 73,
  255, 84,255, 77, 78,255, 83,255, 70,255, 69,255, 82,255, 68,255, 83,255,
   78,255, 69,255, 75,255, 79,255, 84,255, 68, 77, 79,255, 34, 35, 39, 41,
   47, 63, 65, 67, 69, 73, 78, 80, 83,101,115,118,255,118,255, 45,255, 60,
  255,120,255, 35,255, 45, 91,255, 33, 63,255, 13, 38, 60,255, 33, 63,255,
   60,255, 63,255, 47,255, 13, 93,255,120,255, 35,255, 45, 91,255, 33, 47,
   63,255, 13, 38, 60,255, 60,255,110,121,255, 34, 39, 63,101,115,255, 93,
  255, 39,255,110,121,255, 34, 39, 63,115,255, 80, 83,255, 76, 78,255, 45,
   65, 69, 78,255, 33, 63,255, 60,255,120,255, 35,255, 38,255, 65, 69,255,
   35,255, 78,255, 73, 89,255, 84,255, 73,255, 84,255, 78,255, 83,255, 70,
  255, 69,255, 82,255, 68,255, 83,255, 78,255, 69,255, 75,255, 79,255, 84,
  255, 77, 79,255, 67, 69, 73, 78,255, 41,255, 70, 73, 82,255, 35,255
};

static const unsigned char ag_key_act[] = {
  0,3,3,4,3,4,2,1,4,2,4,3,3,4,2,0,4,2,4,3,3,4,3,3,3,3,4,3,3,4,3,0,4,2,4,
  2,4,2,4,3,2,4,0,4,1,4,2,4,2,4,1,4,0,4,1,4,2,4,2,4,2,4,2,4,3,2,3,4,2,2,
  2,3,3,3,3,3,2,2,2,3,3,3,3,3,4,3,4,3,4,3,4,0,4,1,4,3,3,4,2,0,4,3,2,2,4,
  3,0,4,2,4,3,4,3,4,3,3,4,0,4,1,4,3,3,4,2,0,0,4,3,2,2,4,3,4,3,3,4,2,3,3,
  3,3,4,3,4,3,4,3,3,4,2,3,3,3,4,3,3,4,3,3,4,3,3,2,3,4,2,0,4,2,4,0,4,1,4,
  2,4,3,3,4,3,4,3,4,3,0,4,2,4,2,4,2,4,2,4,0,4,1,4,2,4,2,4,1,4,0,4,1,4,2,
  4,2,4,2,4,2,4,2,3,4,3,2,2,2,4,3,4,3,3,3,4,2,4
};

static const unsigned short ag_key_parm[] = {
    0, 59, 97,  0, 84,  0,  0, 64,  0,  0,  0, 59, 97,  0,  0, 64,  0,  0,
    0,124,122,  0,208,207,176,206,  0,123,121,  0,194,193,  0,  0,  0,  0,
    0,  0,  0,154,  0,  0,192,  0,191,  0,  0,  0,  0,  0,190,  0,196,  0,
  195,  0,  0,  0,  0,  0,  0,  0,  0,  0,239,  0,199,  0,  0,  0,  0,180,
  151,  2,155,189,  0,  0,  0,238,237,243,120, 90,  0, 90,  0,  1,  0, 97,
    0,226,  0,224,  0, 59, 75,  0,  0, 64,  0, 76,  0,  0,  0, 59, 64,  0,
    0,  0,  2,  0,151,  0, 76,  3,  0,226,  0,224,  0, 59, 75,  0,  0,147,
   64,  0, 76,  0,  0,  0,147,  0,124,122,  0,  0,123,  2,243,120,  0,  3,
    0,121,  0,124,122,  0,  0,123,  2,120,  0,238,237,  0,152,232,  0, 59,
  181,  0,250,  0,  0, 64,  0,  0,  0,226,  0,224,  0,  0,  0,155,154,  0,
  176,  0,239,  0,194,193,  0,  0,  0,  0,  0,  0,  0,  0,  0,192,  0,191,
    0,  0,  0,  0,  0,190,  0,196,  0,195,  0,  0,  0,  0,  0,  0,  0,  0,
    0,  0,199,  0,189,  0,  0,  0,  0,180,  0,208,207,206,  0,  0,  0
};

static const unsigned short ag_key_jmp[] = {
    0,  0,  2,  0,  9,  0,  1,  4,  0,  6,  0, 12, 14,  0, 11,  0,  0, 14,
    0, 21, 24,  0, 28, 33, 40, 46,  0, 54, 57,  0, 79,  0,  0, 30,  0, 33,
    0, 35,  0, 75, 37,  0,  0,  0, 42,  0, 44,  0, 46,  0, 48,  0,  0,  0,
   52,  0, 54,  0, 56,  0, 58,  0, 60,  0, 82, 62, 86,  0, 19, 22, 27, 61,
   63, 65, 67, 70, 39, 50, 64, 93, 99,105,113,123,  0,130,  0,137,  0,139,
    0,  0,  0, 91,  0,150,152,  0, 95,  0,  0,148, 93, 98,  0,159,  0,  0,
  105,  0,162,  0,164,  0,166,168,  0,  0,  0,117,  0,173,175,  0,121,  0,
    0,  0,171,119,124,  0,182,  0,184,187,  0,134,191,195,197,205,  0,215,
    0,218,  0,223,226,  0,147,230,234,236,  0,246,252,  0,267,273,  0,258,
  260,158,278,  0,161,  0,  0,166,  0,  0,  0,171,  0,173,  0,286,289,  0,
  294,  0,301,  0,311,  0,  0,184,  0,187,  0,189,  0,191,  0,  0,  0,195,
    0,197,  0,199,  0,201,  0,  0,  0,205,  0,207,  0,209,  0,211,  0,213,
    0,215,314,  0,306,193,203,217,  0,321,  0,323,328,335,  0,227,  0
};

static const unsigned char ag_key_index[] = {
    9,  0, 17,  0, 68, 85,  0, 87, 17, 89,  0,101,108,  0,110,110,110, 87,
    0,108,112,  0,  0,114,  0,  0,  0,128,132,  0,  0,  0,137,110,110,110,
    0,  0,112,114,143,  0,  0,145,  0,  0,  0,110,  0,110,110,  0,112,112,
    0,  0,  0,  0,145,  0,150,110,155,  0,  0,  0,  0,  0,110,  0,  0,  0,
  169,  0,  0,  0,  0,  0,  0,  0,  0,  0,  0,  0,  0,169,  0,175,175,  0,
    0,  0,  0,  0,  0,  0,  0,  0,  0,  0,  0,175,175,  0,  0,  0,  0,  0,
    0,  0,  0,  0,  0,  0,  0,  0,  0,  0,155,155,  0,  0,177,  0,175,175,
    0,  0,  0,  0,  0,  0,  0,  0,  0,  0,180,  0,155,175,  0,175,  0,182,
    0,220,180,  0,  0,  0,  0,  0,  0,  0,225,  0,  0,  0,  0,  0,  0,  0,
    0,  0,  0,231,  0,225,  0,225,225,225,  0,  0,  0,  0,  0,  0,  0,  0,
    0,  0,  0,  0,  0,  0,  0,  0,  0,  0,225,  0,  0,  0,  0,  0,225,  0,
    0,  0,  0,  0,  0,  0,  0,  0
};

static const unsigned char ag_key_ends[] = {
45,0, 79,67,84,89,80,69,0, 109,108,0, 45,0, 79,67,84,89,80,69,0, 
111,34,0, 101,115,34,0, 73,88,69,68,0, 77,80,76,73,69,68,0, 
67,68,65,84,65,0, 69,81,85,73,82,69,68,0, 111,39,0, 101,115,39,0, 
42,0, 62,0, 62,0, 78,89,0, 68,65,84,65,0, 80,84,89,0, 69,83,0, 
65,84,65,0, 84,65,84,73,79,78,0, 85,66,76,73,67,0, 
89,83,84,69,77,0, 110,99,111,100,105,110,103,0, 
116,97,110,100,97,108,111,110,101,0, 101,114,115,105,111,110,0, 
101,114,115,105,111,110,0, 45,0, 33,68,79,67,84,89,80,69,0, 10,0, 
45,0, 67,68,65,84,65,91,0, 45,45,0, 62,0, 62,0, 10,0, 93,62,0, 
10,0, 45,0, 67,68,65,84,65,91,0, 47,0, 111,34,0, 101,115,34,0, 
110,111,39,0, 62,0, 110,99,111,100,105,110,103,0, 
116,97,110,100,97,108,111,110,101,0, 93,62,0, 121,101,115,39,0, 
111,34,0, 101,115,34,0, 110,111,39,0, 62,0, 
116,97,110,100,97,108,111,110,101,0, 85,66,76,73,67,0, 
89,83,84,69,77,0, 45,0, 84,84,76,73,83,84,0, 69,77,69,78,84,0, 
84,73,84,89,0, 79,84,65,84,73,79,78,0, 78,89,0, 77,80,84,89,0, 
80,67,68,65,84,65,0, 68,65,84,65,0, 68,65,84,65,0, 69,83,0, 
84,65,84,73,79,78,0, 42,0, 73,88,69,68,0, 77,80,76,73,69,68,0, 
69,81,85,73,82,69,68,0, 
};
#define AG_TCV(x) (((int)(x) >= -1 && (int)(x) <= 255) ? ag_tcv[(x) + 1] : 0)

static const unsigned short ag_tcv[] = {
   10,262,262,262,262,262,262,262,262,262,253,254,262,262,255,262,262,262,
  262,262,262,262,262,262,262,262,262,262,262,262,262,262,262,254,263, 25,
  263,263,229,228, 32,167,172,162,163,173,127,260,263,225,225,225,225,225,
  225,225,225,225,225,256,222,144, 94, 61,161,263,227,227,227,227,227,227,
  257,257,137,257,257,257,257,257,257,257,257,257,257,257,257,257,257,139,
  257,257,101,264,106,264,258,264,227,227,227,227,227,227,257,257,137,257,
  257,257,257,257,257,257,257,257,257,257,257,257,257,139,257,257,264,168,
  264,264,264,264,264,264,264,264,264,264,264,264,264,264,264,264,264,264,
  264,264,264,264,264,264,264,264,264,264,264,264,264,264,264,264,264,264,
  264,264,264,264,264,264,264,264,264,264,264,264,264,264,264,264,264,264,
  264,264,264,264,261,264,264,264,264,264,264,264,264,259,259,259,259,259,
  259,259,259,259,259,259,259,259,259,259,259,259,259,259,259,259,259,259,
  264,259,259,259,259,259,259,259,259,259,259,259,259,259,259,259,259,259,
  259,259,259,259,259,259,259,259,259,259,259,259,259,259,264,259,259,259,
  259,259,259,259,259
};

#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


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;


#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(PCB_DECL) {
  int ag_k = 0;
  while (ag_k < (PCB).rx) {
    int ag_ch = (PCB).lab[ag_k++];
    switch (ag_ch) {
    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++;
    }
  }
  ag_k = 0;
  while ((PCB).rx < (PCB).fx) (PCB).lab[ag_k++] = (PCB).lab[(PCB).rx++];
  (PCB).fx = ag_k;
  (PCB).rx = 0;
}


static void ag_prot(PCB_DECL) {
  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(PCB_DECL) {
  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 = (parse_token_type) (PCB).drt;
  (PCB).ssx = (PCB).dssx;
  (PCB).sn = (PCB).dsn;
  (PCB).drt = -1;
}


static const unsigned short ag_tstt[] = {
255,254,253,144,97,84,64,59,0,4,5,80,81,
255,254,253,0,11,13,
255,254,253,144,97,64,59,0,7,8,9,58,63,
144,0,6,140,141,
255,254,253,0,
90,0,85,
259,258,257,256,227,139,137,0,14,65,
264,263,261,260,259,258,257,256,254,253,229,228,227,225,222,173,172,168,167,
  163,162,161,144,139,137,127,106,101,94,61,32,25,1,0,60,
255,254,253,64,59,0,7,58,63,
144,97,0,82,83,
259,258,257,256,227,139,137,0,14,
264,263,262,261,260,259,258,257,256,255,254,253,229,228,227,226,225,224,222,
  173,172,168,167,163,162,161,144,139,137,127,106,101,94,76,75,64,61,59,
  32,25,0,6,41,42,58,63,71,72,140,141,142,148,149,221,223,
255,254,253,64,59,10,0,7,8,9,58,63,
255,254,253,94,0,11,13,87,91,
255,254,253,2,0,11,13,86,87,
261,260,259,258,257,256,227,225,139,137,127,0,
255,254,253,2,0,11,13,70,
264,263,261,260,259,258,257,256,254,253,229,228,227,225,222,173,172,168,167,
  163,162,161,144,139,137,127,106,101,94,61,32,25,1,0,
255,254,253,0,11,13,
255,254,253,144,64,59,0,7,8,9,58,63,
261,260,259,258,257,256,255,254,253,227,225,151,139,137,127,61,0,145,
225,0,
225,0,
264,263,261,260,259,258,257,256,255,254,253,229,228,227,225,222,173,172,168,
  167,163,162,161,144,139,137,127,106,101,94,76,61,32,25,3,0,73,77,78,79,
259,258,257,256,227,139,137,0,14,
227,225,222,0,
225,222,0,
264,263,262,261,260,259,258,257,256,255,254,253,229,228,227,226,225,224,222,
  173,172,168,167,163,162,161,144,139,137,127,106,101,94,76,75,64,61,59,
  32,25,0,6,41,42,58,63,71,72,140,141,148,221,223,
147,0,143,
10,0,
94,0,
32,25,0,93,
243,124,123,122,120,0,88,89,
2,0,
264,263,261,260,259,258,257,256,229,228,227,225,222,173,172,168,167,163,162,
  161,144,139,137,127,106,101,94,61,32,25,2,0,69,
2,0,
61,0,
259,258,257,256,227,139,137,0,14,
255,254,253,151,61,0,11,13,87,
264,263,261,260,259,258,257,256,255,254,253,229,228,227,225,222,173,172,168,
  167,163,162,161,144,139,137,127,106,101,94,76,61,32,25,0,77,
3,0,74,
261,260,259,258,257,256,227,225,222,139,137,127,0,
259,258,257,256,227,139,137,0,14,
255,254,253,121,32,25,0,11,13,87,
260,258,257,256,227,225,139,137,127,0,92,96,
260,258,257,256,227,225,139,137,127,0,92,96,
255,254,253,94,0,11,13,87,91,
255,254,253,2,0,11,13,87,
255,254,253,94,0,11,13,87,91,
255,254,253,2,0,11,13,87,
264,263,261,260,259,258,257,256,254,253,229,228,227,225,222,173,172,168,167,
  163,162,161,144,139,137,127,106,101,94,61,32,25,2,0,67,68,
261,260,259,258,257,256,255,254,253,227,225,139,137,127,101,61,0,11,13,100,
259,258,257,256,227,139,137,0,14,146,
151,61,0,
261,260,259,258,257,256,255,254,253,227,225,139,137,127,61,0,11,13,87,
260,258,257,256,227,225,139,137,127,0,
25,0,
32,0,
121,0,
32,25,0,245,
124,123,122,120,0,89,
264,263,261,260,259,258,257,256,254,253,229,228,227,225,222,173,172,168,167,
  163,162,161,144,139,137,127,106,101,94,61,32,25,0,
238,237,101,61,0,98,99,
101,61,0,107,
261,260,259,258,257,256,255,254,253,227,225,139,137,127,94,0,11,13,87,91,
61,0,
257,227,139,137,0,244,
257,227,139,137,0,244,
255,254,253,2,0,11,13,87,
255,254,253,0,11,13,
255,254,253,0,11,13,
255,254,253,101,61,0,11,13,87,
255,254,253,250,232,229,181,152,106,64,59,0,27,58,63,102,103,104,105,108,
  109,110,111,230,231,
61,0,
32,25,0,37,
258,257,227,225,139,137,127,32,25,0,247,248,249,
32,0,
25,0,
32,25,0,51,
32,25,0,44,
255,254,253,0,11,13,
255,254,253,0,11,13,
255,254,253,0,11,13,
255,254,253,0,11,13,
259,258,257,256,227,139,137,0,14,
255,254,253,250,232,229,181,152,64,59,0,27,58,63,102,103,108,109,110,111,
  230,231,
106,0,
264,263,262,261,260,259,258,257,256,255,254,253,228,227,226,225,224,222,173,
  172,168,167,163,162,161,144,139,137,127,106,101,94,61,32,25,0,39,
264,263,262,261,260,259,258,257,256,255,254,253,228,227,226,225,224,222,173,
  172,168,167,163,162,161,144,139,137,127,106,101,94,61,32,25,0,38,
258,257,227,225,139,137,127,0,247,
263,260,258,257,256,255,254,229,227,225,222,173,172,167,163,162,161,139,137,
  127,32,0,56,57,
263,260,258,257,256,255,254,229,227,225,222,173,172,167,163,162,161,139,137,
  127,32,25,0,53,54,
255,254,253,0,11,13,
264,263,262,261,260,259,258,257,256,255,254,253,229,228,227,225,222,173,172,
  168,167,163,162,161,144,139,137,127,106,101,94,61,32,25,0,49,50,
264,263,262,261,260,259,258,257,256,255,254,253,229,228,227,225,222,173,172,
  168,167,163,162,161,144,139,137,127,106,101,94,61,32,25,0,46,47,
259,258,257,256,229,227,139,137,0,14,
259,258,257,256,227,139,137,0,14,
259,258,257,256,227,139,137,0,14,
259,258,257,256,227,139,137,0,14,
261,260,259,258,257,256,227,225,222,139,137,127,0,
255,254,253,61,0,11,13,87,
264,263,262,261,260,259,258,257,256,255,254,253,228,227,226,225,224,222,173,
  172,168,167,163,162,161,144,139,137,127,106,101,94,61,32,25,0,41,42,221,
  223,
264,263,262,261,260,259,258,257,256,255,254,253,228,227,226,225,224,222,173,
  172,168,167,163,162,161,144,139,137,127,106,101,94,61,32,25,0,41,42,221,
  223,
263,260,258,257,256,255,254,229,227,225,222,173,172,167,163,162,161,139,137,
  127,0,
32,0,
263,260,258,257,256,255,254,229,227,225,222,173,172,167,163,162,161,139,137,
  127,32,0,
25,0,
32,25,0,44,
264,263,262,261,260,259,258,257,256,255,254,253,229,228,227,225,222,173,172,
  168,167,163,162,161,144,139,137,127,106,101,94,61,25,0,
32,0,
264,263,262,261,260,259,258,257,256,255,254,253,229,228,227,225,222,173,172,
  168,167,163,162,161,144,139,137,127,106,101,94,61,32,0,
25,0,
255,254,253,0,11,13,
261,260,259,258,257,256,255,254,253,227,225,139,137,127,0,11,13,
261,260,259,258,257,256,255,254,253,227,225,139,137,127,0,11,13,
261,260,259,258,257,256,255,254,253,227,225,139,137,127,0,11,13,182,183,
261,260,259,258,257,256,255,254,253,227,225,139,137,127,0,11,13,
259,258,257,256,227,139,137,0,14,
238,237,32,25,0,24,98,233,
238,237,0,98,251,252,
259,258,257,256,227,139,137,0,14,
255,254,253,61,0,11,13,87,183,
167,155,154,0,153,156,157,158,159,160,
261,260,259,258,257,256,255,254,253,227,225,139,137,127,0,11,13,
264,263,262,261,260,259,258,257,256,255,254,253,229,228,227,226,225,224,222,
  173,172,168,167,163,162,161,144,139,137,127,106,101,94,61,32,25,0,27,28,
  34,35,36,41,42,221,223,
264,263,262,261,260,259,258,257,256,255,254,253,229,228,227,226,225,224,222,
  173,172,168,167,163,162,161,144,139,137,127,106,101,94,61,32,25,0,27,28,
  29,30,31,41,42,221,223,
255,254,253,61,0,11,13,235,236,
255,254,253,61,0,11,13,87,
61,0,
255,254,253,0,11,13,
255,254,253,61,0,11,13,87,
61,0,
261,260,259,258,257,256,255,254,253,227,225,139,137,127,0,11,13,
259,258,257,256,227,139,137,0,14,
61,0,
255,254,253,163,162,161,61,0,164,
259,258,257,256,255,254,253,227,176,167,139,137,0,11,13,87,
255,254,253,61,0,11,13,87,
238,237,32,25,0,24,98,234,
264,263,262,261,260,259,258,257,256,255,254,253,229,228,227,226,225,224,222,
  173,172,168,167,163,162,161,144,139,137,127,106,101,94,61,25,0,27,28,34,
  41,42,221,223,
32,0,
264,263,262,261,260,259,258,257,256,255,254,253,229,228,227,226,225,224,222,
  173,172,168,167,163,162,161,144,139,137,127,106,101,94,61,32,0,27,28,29,
  41,42,221,223,
25,0,
239,0,
32,25,0,51,
199,196,195,194,193,192,191,190,189,167,0,184,186,187,188,197,198,
259,258,257,256,227,176,167,139,137,0,14,158,159,165,166,
61,0,
255,254,253,61,0,11,13,87,
255,254,253,0,11,13,
255,254,253,61,0,11,13,87,
261,260,259,258,257,256,227,225,139,137,127,0,18,19,
255,254,253,0,11,13,
255,254,253,0,11,13,
255,254,253,180,172,168,0,11,13,87,177,178,179,
259,258,257,256,255,254,253,227,167,139,137,0,11,13,87,
261,260,259,258,257,256,227,225,139,137,127,0,
255,254,253,173,172,168,163,162,161,0,164,
255,254,253,173,172,168,0,11,13,87,
61,0,
259,258,257,256,227,139,137,0,14,
32,25,0,44,
261,260,259,258,257,256,227,225,139,137,127,0,
255,254,253,172,168,0,11,13,87,
167,0,
208,207,206,32,25,0,37,185,
172,0,
180,172,168,0,
259,258,257,256,255,254,253,227,139,137,0,11,13,87,
168,0,
255,254,253,0,11,13,
180,0,
259,258,257,256,227,167,139,137,0,14,158,159,165,166,
173,172,168,0,169,170,171,174,175,
261,260,259,258,257,256,227,225,139,137,127,0,
172,168,0,203,204,205,
259,258,257,256,227,139,137,0,14,
255,254,253,0,11,13,
259,258,257,256,227,139,137,0,14,
259,258,257,256,255,254,253,227,139,137,0,11,13,87,
259,258,257,256,255,254,253,227,167,139,137,0,11,13,87,
173,172,0,174,
259,258,257,256,255,254,253,227,167,139,137,0,11,13,87,
168,0,169,
172,0,
261,260,259,258,257,256,255,254,253,227,225,139,137,127,0,11,13,87,
168,0,203,
172,0,
261,260,259,258,257,256,255,254,253,227,225,172,168,139,137,127,0,11,13,87,
32,25,0,37,
261,260,259,258,257,256,227,225,139,137,127,0,
259,258,257,256,227,139,137,0,14,
259,258,257,256,227,167,139,137,0,14,158,159,165,166,
259,258,257,256,227,167,139,137,0,14,158,159,165,166,
261,260,259,258,257,256,227,225,139,137,127,0,18,19,
172,168,0,200,201,202,
261,260,259,258,257,256,227,225,139,137,127,0,
255,254,253,173,172,0,11,13,87,
255,254,253,172,168,0,11,13,87,
255,254,253,172,168,0,11,13,87,
259,258,257,256,255,254,253,227,139,137,0,11,13,87,
168,0,200,
172,0,
259,258,257,256,227,139,137,0,14,
261,260,259,258,257,256,255,254,253,227,225,172,168,139,137,127,0,11,13,87,
  0
};


static unsigned const char ag_astt[2389] = {
  8,8,8,5,5,1,8,8,7,0,1,1,1,1,1,1,7,1,1,1,1,1,5,8,1,1,7,1,1,1,1,1,1,7,1,1,1,
  9,9,9,5,1,7,1,2,2,2,2,2,2,2,7,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,4,4,4,4,4,7,1,9,9,9,1,1,5,3,3,3,5,1,7,1,3,2,2,2,2,2,2,2,7,
  1,2,2,2,2,2,2,2,2,2,2,2,2,2,1,2,1,2,1,2,2,2,2,2,2,2,2,1,2,2,2,2,2,2,2,1,1,
  2,1,2,2,7,1,2,1,1,1,1,1,1,1,1,1,1,1,1,1,1,1,1,1,8,7,1,1,1,1,1,1,1,1,8,7,1,
  1,1,1,1,1,1,5,7,1,1,1,1,10,10,10,10,10,10,10,10,10,10,10,5,1,1,1,8,7,1,1,1,
  10,10,10,10,10,10,10,10,10,10,10,10,10,10,10,10,10,10,10,10,10,10,10,10,10,
  10,10,10,10,10,10,10,1,7,1,1,1,7,1,1,1,1,1,5,1,1,7,1,1,3,1,1,10,10,10,10,
  10,10,4,4,4,10,10,4,10,10,10,4,7,1,2,7,2,7,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,5,7,1,1,1,1,2,2,2,2,2,2,2,7,1,10,10,3,
  7,10,3,7,2,2,2,2,2,2,2,2,2,2,2,2,2,1,2,1,2,1,2,2,2,2,2,2,2,2,1,2,2,2,2,2,2,
  2,1,1,2,1,2,2,5,3,2,3,3,3,3,1,3,1,3,1,1,1,7,3,3,7,1,7,1,1,7,3,1,1,1,1,1,5,
  1,1,3,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,5,7,3,
  3,7,2,7,2,2,2,2,2,2,2,7,1,1,1,1,8,8,7,1,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,5,3,3,7,3,10,10,10,10,10,10,10,10,2,
  10,10,10,7,2,2,2,2,2,2,2,7,1,1,1,1,5,5,5,7,3,1,3,1,1,1,1,1,1,1,1,1,7,1,1,1,
  1,1,1,1,1,1,1,1,7,1,1,1,1,1,8,7,1,1,1,1,1,1,1,5,7,3,1,3,1,1,1,8,7,1,1,1,1,
  1,1,1,5,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,1,1,1,1,1,1,1,
  1,1,1,5,7,1,3,10,10,10,10,10,10,1,1,1,10,10,10,10,10,8,5,7,1,1,1,2,2,2,2,2,
  2,2,5,1,2,2,2,7,10,10,10,10,10,10,1,1,1,10,10,10,10,10,8,7,1,1,1,9,9,9,9,9,
  9,9,9,9,5,3,7,3,7,3,7,1,1,7,3,1,1,1,1,5,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,5,1,1,5,5,7,1,3,1,8,7,1,10,10,10,10,10,10,
  1,1,1,10,10,10,10,10,8,7,1,1,1,1,2,7,1,1,1,1,7,1,1,1,1,1,7,1,1,1,1,5,7,3,1,
  3,1,1,1,7,1,1,1,1,1,7,1,1,1,1,1,5,5,7,3,1,3,1,1,1,1,1,1,1,1,8,1,1,7,1,1,1,
  1,1,1,1,1,1,1,1,1,1,2,7,1,1,7,2,1,1,1,1,1,1,1,5,5,7,1,1,3,3,7,3,7,1,1,7,1,
  1,1,7,3,1,1,1,7,1,1,1,1,1,7,1,1,1,1,1,7,1,1,1,1,1,7,1,1,2,2,2,2,2,2,2,7,1,
  9,9,9,1,1,1,1,1,1,1,5,3,3,3,3,3,3,3,3,3,3,3,1,7,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,4,4,4,4,4,4,4,7,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,4,4,4,4,4,4,4,7,1,9,9,9,9,9,9,9,5,3,1,1,1,1,
  1,1,1,1,1,1,1,1,1,1,1,1,1,1,1,1,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,8,7,1,1,1,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,8,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,8,7,1,1,2,2,2,2,1,2,2,2,7,1,2,2,2,2,2,2,2,7,1,2,2,2,2,
  2,2,2,7,1,2,2,2,2,2,2,2,7,1,10,10,10,10,10,10,10,10,2,10,10,10,7,1,1,1,5,7,
  3,1,3,10,10,10,10,10,10,10,10,10,10,10,10,1,10,1,10,1,10,10,10,10,10,10,10,
  10,10,10,10,10,10,10,10,10,2,10,7,2,2,1,1,10,10,10,10,10,10,10,10,10,10,10,
  10,1,10,1,10,1,10,10,10,10,10,10,10,10,10,10,10,10,10,10,10,10,10,2,7,2,2,
  1,1,9,9,9,9,9,9,9,9,9,9,9,9,9,9,9,9,9,9,9,9,5,3,7,9,9,9,9,9,9,9,9,9,9,9,9,
  9,9,9,9,9,9,9,9,9,5,3,7,1,1,7,3,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,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,1,1,1,7,1,1,10,10,10,10,10,10,1,1,1,10,10,10,
  10,10,7,1,1,10,10,10,10,10,10,1,1,1,10,10,10,10,10,7,1,1,10,10,10,10,10,10,
  1,1,1,10,10,10,10,10,7,1,1,1,2,10,10,10,10,10,10,1,1,1,10,10,10,10,10,7,1,
  1,2,2,2,2,2,2,2,7,1,1,1,1,1,7,1,1,1,1,1,7,1,1,1,2,2,2,2,2,2,2,7,1,1,1,1,8,
  7,1,1,1,2,1,1,1,7,1,1,1,1,1,1,10,10,10,10,10,10,1,1,1,10,10,10,10,10,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,1,8,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,1,1,
  1,1,1,1,1,1,1,8,7,1,1,1,1,1,1,1,1,1,1,1,1,5,7,1,1,3,3,1,1,1,5,7,3,1,3,2,7,
  1,1,1,7,1,1,1,1,1,5,7,3,1,3,2,7,10,10,10,10,10,10,1,1,1,10,10,10,10,10,7,1,
  1,2,2,2,2,2,2,2,5,1,2,7,5,5,5,3,3,3,5,7,3,8,8,8,8,1,1,1,8,8,8,8,8,7,1,1,1,
  1,1,1,8,7,1,1,1,1,1,1,1,7,1,1,1,9,9,9,9,9,9,9,9,9,9,9,9,1,1,9,1,9,1,9,9,9,
  9,9,9,9,9,9,9,9,9,9,9,9,9,9,5,3,3,3,3,3,1,1,3,7,9,9,9,9,9,9,9,9,9,9,9,9,1,
  1,9,1,9,1,9,9,9,9,9,9,9,9,9,9,9,9,9,9,9,9,9,5,3,3,3,3,3,1,1,3,7,1,5,1,1,7,
  1,1,2,2,2,2,2,2,2,2,1,7,1,1,1,1,2,2,2,2,2,2,2,1,1,2,2,7,1,1,1,1,1,2,7,1,1,
  1,8,7,1,1,1,1,1,1,7,1,1,1,1,1,5,7,1,1,3,1,1,1,1,1,1,1,1,1,1,1,7,1,1,1,1,1,
  7,1,1,1,1,1,7,1,1,1,1,1,8,8,1,7,1,1,1,1,1,1,8,8,8,8,1,1,1,8,8,8,8,7,1,1,1,
  10,10,10,10,10,10,10,10,10,10,10,5,5,5,5,5,5,5,3,3,3,7,3,1,1,1,8,5,8,7,1,1,
  1,2,7,2,2,2,2,2,2,2,7,1,1,1,5,3,9,9,9,9,9,9,9,9,9,9,9,5,1,1,1,5,8,7,1,1,1,
  1,7,1,2,2,1,1,7,2,2,3,7,5,5,5,7,8,8,8,8,1,1,1,8,8,8,7,1,1,1,1,5,1,1,1,5,3,
  1,3,7,2,2,2,2,2,1,2,2,7,1,1,1,1,1,1,8,1,7,1,1,1,1,1,10,10,10,10,10,10,10,
  10,10,10,10,4,8,1,7,1,1,1,2,2,2,2,2,2,2,7,1,1,1,1,7,1,1,2,2,2,2,2,2,2,7,1,
  8,8,8,8,1,1,1,8,8,8,7,1,1,1,8,8,8,8,1,1,1,8,8,8,8,7,1,1,1,1,3,7,3,8,8,8,8,
  1,1,1,8,8,8,8,7,1,1,1,1,5,3,3,7,8,8,8,8,8,8,1,1,1,8,8,8,8,8,7,1,1,1,1,5,3,
  3,7,10,10,10,10,10,10,1,1,1,10,10,5,8,10,10,10,7,1,1,1,1,1,7,2,10,10,10,10,
  10,10,10,10,10,10,10,4,2,2,2,2,2,2,2,7,1,2,2,2,2,2,1,2,2,7,1,1,1,1,1,2,2,2,
  2,2,1,2,2,7,1,1,1,1,1,1,1,1,1,1,1,1,1,1,1,1,7,1,1,8,1,7,1,1,1,10,10,10,10,
  10,10,10,10,10,10,10,4,1,1,1,5,5,7,3,1,3,1,1,1,5,5,7,3,1,3,1,1,1,5,5,7,3,1,
  3,8,8,8,8,1,1,1,8,8,8,7,1,1,1,1,5,3,2,7,2,2,2,2,2,2,2,7,1,10,10,10,10,10,
  10,1,1,1,10,10,5,5,10,10,10,7,2,1,2,11
};


static const unsigned short ag_pstt[] = {
2,2,2,94,94,1,2,2,0,0,3,2,2,
4,4,4,1,5,4,
8,8,8,3,9,6,7,2,8,8,9,8,8,
10,3,12,12,11,
7,7,7,8,
13,5,14,
9,9,9,9,9,9,9,6,15,16,
71,71,71,71,71,71,71,71,71,71,71,71,71,71,71,71,71,71,71,71,71,71,71,71,71,
  71,71,71,71,71,71,71,71,7,17,
2,2,2,6,7,4,2,2,2,
96,18,9,19,98,
9,9,9,9,9,9,9,10,20,
178,178,178,178,178,178,178,178,178,181,181,181,178,24,178,21,178,22,178,
  178,178,178,178,178,178,178,10,178,178,178,178,178,178,182,23,6,178,7,
  178,178,11,27,179,27,27,27,27,23,27,11,28,27,27,26,25,
8,8,8,6,7,29,12,8,8,29,8,8,
4,4,4,30,13,30,4,30,31,
4,4,4,100,14,32,4,33,33,
10,10,10,10,10,10,10,10,10,10,10,82,
4,4,4,35,16,34,4,35,
72,72,72,72,72,72,72,72,72,72,72,72,72,72,72,72,72,72,72,72,72,72,72,72,72,
  72,72,72,72,72,72,72,36,17,
4,4,4,18,37,4,
8,8,8,3,6,7,19,8,8,97,8,8,
10,10,10,10,10,10,170,170,170,10,10,170,10,10,10,170,20,38,
274,21,
272,22,
85,85,85,85,85,85,85,85,87,87,87,85,85,85,85,85,85,85,85,85,85,85,85,85,85,
  85,85,85,85,85,86,85,85,85,90,23,40,39,39,40,
9,9,9,9,9,9,9,24,41,
276,275,271,25,
273,270,26,
178,178,178,178,178,178,178,178,178,181,181,181,178,24,178,21,178,22,178,
  178,178,178,178,178,178,178,10,178,178,178,178,178,178,182,23,6,178,7,
  178,178,176,175,179,175,175,175,175,23,175,11,175,26,25,
42,28,168,
5,29,
43,30,
45,44,31,108,
48,47,47,47,46,101,49,47,
99,33,
50,50,50,50,50,50,50,50,50,50,50,50,50,50,50,50,50,50,50,50,50,50,50,50,50,
  50,50,50,50,50,77,34,80,
81,35,
70,36,
9,9,9,9,9,9,9,37,51,
4,4,4,53,53,38,52,4,53,
85,85,85,85,85,85,85,85,87,87,87,85,85,85,85,85,85,85,85,85,85,85,85,85,85,
  85,85,85,85,85,86,85,85,85,91,89,
83,40,83,
10,10,10,10,10,10,10,10,279,10,10,10,41,
9,9,9,9,9,9,9,42,54,
4,4,4,100,100,100,43,109,4,109,
55,55,55,55,55,55,55,55,55,44,56,55,
55,55,55,55,55,55,55,55,55,45,57,55,
4,4,4,30,46,30,4,30,58,
4,4,4,100,47,105,4,105,
4,4,4,30,48,30,4,30,59,
4,4,4,100,49,60,4,103,
61,61,61,61,61,61,61,61,61,61,61,61,61,61,61,61,61,61,61,61,61,61,61,61,61,
  61,61,61,61,61,61,61,75,50,61,78,
10,10,10,10,10,10,4,4,4,10,10,10,10,10,63,118,51,62,4,63,
9,9,9,9,9,9,9,101,64,171,
186,169,53,
10,10,10,10,10,10,4,4,4,10,10,10,10,10,65,54,65,4,65,
111,111,111,111,111,111,111,111,111,112,
107,56,
106,57,
148,58,
66,67,59,302,
68,68,68,46,101,68,
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,
  74,74,74,74,74,74,74,76,
69,70,116,116,62,71,119,
72,73,63,73,
10,10,10,10,10,10,4,4,4,10,10,10,10,10,30,64,30,4,30,74,
173,65,
75,75,75,75,66,76,
75,75,75,75,67,77,
4,4,4,100,68,104,4,104,
4,4,4,69,78,4,
4,4,4,70,79,4,
4,4,4,100,100,71,117,4,117,
85,85,85,81,80,84,82,83,86,6,7,72,85,85,85,85,85,85,86,85,85,85,85,85,85,
129,73,
87,88,74,172,
89,89,89,89,89,89,89,307,307,75,89,89,309,
301,76,
300,77,
90,91,78,92,
93,94,79,292,
4,4,4,80,95,4,
4,4,4,81,96,4,
4,4,4,82,97,4,
4,4,4,83,98,4,
9,9,9,9,9,9,9,84,99,
124,124,124,81,80,84,82,83,6,7,126,124,124,124,124,124,124,124,124,124,124,
  124,
100,86,
45,45,45,45,45,45,45,45,45,45,45,45,45,45,45,45,45,45,45,45,45,45,45,45,45,
  45,45,45,45,45,45,45,45,45,45,87,101,
40,40,40,40,40,40,40,40,40,40,40,40,40,40,40,40,40,40,40,40,40,40,40,40,40,
  40,40,40,40,40,40,40,40,40,40,88,102,
306,306,306,306,306,306,306,308,306,
103,103,103,103,103,103,103,103,103,103,103,103,103,103,103,103,103,103,103,
  103,104,90,103,104,
105,105,105,105,105,105,105,105,105,105,105,105,105,105,105,105,105,105,105,
  105,105,106,91,105,106,
4,4,4,92,107,4,
108,108,108,108,108,108,108,108,108,108,108,108,108,108,108,108,108,108,108,
  108,108,108,108,108,108,108,108,108,108,108,108,108,109,108,93,108,109,
110,110,110,110,110,110,110,110,110,110,110,110,110,110,110,110,110,110,110,
  110,110,110,110,110,110,110,110,110,110,110,110,110,110,111,94,110,111,
9,9,9,9,112,9,9,9,95,113,
9,9,9,9,9,9,9,96,114,
9,9,9,9,9,9,9,97,115,
9,9,9,9,9,9,9,98,116,
10,10,10,10,10,10,10,10,280,10,10,10,99,
4,4,4,100,100,128,4,128,
46,46,46,46,46,46,46,46,46,47,47,47,24,46,21,46,22,46,46,46,46,46,46,46,46,
  46,46,46,46,46,46,46,46,39,46,101,48,49,26,25,
41,41,41,41,41,41,41,41,41,42,42,42,24,41,21,41,22,41,41,41,41,41,41,41,41,
  41,41,41,41,41,41,41,41,41,38,102,43,44,26,25,
66,66,66,66,66,66,66,66,66,66,66,66,66,66,66,66,66,66,66,66,68,
69,104,
61,61,61,61,61,61,61,61,61,61,61,61,61,61,61,61,61,61,61,61,61,63,
64,106,
93,94,107,293,
56,56,56,56,56,56,56,56,56,56,56,56,56,56,56,56,56,56,56,56,56,56,56,56,56,
  56,56,56,56,56,56,56,56,58,
59,109,
51,51,51,51,51,51,51,51,51,51,51,51,51,51,51,51,51,51,51,51,51,51,51,51,51,
  51,51,51,51,51,51,51,51,53,
54,111,
4,4,4,112,117,4,
10,10,10,10,10,10,4,4,4,10,10,10,10,10,113,118,4,
10,10,10,10,10,10,4,4,4,10,10,10,10,10,114,119,4,
10,10,10,10,10,10,4,4,4,10,10,10,10,10,115,120,4,121,223,
10,10,10,10,10,10,4,4,4,10,10,10,10,10,116,122,4,
9,9,9,9,9,9,9,117,123,
69,70,124,125,118,127,126,128,
129,70,119,130,131,131,
9,9,9,9,9,9,9,120,132,
4,4,4,134,121,133,4,134,224,
136,137,137,122,137,137,137,135,135,135,
10,10,10,10,10,10,4,4,4,10,10,10,10,10,123,138,4,
139,139,139,139,139,139,139,139,139,139,139,139,84,24,139,21,139,22,139,139,
  139,139,139,139,139,139,139,139,139,139,139,139,139,139,140,139,124,139,
  139,139,139,140,139,139,26,25,
141,141,141,141,141,141,141,141,141,141,141,141,84,24,141,21,141,22,141,141,
  141,141,141,141,141,141,141,141,141,141,141,141,141,141,141,142,125,141,
  141,141,141,142,141,141,26,25,
4,4,4,286,126,143,4,289,289,
4,4,4,100,127,285,4,285,
283,128,
4,4,4,129,144,4,
4,4,4,100,130,310,4,310,
312,131,
10,10,10,10,10,10,4,4,4,10,10,10,10,10,132,145,4,
9,9,9,9,9,9,9,101,132,
222,134,
194,194,194,198,198,198,194,135,198,
146,146,146,146,4,4,4,146,146,146,146,146,136,146,4,146,
4,4,4,147,137,147,4,147,
69,70,124,125,138,148,148,148,
34,34,34,34,34,34,34,34,34,34,34,34,84,24,34,21,34,22,34,34,34,34,34,34,34,
  34,34,34,34,34,34,34,34,34,34,36,34,34,34,34,34,26,25,
37,140,
26,26,26,26,26,26,26,26,26,26,26,26,84,24,26,21,26,22,26,26,26,26,26,26,26,
  26,26,26,26,26,26,26,26,26,26,28,26,26,26,26,26,26,25,
29,142,
149,288,
90,91,144,150,
152,236,235,234,233,232,231,230,229,151,145,153,153,153,153,237,238,
9,9,9,9,9,154,155,9,9,146,156,157,157,158,157,
187,147,
4,4,4,159,148,159,4,159,
4,4,4,149,160,4,
4,4,4,100,150,161,4,313,
162,162,162,162,162,162,162,162,162,162,162,151,163,162,
4,4,4,152,164,4,
4,4,4,153,165,4,
4,4,4,171,166,168,154,167,4,166,170,169,171,
172,172,172,172,4,4,4,172,172,172,172,155,172,4,172,
10,10,10,10,10,10,10,10,10,10,10,199,
194,194,194,194,194,194,202,202,202,157,202,
4,4,4,173,100,173,158,173,4,173,
284,159,
9,9,9,9,9,9,9,160,174,
93,94,101,293,
14,14,14,14,14,14,14,14,14,14,14,15,
4,4,4,100,175,163,175,4,175,
176,164,
177,252,251,87,88,165,253,225,
221,166,
216,101,216,167,
178,178,178,178,4,4,4,178,178,178,168,178,4,178,
179,219,
4,4,4,218,215,4,
220,171,
9,9,9,9,9,155,9,9,172,156,157,157,158,157,
180,184,182,173,183,183,184,181,181,
10,10,10,10,10,10,10,10,10,10,10,294,
187,185,175,186,186,187,
9,9,9,9,9,9,9,176,188,
4,4,4,177,189,4,
9,9,9,9,9,9,9,178,190,
191,191,191,191,4,4,4,191,191,191,179,191,4,191,
192,192,192,192,4,4,4,192,192,192,192,180,192,4,192,
180,212,181,211,
193,193,193,193,4,4,4,193,193,193,193,182,193,4,193,
182,207,205,
208,184,
194,194,194,194,194,194,4,4,4,194,194,194,194,194,185,194,4,194,
185,249,247,
250,187,
10,10,10,10,10,10,4,4,4,10,10,100,195,10,10,10,188,195,4,195,
87,88,189,254,
10,10,10,10,10,10,10,10,10,10,10,213,
9,9,9,9,9,9,9,191,196,
9,9,9,9,9,155,9,9,192,156,157,157,197,157,
9,9,9,9,9,155,9,9,193,156,157,157,198,157,
162,162,162,162,162,162,162,162,162,162,162,194,199,162,
202,200,195,201,201,202,
10,10,10,10,10,10,10,10,10,10,10,214,
4,4,4,100,100,197,209,4,209,
4,4,4,100,100,198,203,4,203,
4,4,4,100,100,199,245,4,245,
203,203,203,203,4,4,4,203,203,203,200,203,4,203,
200,243,241,
244,202,
9,9,9,9,9,9,9,203,204,
10,10,10,10,10,10,4,4,4,10,10,100,100,10,10,10,204,239,4,239,
  0
};


static const unsigned short ag_sbt[] = {
     0,  13,  19,  32,  37,  41,  44,  54,  89,  98, 103, 112, 167, 179,
   188, 197, 209, 217, 251, 257, 269, 287, 289, 291, 331, 340, 344, 347,
   400, 403, 405, 407, 411, 419, 421, 454, 456, 458, 467, 476, 512, 515,
   528, 537, 547, 559, 571, 580, 588, 597, 605, 641, 661, 671, 674, 693,
   703, 705, 707, 709, 713, 719, 752, 759, 763, 783, 785, 791, 797, 805,
   811, 817, 826, 851, 853, 857, 870, 872, 874, 878, 882, 888, 894, 900,
   906, 915, 937, 939, 976,1013,1022,1046,1071,1077,1114,1151,1161,1170,
  1179,1188,1201,1209,1249,1289,1310,1312,1334,1336,1340,1374,1376,1410,
  1412,1418,1435,1452,1471,1488,1497,1505,1511,1520,1529,1539,1556,1602,
  1648,1657,1665,1667,1673,1681,1683,1700,1709,1711,1720,1736,1744,1752,
  1795,1797,1840,1842,1844,1848,1865,1880,1882,1890,1896,1904,1918,1924,
  1930,1943,1958,1970,1981,1991,1993,2002,2006,2018,2027,2029,2037,2039,
  2043,2057,2059,2065,2067,2081,2090,2102,2108,2117,2123,2132,2146,2161,
  2165,2180,2183,2185,2203,2206,2208,2228,2232,2244,2253,2267,2281,2295,
  2301,2313,2322,2331,2340,2354,2357,2359,2368,2388
};


static const unsigned short ag_sbe[] = {
     8,  16,  26,  33,  40,  42,  51,  87,  94, 100, 110, 152, 173, 183,
   192, 208, 213, 250, 254, 263, 285, 288, 290, 326, 338, 343, 346, 387,
   401, 404, 406, 409, 416, 420, 452, 455, 457, 465, 472, 510, 513, 527,
   535, 543, 556, 568, 575, 584, 592, 601, 638, 657, 668, 673, 689, 702,
   704, 706, 708, 711, 717, 751, 756, 761, 778, 784, 789, 795, 801, 808,
   814, 822, 837, 852, 855, 866, 871, 873, 876, 880, 885, 891, 897, 903,
   913, 925, 938, 974,1011,1020,1043,1068,1074,1111,1148,1159,1168,1177,
  1186,1200,1205,1244,1284,1309,1311,1333,1335,1338,1373,1375,1409,1411,
  1415,1432,1449,1466,1485,1495,1501,1507,1518,1524,1532,1553,1592,1638,
  1652,1661,1666,1670,1677,1682,1697,1707,1710,1718,1732,1740,1748,1787,
  1796,1832,1841,1843,1846,1858,1874,1881,1886,1893,1900,1915,1921,1927,
  1936,1954,1969,1979,1987,1992,2000,2004,2017,2023,2028,2034,2038,2042,
  2053,2058,2062,2066,2075,2084,2101,2104,2115,2120,2130,2142,2157,2163,
  2176,2181,2184,2199,2204,2207,2224,2230,2243,2251,2261,2275,2292,2297,
  2312,2318,2327,2336,2350,2355,2358,2366,2384,2388
};


static const unsigned char ag_fl[] = {
  1,1,2,0,1,4,1,2,1,1,2,1,3,1,2,1,2,1,2,0,1,2,1,1,1,1,2,0,1,3,1,1,1,1,2,
  0,1,3,3,3,0,2,2,2,2,0,2,2,2,2,1,2,0,1,3,1,2,0,1,3,1,2,0,1,3,1,2,0,1,3,
  4,0,2,1,2,0,1,0,2,0,2,4,1,3,1,1,1,1,1,2,0,1,1,1,0,1,0,2,3,5,0,1,1,3,5,
  3,3,3,3,3,1,2,1,1,1,1,0,2,0,2,1,1,1,1,2,0,1,0,4,6,1,1,1,1,1,1,0,1,2,1,
  1,1,1,1,2,0,1,1,3,1,1,1,2,1,2,0,1,2,1,1,1,2,1,2,3,3,1,1,3,5,0,3,3,4,1,
  2,1,1,1,1,1,1,1,1,1,1,5,7,1,1,1,1,1,1,0,1,1,1,2,1,1,1,2,4,1,2,0,1,6,4,
  1,2,6,3,4,2,1,0,1,1,5,5,6,1,2,6,1,1,1,1,1,1,1,1,1,1,1,1,1,4,1,2,0,1,7,
  4,1,2,0,1,5,1,1,1,3,1,1,7,1,2,0,1,7,4,1,2,0,1,2,1,2,2,2,2,2,2,2,1,1,3,
  3,1,1,6,9,2,0,1,1,2,1,1,3,5,4,0,2,6,2,2,3,3,3,1,1,1,2,0,1,2,2,1,6,4
};

static const unsigned short ag_ptt[] = {
    0,  8,  8,  9,  9,  4, 13, 13, 11, 14, 14, 17, 17, 19, 19, 18, 21, 22,
   22, 23, 23, 20, 29, 29, 29, 30, 30, 31, 31, 24, 34, 34, 34, 35, 35, 36,
   36, 24, 37, 37, 38, 38, 38, 38, 38, 39, 39, 39, 39, 39, 46, 46, 47, 47,
   44, 49, 49, 50, 50, 44, 53, 53, 54, 54, 51, 56, 56, 57, 57, 51, 58, 60,
   60, 67, 67, 68, 68, 69, 69, 70, 70, 63, 65, 71, 72, 77, 77, 77, 78, 78,
   79, 79, 73, 74, 81, 81, 83, 83,  5, 80, 87, 87, 86, 86, 86, 86, 93, 93,
   85, 91, 96, 96, 92,  7,  7,  7, 99, 99,100,100,103,103,103,104,104,105,
  105,107,107, 82,102,102,102,102,102,102,114,114,112,117,117,117,117,118,
  118,119,119,115, 89, 89, 89, 89,129,130,130,131,131,125,126,126,126,132,
  138,138,133,134,128,  6,  6,141,145,145,146,143,149,149,142,148,148,148,
  148,148,148,148,148,148,140,108,153,153,153,153,160,160,164,164,164,164,
  157,166,166,166,165,169,170,170,171,171,158,174,175,175,159,177,177,178,
  178,179,179,179,156,156,109,182,182,183,184,184,184,186,187,187,187,187,
  187,187,187,188,188,200,201,201,202,202,197,203,204,204,205,205,198,185,
  185,185,185,116,116,209,215,215,216,216,210,218,219,219,220,220,214,217,
   41, 41,221,221,223,223,223, 28, 28, 42, 27,110,110,230,231,233,236,236,
  236,233,234,234, 98, 98,235,240,240,113,241,242,245,245, 88,247,247,248,
  248,249,249,244,252,252,111,251
};


static void ag_ra(PCB_DECL)
{
  switch(ag_rpx[(PCB).ag_ap]) {
    case 1: VNO AG_WRAP_5(ag_rp_1(PCB_POINTER, V(0,(int *)))); break;
    case 2: VRO(AG_WRAP_5 *, ag_rp_2(PCB_POINTER, VW(0, AG_WRAP_5 *), V(1,(int *)))); break;
    case 3: VWD(0,AG_WRAP_5 *); break;
    case 4: VWD(2,AG_WRAP_5 *); break;
    case 5: VNO AG_WRAP_5(ag_rp_3(PCB_POINTER, VW(1, AG_WRAP_5 *))); 
            VWD(1, AG_WRAP_5 *); break;
    case 6: VNO AG_WRAP_5(ag_rp_4(PCB_POINTER, VW(1, AG_WRAP_5 *))); 
            VWD(1, AG_WRAP_5 *); break;
    case 7: VNO AG_WRAP_5(ag_rp_5(PCB_POINTER)); break;
    case 8: VRO(AG_WRAP_5 *, ag_rp_6(PCB_POINTER, VW(0, AG_WRAP_5 *), V(1,(int *)))); break;
    case 9: VRO(AG_WRAP_5 *, ag_rp_7(PCB_POINTER, VW(0, AG_WRAP_5 *))); break;
    case 10: VRO(AG_WRAP_5 *, ag_rp_8(PCB_POINTER, VW(0, AG_WRAP_5 *), V(1,(int *)))); break;
    case 11: VRO(AG_WRAP_5 *, ag_rp_9(PCB_POINTER, VW(0, AG_WRAP_5 *))); break;
    case 12: VNO AG_WRAP_5(ag_rp_10(PCB_POINTER)); break;
    case 13: VRO(AG_WRAP_5 *, ag_rp_11(PCB_POINTER, VW(0, AG_WRAP_5 *), V(1,(int *)))); break;
    case 14: VRO(AG_WRAP_5 *, ag_rp_12(PCB_POINTER, VW(0, AG_WRAP_5 *))); break;
    case 15: VRO(AG_WRAP_5 *, ag_rp_13(PCB_POINTER, VW(0, AG_WRAP_5 *), V(1,(int *)))); break;
    case 16: VRO(AG_WRAP_5 *, ag_rp_14(PCB_POINTER, VW(0, AG_WRAP_5 *))); break;
    case 17: ag_rp_15(PCB_POINTER, VW(1, AG_WRAP_5 *)); 
            VWD(1, AG_WRAP_5 *); break;
    case 18: VNO AG_WRAP_5(ag_rp_16(PCB_POINTER)); break;
    case 19: VRO(AG_WRAP_5 *, ag_rp_17(PCB_POINTER, VW(0, AG_WRAP_5 *), V(1,(int *)))); break;
    case 20: ag_rp_18(PCB_POINTER, V(0,(int *))); break;
    case 21: ag_rp_19(PCB_POINTER); break;
    case 22: ag_rp_20(PCB_POINTER, V(0,(int *))); break;
    case 23: ag_rp_21(PCB_POINTER, VW(2, AG_WRAP_5 *)); 
            VWD(2, AG_WRAP_5 *); break;
    case 24: ag_rp_22(PCB_POINTER, VW(1, AG_WRAP_5 *), VW(2, AG_WRAP_6 *)); 
            VWD(1, AG_WRAP_5 *); VWD(2, AG_WRAP_6 *); break;
    case 25: VNO AG_WRAP_6(ag_rp_23(PCB_POINTER)); break;
    case 26: VRO(AG_WRAP_6 *, ag_rp_24(PCB_POINTER, VW(0, AG_WRAP_6 *), VW(2, AG_WRAP_4 *))); 
            VWD(2, AG_WRAP_4 *); break;
    case 27: VRO(AG_WRAP_5 *, ag_rp_25(PCB_POINTER, VW(0, AG_WRAP_5 *), VW(2, AG_WRAP_5 *))); 
            VWD(2, AG_WRAP_5 *); break;
    case 28: ag_rp_26(PCB_POINTER, VW(1, AG_WRAP_5 *)); 
            VWD(1, AG_WRAP_5 *); break;
    case 29: ag_rp_27(PCB_POINTER, V(0,(int *))); break;
    case 30: ag_rp_28(PCB_POINTER, V(0,(int *))); break;
    case 31: ag_rp_29(PCB_POINTER, V(0,(int *))); break;
    case 32: ag_rp_30(PCB_POINTER); break;
    case 33: ag_rp_31(PCB_POINTER, VW(1, AG_WRAP_5 *), VW(2, AG_WRAP_6 *)); 
            VWD(1, AG_WRAP_5 *); VWD(2, AG_WRAP_6 *); break;
    case 34: VWD(3,AG_WRAP_5 *); break;
    case 35: ag_rp_32(PCB_POINTER, VW(2, AG_WRAP_5 *), VW(3, AG_WRAP_8 *)); 
            VWD(2, AG_WRAP_5 *); VWD(3, AG_WRAP_8 *); break;
    case 36: VRO(AG_WRAP_7 *, ag_rp_33(PCB_POINTER, VW(0, AG_WRAP_7 *))); break;
    case 37: VRO(AG_WRAP_8 *, ag_rp_34(PCB_POINTER, VW(0, AG_WRAP_8 *), VW(1, AG_WRAP_7 *))); 
            VWD(1, AG_WRAP_7 *); break;
    case 38: VNO AG_WRAP_7(ag_rp_35(PCB_POINTER, VW(1, AG_WRAP_5 *), V(3,(Attribute::Type *)), VW(5, AG_WRAP_9 *))); 
            VWD(1, AG_WRAP_5 *); VWD(5, AG_WRAP_9 *); break;
    case 39: V(0,(Attribute::Type *)) = ag_rp_36(PCB_POINTER); break;
    case 40: V(0,(Attribute::Type *)) = ag_rp_37(PCB_POINTER); break;
    case 41: V(0,(Attribute::Type *)) = ag_rp_38(PCB_POINTER); break;
    case 42: V(0,(Attribute::Type *)) = ag_rp_39(PCB_POINTER); break;
    case 43: V(0,(Attribute::Type *)) = ag_rp_40(PCB_POINTER); break;
    case 44: V(0,(Attribute::Type *)) = ag_rp_41(PCB_POINTER); break;
    case 45: V(0,(Attribute::Type *)) = ag_rp_42(PCB_POINTER); break;
    case 46: V(0,(Attribute::Type *)) = ag_rp_43(PCB_POINTER); break;
    case 47: V(0,(Attribute::Type *)) = ag_rp_44(PCB_POINTER); break;
    case 48: V(0,(Attribute::Type *)) = ag_rp_45(PCB_POINTER); break;
    case 49: VNO AG_WRAP_9(ag_rp_46(PCB_POINTER)); break;
    case 50: VNO AG_WRAP_9(ag_rp_47(PCB_POINTER)); break;
    case 51: VRO(AG_WRAP_5 *, ag_rp_48(PCB_POINTER, VW(0, AG_WRAP_5 *))); break;
    case 52: VNO AG_WRAP_9(ag_rp_49(PCB_POINTER, VW(2, AG_WRAP_5 *))); 
            VWD(2, AG_WRAP_5 *); break;
    case 53: V(0,(int *)) = ag_rp_50(PCB_POINTER, V(1,(int *))); break;
    case 54: V(0,(int *)) = ag_rp_51(PCB_POINTER, V(0,(int *)), V(1,(int *))); break;
    case 55: V(0,(int *)) = ag_rp_52(PCB_POINTER, V(1,(int *))); break;
    case 56: V(0,(int *)) = ag_rp_53(PCB_POINTER, V(0,(int *)), V(1,(int *))); break;
    case 57: V(0,(int *)) = ag_rp_54(PCB_POINTER, V(0,(int *)), V(1,(int *))); break;
    case 58: V(0,(int *)) = ag_rp_55(PCB_POINTER, VW(1, AG_WRAP_5 *)); 
            VWD(1, AG_WRAP_5 *); break;
    case 59: VWD(1,AG_WRAP_5 *); break;
    case 60: VWD(4,AG_WRAP_5 *); break;
  }
}

#define TOKEN_NAMES parse_token_names
const char *const parse_token_names[265] = {
  "document",
  "\"--\"",
  "\"?>\"",
  "\"]]>\"",
  "document",
  "prolog",
  "element",
  "Misc",
  "",
  "",
  "eof",
  "S",
  "SpaceChar",
  "",
  "Name",
  "",
  "NameChar",
  "Names",
  "Nmtoken",
  "",
  "Nmtokens",
  "",
  "",
  "",
  "EntityValue",
  "'\\\"'",
  "",
  "PEReference",
  "Reference",
  "",
  "",
  "",
  "'\\''",
  "",
  "",
  "",
  "",
  "AttValue",
  "dq AttValString",
  "sq AttValString",
  "",
  "CharRef",
  "EntityRef",
  "",
  "SystemLiteral",
  "",
  "",
  "",
  "",
  "",
  "",
  "PubidLiteral",
  "PubidChar",
  "",
  "",
  "",
  "",
  "",
  "Comment",
  "\"<!--\"",
  "comment text",
  "'>'",
  "Char",
  "PI",
  "\"<?\"",
  "PITarget",
  "",
  "",
  "",
  "",
  "",
  "CDSect",
  "CDStart",
  "CData",
  "CDEnd",
  "\"<![CDATA[\"",
  "\"\\r\\n\"",
  "",
  "",
  "",
  "XMLDecl",
  "",
  "doctypedecl",
  "",
  "\"<?xml\"",
  "VersionInfo",
  "VersionDecl",
  "",
  "EncodingDecl",
  "SDDecl",
  "\"version\"",
  "Eq",
  "VersionNum",
  "",
  "'='",
  "",
  "",
  "\"<!DOCTYPE\"",
  "ExternalID",
  "",
  "",
  "'['",
  "markupdecl",
  "",
  "",
  "",
  "']'",
  "",
  "elementdecl",
  "AttlistDecl",
  "EntityDecl",
  "NotationDecl",
  "extSubset",
  "TextDecl",
  "",
  "extSubsetDecl",
  "conditionalSect",
  "",
  "",
  "",
  "\"standalone\"",
  "\"\\'yes\\'\"",
  "\"\\\"yes\\\"\"",
  "\"\\'no\\'\"",
  "\"\\\"no\\\"\"",
  "LanguageId",
  "Langcode",
  "'-'",
  "Subcode",
  "",
  "",
  "",
  "ISO639Code",
  "IanaCode",
  "UserCode",
  "",
  "",
  "",
  "",
  "",
  "EmptyElementTag",
  "STag",
  "content",
  "ETag",
  "'<'",
  "AttributeList",
  "Attribute",
  "\"</\"",
  "content unit",
  "",
  "",
  "\"/>\"",
  "\"<!ELEMENT\"",
  "contentspec",
  "\"EMPTY\"",
  "\"ANY\"",
  "Mixed",
  "Children",
  "choice",
  "seq",
  "",
  "'\\?'",
  "'*'",
  "'+'",
  "",
  "cp",
  "",
  "'('",
  "'|'",
  "",
  "",
  "",
  "')'",
  "','",
  "",
  "",
  "\"#PCDATA\"",
  "",
  "",
  "",
  "\")*\"",
  "\"<!ATTLIST\"",
  "AttDefs",
  "AttDef",
  "AttType",
  "DefaultDecl",
  "StringType",
  "TokenizedType",
  "EnumeratedType",
  "\"CDATA\"",
  "\"ID\"",
  "\"IDREF\"",
  "\"IDREFS\"",
  "\"ENTITY\"",
  "\"ENTITIES\"",
  "\"NMTOKEN\"",
  "\"NMTOKENS\"",
  "NotationType",
  "Enumeration",
  "\"NOTATION\"",
  "",
  "",
  "",
  "",
  "",
  "",
  "\"#REQUIRED\"",
  "\"#IMPLIED\"",
  "\"#FIXED\"",
  "includeSect",
  "ignoreSect",
  "\"<![\"",
  "\"INCLUDE\"",
  "\"IGNORE\"",
  "ignoreSectContents",
  "",
  "",
  "Ignore",
  "",
  "",
  "",
  "decimal CharRef",
  "';'",
  "hex CharRef",
  "\"&#\"",
  "",
  "\"&#x\"",
  "",
  "'&'",
  "'%'",
  "GEDecl",
  "PEDecl",
  "\"<!ENTITY\"",
  "EntityDef",
  "PEDef",
  "NDataDecl",
  "",
  "\"SYSTEM\"",
  "\"PUBLIC\"",
  "\"NDATA\"",
  "",
  "extParsedEnt",
  "extPE",
  "\"encoding\"",
  "EncName",
  "",
  "",
  "",
  "",
  "",
  "\"<!NOTATION\"",
  "PublicID",
  "",
  "",
  "",
  "",
  "",
  "",
  "",
  "",
  "",
  "",
  "",
  "",
  "",

};

#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(PCB_DECL) {
  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((*(PCB).lab)) && (*(PCB).lab) != '\\') {
    char buf[20];
    sprintf(buf, "\'%c\'", (char) (*(PCB).lab));
    sprintf((PCB).ag_msg, UNEXPECTED_FORMAT, buf);
  }
  else sprintf((PCB).ag_msg, UNEXPECTED_FORMAT, UNNAMED_TOKEN);
  (PCB).error_message = (PCB).ag_msg;


}
static int ag_action_1_r_proc(PCB_DECL);
static int ag_action_2_r_proc(PCB_DECL);
static int ag_action_3_r_proc(PCB_DECL);
static int ag_action_4_r_proc(PCB_DECL);
static int ag_action_1_s_proc(PCB_DECL);
static int ag_action_3_s_proc(PCB_DECL);
static int ag_action_1_proc(PCB_DECL);
static int ag_action_2_proc(PCB_DECL);
static int ag_action_3_proc(PCB_DECL);
static int ag_action_4_proc(PCB_DECL);
static int ag_action_5_proc(PCB_DECL);
static int ag_action_6_proc(PCB_DECL);
static int ag_action_7_proc(PCB_DECL);
static int ag_action_8_proc(PCB_DECL);
static int ag_action_9_proc(PCB_DECL);
static int ag_action_10_proc(PCB_DECL);
static int ag_action_11_proc(PCB_DECL);
static int ag_action_8_proc(PCB_DECL);


static int (*const  ag_r_procs_scan[])(PCB_DECL) = {
  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[])(PCB_DECL) = {
  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[])(PCB_DECL) = {
  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_action_10_proc(PCB_DECL) {
  (PCB).btsx = 0, (PCB).drt = -1;
  ag_track(PCB_POINTER);
  return 0;
}

static int ag_action_11_proc(PCB_DECL) {
  (PCB).btsx = 0, (PCB).drt = -1;
  (*(int *) &(PCB).vs[(PCB).ssx]) = *(PCB).lab;
  (PCB).ssx--;
  ag_ra(PCB_POINTER);
  (PCB).ssx++;
  ag_track(PCB_POINTER);
  return 0;
}

static int ag_action_3_r_proc(PCB_DECL) {
  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 = (parse_token_type) ag_ptt[(PCB).ag_ap];
  ag_ra(PCB_POINTER);
  return (PCB).exit_flag == AG_RUNNING_CODE;
}

static int ag_action_3_s_proc(PCB_DECL) {
  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 = (parse_token_type) ag_ptt[(PCB).ag_ap];
  ag_ra(PCB_POINTER);
  return (PCB).exit_flag == AG_RUNNING_CODE;
}

static int ag_action_4_r_proc(PCB_DECL) {
  int ag_sd = ag_fl[(PCB).ag_ap] - 1;
  if (ag_sd) (PCB).sn = (PCB).ss[(PCB).ssx -= ag_sd];
  (PCB).reduction_token = (parse_token_type) ag_ptt[(PCB).ag_ap];
  return 1;
}

static int ag_action_2_proc(PCB_DECL) {
  (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).lab;
  GET_CONTEXT;
  (PCB).ss[(PCB).ssx] = (PCB).sn;
  (PCB).ssx++;
  (PCB).sn = (PCB).ag_ap;
  ag_track(PCB_POINTER);
  return 0;
}

static int ag_action_9_proc(PCB_DECL) {
  if ((PCB).drt == -1) {
    (PCB).drt=(PCB).token_number;
    (PCB).dssx=(PCB).ssx;
    (PCB).dsn=(PCB).sn;
  }
  ag_prot(PCB_POINTER);
  GET_CONTEXT;
  (PCB).ss[(PCB).ssx] = (PCB).sn;
  (PCB).ssx++;
  (PCB).sn = (PCB).ag_ap;
  (PCB).rx = 0;
  return (PCB).exit_flag == AG_RUNNING_CODE;
}

static int ag_action_2_r_proc(PCB_DECL) {
  (PCB).ssx++;
  (PCB).sn = (PCB).ag_ap;
  return 0;
}

static int ag_action_7_proc(PCB_DECL) {
  --(PCB).ssx;
  (PCB).exit_flag = AG_SUCCESS_CODE;
  (PCB).rx = 0;
  return 0;
}

static int ag_action_1_proc(PCB_DECL) {
  (PCB).exit_flag = AG_SUCCESS_CODE;
  ag_track(PCB_POINTER);
  return 0;
}

static int ag_action_1_r_proc(PCB_DECL) {
  (PCB).exit_flag = AG_SUCCESS_CODE;
  return 0;
}

static int ag_action_1_s_proc(PCB_DECL) {
  (PCB).exit_flag = AG_SUCCESS_CODE;
  return 0;
}

static int ag_action_4_proc(PCB_DECL) {
  int ag_sd = ag_fl[(PCB).ag_ap] - 1;
  (PCB).reduction_token = (parse_token_type) ag_ptt[(PCB).ag_ap];
  (PCB).btsx = 0, (PCB).drt = -1;
  (*(int *) &(PCB).vs[(PCB).ssx]) = *(PCB).lab;
  if (ag_sd) (PCB).sn = (PCB).ss[(PCB).ssx -= ag_sd];
  else GET_CONTEXT;
  (PCB).ss[(PCB).ssx] = (PCB).sn;
  ag_track(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 short)(PCB).reduction_token) ag_t1 = ag_tx + 1;
      else ag_t2 = ag_tx;
    } while (ag_t1 < ag_t2);
    (PCB).ag_ap = ag_pstt[ag_t1];
    if ((ag_s_procs_scan[ag_astt[ag_t1]])(PCB_POINTER) == 0) break;
  }
  return 0;
}

static int ag_action_3_proc(PCB_DECL) {
  int ag_sd = ag_fl[(PCB).ag_ap] - 1;
  (PCB).btsx = 0, (PCB).drt = -1;
  (*(int *) &(PCB).vs[(PCB).ssx]) = *(PCB).lab;
  if (ag_sd) (PCB).sn = (PCB).ss[(PCB).ssx -= ag_sd];
  else GET_CONTEXT;
  (PCB).ss[(PCB).ssx] = (PCB).sn;
  ag_track(PCB_POINTER);
  (PCB).reduction_token = (parse_token_type) ag_ptt[(PCB).ag_ap];
  ag_ra(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 short)(PCB).reduction_token) ag_t1 = ag_tx + 1;
      else ag_t2 = ag_tx;
    } while (ag_t1 < ag_t2);
    (PCB).ag_ap = ag_pstt[ag_t1];
    if ((ag_s_procs_scan[ag_astt[ag_t1]])(PCB_POINTER) == 0) break;
  }
  return 0;
}

static int ag_action_8_proc(PCB_DECL) {
  ag_undo(PCB_POINTER);
  (PCB).rx = 0;
  (PCB).exit_flag = AG_SYNTAX_ERROR_CODE;
  ag_diagnose(PCB_POINTER);
  SYNTAX_ERROR;
  {(PCB).rx = 1; ag_track(PCB_POINTER);}
  return (PCB).exit_flag == AG_RUNNING_CODE;
}

static int ag_action_5_proc(PCB_DECL) {
  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).rx = 0;
  (PCB).reduction_token = (parse_token_type) ag_ptt[(PCB).ag_ap];
  ag_ra(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 short)(PCB).reduction_token) ag_t1 = ag_tx + 1;
      else ag_t2 = ag_tx;
    } while (ag_t1 < ag_t2);
    (PCB).ag_ap = ag_pstt[ag_t1];
    if ((ag_r_procs_scan[ag_astt[ag_t1]])(PCB_POINTER) == 0) break;
  }
  return (PCB).exit_flag == AG_RUNNING_CODE;
}

static int ag_action_6_proc(PCB_DECL) {
  int ag_sd = ag_fl[(PCB).ag_ap];
  (PCB).reduction_token = (parse_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_POINTER);
    (PCB).vs[(PCB).ssx] = ag_null_value;
    GET_CONTEXT;
    (PCB).ss[(PCB).ssx] = (PCB).sn;
  }
  (PCB).rx = 0;
  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 short)(PCB).reduction_token) ag_t1 = ag_tx + 1;
      else ag_t2 = ag_tx;
    } while (ag_t1 < ag_t2);
    (PCB).ag_ap = ag_pstt[ag_t1];
    if ((ag_r_procs_scan[ag_astt[ag_t1]])(PCB_POINTER) == 0) break;
  }
  return (PCB).exit_flag == AG_RUNNING_CODE;
}


void init_parse(parse_pcb_type *PCB_POINTER) {
  unsigned ag_t1;
  ag_t1 = 0;
  (PCB).rx = (PCB).fx = 0;
  (PCB).ss[0] = (PCB).sn = (PCB).ssx = 0;
  (PCB).exit_flag = AG_RUNNING_CODE;
  (PCB).key_sp = NULL;
  (PCB).key_state = 0;
  (PCB).line = FIRST_LINE;
  (PCB).column = FIRST_COLUMN;
  (PCB).btsx = 0, (PCB).drt = -1;
  while (ag_tstt[ag_t1] == 0) {
    (PCB).ag_ap = ag_pstt[ag_t1];
    (ag_gt_procs_scan[ag_astt[ag_t1]])((PCB_TYPE *)PCB_POINTER);
    ag_t1 = ag_sbt[(PCB).sn];
  }
}

void parse(parse_pcb_type *PCB_POINTER) {
  (PCB).lab[(PCB).fx++] = (PCB).input_code;
  while ((PCB).exit_flag == AG_RUNNING_CODE) {
    while (1) {
      const  unsigned char *ag_p;
      int ag_ch;
      if ((PCB).rx >= (PCB).fx) return;
      ag_ch = CONVERT_CASE((PCB).lab[(PCB).rx++]);
      if ((PCB).key_sp) {
        if (ag_ch != *(PCB).key_sp++) {
          (PCB).rx = (PCB).save_index;
          (PCB).key_sp = NULL;
          (PCB).key_state = 0;
          break;
        } else if (*(PCB).key_sp) continue;
        if (ag_key_act[(PCB).key_state] == ag_cf_end_key) {
          int ag_k1;
          int ag_k2;
          if ((PCB).rx >= (PCB).fx) {
            (PCB).rx--;
            (PCB).key_sp--;
            return;
          }
          (PCB).key_sp = NULL;
          ag_k1 = ag_key_parm[(PCB).key_state];
          ag_k2 = ag_key_pt[ag_k1];
          if (ag_key_itt[ag_k2 + CONVERT_CASE((PCB).lab[(PCB).rx])])
            (PCB).rx = (PCB).save_index;
          else {
            (PCB).token_number =  (parse_token_type) ag_key_pt[ag_k1+1];
            (PCB).key_state = 0;
          }
          break;
        }
        else {
          (PCB).token_number = (parse_token_type) ag_key_parm[(PCB).key_state];
          (PCB).key_state = 0;
          (PCB).key_sp = NULL;
        }
        break;
      }
      if ((PCB).key_state == 0) {
        (PCB).token_number = (parse_token_type) AG_TCV(ag_ch);
        if (((PCB).key_state = ag_key_index[(PCB).sn]) == 0) break;
        (PCB).save_index = 1;
      }
      ag_p = &ag_key_ch[(PCB).key_state];
      if (ag_ch <= 255) while (*ag_p < ag_ch) ag_p++;
      if (*ag_p == ag_ch) {
        (PCB).key_state = (int)(ag_p - ag_key_ch);
        switch (ag_key_act[(PCB).key_state]) {
        case ag_cf_set_key: {
          int ag_k1;
          int ag_k2;
          if ((PCB).rx >= (PCB).fx) {
            (PCB).rx--;
            return;
          }
          ag_k1 = ag_key_parm[(PCB).key_state];
          ag_k2 = ag_key_pt[ag_k1];
          (PCB).key_state = ag_key_jmp[(PCB).key_state];
          if (ag_key_itt[ag_k2 + CONVERT_CASE((PCB).lab[(PCB).rx])]) continue;
          (PCB).save_index = (PCB).rx;
          (PCB).token_number = (parse_token_type) ag_key_pt[ag_k1+1];
          continue;
        }
        case ag_set_key:
          (PCB).save_index = (PCB).rx;
          (PCB).token_number = (parse_token_type) ag_key_parm[(PCB).key_state];
        case ag_jmp_key:
          (PCB).key_state = ag_key_jmp[(PCB).key_state];
          continue;
        case ag_cf_end_key:
        case ag_end_key:
          (PCB).key_sp = ag_key_ends + ag_key_jmp[(PCB).key_state];
          continue;
        case ag_accept_key:
          (PCB).token_number = (parse_token_type) ag_key_parm[(PCB).key_state];
          (PCB).key_state = 0;
          break;
        case ag_cf_accept_key: {
          int ag_k1;
          int ag_k2;
          if ((PCB).rx >= (PCB).fx) {
            (PCB).rx--;
            return;
          }
          ag_k1 = ag_key_parm[(PCB).key_state];
          ag_k2 = ag_key_pt[ag_k1];
          if (ag_key_itt[ag_k2 + CONVERT_CASE((PCB).lab[(PCB).rx])])
            (PCB).rx = (PCB).save_index;
          else {
            (PCB).token_number = (parse_token_type) ag_key_pt[ag_k1+1];
            (PCB).key_state = 0;
          }
          break;
        }
        }
        break;
      } else {
        (PCB).rx = (PCB).save_index;
        (PCB).key_state = 0;
        break;
      }
    }

    {
      unsigned ag_t1 = ag_sbt[(PCB).sn];
      unsigned ag_t2 = ag_sbe[(PCB).sn] - 1;
      do {
        unsigned ag_tx = (ag_t1 + ag_t2)/2;
        if (ag_tstt[ag_tx] > (unsigned short)(PCB).token_number)
          ag_t1 = ag_tx + 1;
        else ag_t2 = ag_tx;
      } while (ag_t1 < ag_t2);
      if (ag_tstt[ag_t1] != (PCB).token_number)  ag_t1 = ag_sbe[(PCB).sn];
      (PCB).ag_ap = ag_pstt[ag_t1];
      (ag_gt_procs_scan[ag_astt[ag_t1]])((PCB_TYPE *)PCB_POINTER);
    }
  }
}