]> git.saurik.com Git - bison.git/blobdiff - src/scan-gram.c
* tests/regression.at (Invalid inputs): Adjust to the recent
[bison.git] / src / scan-gram.c
index a107a68aaa76b20c875d66f41e176cf57075719b..7999cd2d280db8c43be82624e43b399c22d62762 100644 (file)
@@ -15,7 +15,7 @@
 #define yyrestart gram_restart
 #define yytext gram_text
 
-#line 19 "lex.yy.c"
+#line 19 "scan-gram.c"
 /* A lexical scanner generated by flex */
 
 /* Scanner skeleton version:
@@ -309,69 +309,73 @@ static void yy_fatal_error YY_PROTO(( yyconst char msg[] ));
        *yy_cp = '\0'; \
        yy_c_buf_p = yy_cp;
 
-#define YY_NUM_RULES 101
-#define YY_END_OF_BUFFER 102
-static yyconst short int yy_accept[380] =
+#define YY_NUM_RULES 104
+#define YY_END_OF_BUFFER 105
+static yyconst short int yy_accept[411] =
     {   0,
-        0,    0,    0,    0,    0,    0,    0,    0,    0,    0,
-        0,    0,    0,    0,    0,    0,    0,    0,  102,   49,
-       38,   37,   37,   42,   49,   41,   39,   49,   40,   34,
-       36,   49,   33,   46,   35,   53,   54,   54,   55,   50,
-       51,   80,   83,   83,   79,   50,   82,   51,   75,   78,
-       78,   74,   77,   57,   58,   58,   56,   73,   60,   61,
-       61,   59,   93,   94,   94,   85,   95,   84,   88,   95,
-       50,   51,   90,   89,   97,   99,   99,   85,   98,   84,
-       88,  100,  100,  100,   85,   84,   88,   38,   37,   37,
-       37,   37,   48,    0,    0,    0,    0,    0,    0,    0,
-
-        0,    0,    0,    0,    0,    0,    0,    0,    0,   45,
-       39,   43,   44,   40,    0,   53,   54,   54,   54,   54,
-       52,   80,   83,   83,   83,   83,   81,   75,   78,   78,
-       78,   78,   76,   57,   58,   58,   58,   58,   72,   71,
-       72,   64,   65,   66,   67,   68,   69,   70,   72,   61,
-       61,   61,   61,   93,   94,   94,   94,   94,   91,    0,
-       91,    0,   86,   87,   92,    0,   92,   97,   99,   99,
-       99,   99,   96,  100,  100,  100,  100,  100,   86,   87,
-        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,   44,   47,    0,    0,    0,
-       87,   87,   87,    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,   62,   63,    0,    0,    0,    0,    0,
-        0,    0,    0,    0,    0,    0,   12,    0,    0,    0,
-        0,    0,    0,    0,   20,    0,    0,    0,    0,    0,
-       26,    0,   29,    0,    0,   32,    0,    2,    0,    0,
-        6,    0,    0,    0,    0,    0,    0,   14,    0,    0,
-        0,   18,    0,    0,    0,   23,    0,   25,   27,   30,
-
-        0,    1,    3,    0,    0,    8,    0,    0,    0,    0,
-        0,    0,    0,   19,    0,    0,    0,    0,    0,    4,
-        0,    0,    0,    0,    0,    0,    0,    0,    0,   21,
-        0,    0,    0,   31,    0,    0,    0,    0,    0,    0,
-        0,   16,   17,    0,   24,    0,    0,    0,    0,    0,
-        0,   13,    0,    0,    0,    5,    0,    0,    0,   11,
-        0,    0,    0,    0,    9,    0,   15,   22,   28,    0,
-        0,    7,    0,    0,    0,    0,    0,   10,    0
+        0,    0,    0,    0,   61,   61,    0,    0,   87,   87,
+       82,   82,    0,    0,    0,    0,    0,    0,    0,    0,
+        0,    0,  105,   53,   42,   42,   46,   53,   45,   40,
+       43,   53,   44,   38,   41,   53,   37,   50,   39,   53,
+       59,   59,   54,   55,   61,   60,   61,   57,   57,   85,
+       84,   88,   80,   79,   83,   63,   62,   78,   65,   64,
+       99,   90,   99,   99,   89,   93,   99,   99,   94,   96,
+      101,  102,   93,  103,   90,   89,   93,   42,   52,   35,
+       35,   35,   35,   35,   35,   35,   35,   35,   35,   35,
+       35,   35,   35,   35,   35,   35,   49,   43,   47,   48,
+
+       44,    0,    0,   59,   58,    0,   61,   61,   61,   61,
+       57,   56,   85,   86,   86,   86,   86,   80,   81,   81,
+       81,   81,   63,   77,   75,   66,   77,   68,   69,   70,
+       71,   72,   73,   77,   74,   77,   65,   99,   97,    0,
+       97,    0,   95,    0,   91,   92,    0,   94,   99,    0,
+       98,    0,   98,  101,  100,  103,   91,   92,  103,   35,
+       35,   35,   35,   35,   35,   35,   35,   35,   35,   35,
+       35,   35,   35,   35,   35,   35,   35,   35,   35,   35,
+       35,   35,   35,   35,   35,   35,   48,   51,    0,    0,
+        0,    0,   87,    0,    0,    0,    0,   82,    0,    0,
+
+        0,   66,    0,    0,   67,    0,    0,    0,    0,    0,
+        0,    0,  103,  103,   35,   35,   35,   35,   35,   35,
+       35,   35,   35,   35,   35,   35,   35,   35,   35,   35,
+       35,   35,   35,   35,   35,   35,   35,   35,   35,   35,
+       35,   35,   35,   35,   35,   35,    0,   66,    0,    0,
+        0,   35,   35,   35,   35,   35,   35,   35,   35,   35,
+       35,   12,   35,   35,   35,   35,   35,   35,   35,   35,
+       35,   21,   35,   35,   35,   35,   35,   28,   35,   31,
+       35,   35,   34,    0,    0,    0,   35,    2,   35,   35,
+        6,   35,   35,   35,   35,   35,   35,   35,   14,   35,
+
+       35,   35,   18,   35,   35,   35,   35,   24,   35,   27,
+       29,   32,   35,    0,    0,   76,    1,    3,   35,   35,
+        8,   35,   35,   35,   35,   35,   35,   35,   35,   19,
+       35,   35,   35,   35,   35,   35,    0,    4,   35,   35,
+       35,   35,   35,   35,   35,   35,   35,   35,   35,   22,
+       35,   35,   35,   33,    0,   35,   35,   35,   35,   35,
+       35,   35,   35,   16,   17,   35,   35,   26,   35,    0,
+       35,   35,   35,   35,   35,   25,   13,   35,   35,   35,
+       35,    0,    0,    5,   35,   35,   35,   11,   35,   35,
+       35,   35,   36,   35,    9,   35,   15,   20,   23,   30,
+
+       35,   35,    7,   35,   35,   35,   35,   35,   10,    0
     } ;
 
 static yyconst int yy_ec[256] =
     {   0,
         1,    1,    1,    1,    1,    1,    1,    1,    2,    3,
-        1,    2,    4,    1,    1,    1,    1,    1,    1,    1,
+        2,    2,    1,    1,    1,    1,    1,    1,    1,    1,
         1,    1,    1,    1,    1,    1,    1,    1,    1,    1,
-        1,    2,    1,    5,    1,    6,    7,    1,    8,    1,
-        1,    9,    1,    1,   10,   11,   12,   13,   13,   13,
-       13,   13,   13,   13,   13,   14,   14,   15,   16,   17,
-       18,   19,    1,   20,   21,   21,   21,   21,   21,   21,
-       11,   11,   11,   11,   11,   11,   11,   11,   11,   11,
-       11,   11,   11,   11,   11,   11,   11,   11,   11,   11,
-       22,   23,   24,    1,   25,    1,   26,   27,   28,   29,
-
-       30,   31,   32,   33,   34,   11,   35,   36,   37,   38,
-       39,   40,   11,   41,   42,   43,   44,   45,   11,   46,
-       47,   11,   48,   49,   50,    1,    1,    1,    1,    1,
+        1,    4,    1,    5,    6,    7,    8,    1,    9,    1,
+        1,   10,    1,   11,   12,   13,   14,   15,   15,   15,
+       15,   15,   15,   15,   15,   16,   16,   17,   18,   19,
+       20,   21,   22,   23,   24,   24,   24,   24,   24,   24,
+       13,   13,   13,   13,   13,   13,   13,   13,   13,   13,
+       13,   13,   13,   13,   25,   13,   13,   13,   13,   13,
+       26,   27,   28,    1,   29,    1,   30,   31,   32,   33,
+
+       34,   35,   36,   37,   38,   13,   39,   40,   41,   42,
+       43,   44,   13,   45,   46,   47,   48,   49,   13,   50,
+       51,   13,   52,   53,   54,    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,
@@ -388,313 +392,338 @@ static yyconst int yy_ec[256] =
         1,    1,    1,    1,    1
     } ;
 
-static yyconst int yy_meta[51] =
+static yyconst int yy_meta[56] =
     {   0,
-        1,    1,    2,    3,    4,    5,    6,    7,    8,    1,
-        9,   10,   11,   11,    1,    1,    1,    1,   12,    5,
-       11,   13,   14,   13,    9,   11,   11,   11,   11,   11,
-       11,    9,    9,    9,    9,    9,    9,    9,    9,    9,
-        9,    9,    9,    9,    9,    9,    9,    5,    1,    5
+        1,    1,    2,    1,    3,    1,    4,    5,    6,    7,
+        1,    8,    9,    5,   10,   10,    1,    1,    4,    1,
+       11,    1,    4,   10,    9,   12,   13,   12,    9,   10,
+       10,   10,   10,   10,   10,    9,    9,    9,    9,    9,
+        9,    9,    9,    9,    9,    9,    9,    9,    9,    9,
+        9,    4,    1,    4,   11
     } ;
 
-static yyconst short int yy_base[406] =
+static yyconst short int yy_base[449] =
     {   0,
-        0,    0,   48,   51,   58,   61,   83,   86,   73,   94,
-      108,  110,  131,  179,  227,  249,  116,  142,  839,  840,
-      836,   55,   64,  840,  267,  840,    0,   44,   79,  840,
-      840,    0,  840,  840,  840,    0,   97,   99,  825,  840,
-      840,    0,  119,  122,  840,  840,    0,  840,    0,  126,
-      138,  840,    0,    0,  145,  153,  840,  311,  840,  155,
-      157,  840,    0,  159,  164,  840,  159,  840,   62,  164,
-      840,  840,  840,  840,    0,  185,  189,  840,  786,  840,
-      185,  192,  201,  203,  205,  207,  209,  833,  211,  213,
-      216,  219,  840,  800,   39,   86,  799,  796,   65,  801,
-
-      198,  786,  184,  795,  109,  203,  790,  797,  800,  840,
-        0,  840,    0,  230,  806,    0,  242,  244,  255,  259,
-      840,    0,  261,  263,  265,  272,  840,    0,  274,  276,
-      278,  280,  840,    0,  282,  284,  286,  288,  840,  840,
-      811,  840,  840,  840,  840,  840,  840,  840,    0,  297,
-      314,  316,  318,    0,  322,  324,  326,  328,  840,  322,
-      326,    0,  840,    0,  840,  330,  332,    0,  344,  347,
-      355,  357,  840,  359,  361,  363,  365,  367,  369,  371,
-      785,  144,  781,  780,  780,  144,  778,  787,  789,  775,
-      778,  366,  784,  770,  168,  771,  779,  780,  783,  767,
-
-      772,  766,  771,  763,  775,    0,  840,  789,    0,  782,
-        0,  374,  377,  774,  755,  764,  754,  766,  756,  764,
-      763,  762,  230,  748,  764,  757,  758,  751,  760,  744,
-      744,  755,  744,  751,  747,  743,  737,  740,  746,  745,
-      735,  746,  744,  840,  840,  373,  730,  738,  731,  727,
-      739,  725,  737,  754,  734,  722,  840,  718,  730,  372,
-      725,  716,  720,  712,  840,  712,  375,  711,  723,  709,
-      840,  713,  840,  712,  710,  840,  701,  840,  717,  702,
-      840,  378,  702,  704,  380,  717,  708,  840,  701,  702,
-      697,  840,  695,  707,  696,  840,  692,  840,  382,  840,
-
-      692,  840,  691,  704,  686,  840,  689,  690,  687,  688,
-      659,  666,  633,  840,  628,  629,  613,  606,  618,  840,
-      603,  615,  614,  597,  596,  597,  603,  590,  603,  840,
-      589,  567,  578,  840,  564,  541,  547,  534,  523,  510,
-      520,  840,  840,  506,  840,  516,  497,  510,  499,  368,
-      365,  840,  368,  359,  348,  840,  316,  307,  297,  840,
-      287,  282,  283,  260,  840,  252,  840,  840,  840,  263,
-      384,  840,  241,  236,  224,  196,  158,  840,  840,  409,
-      423,  437,  451,  465,  479,  493,  507,  227,  521,  535,
-      549,  561,  575,  587,  601,  614,  628,  642,  656,  670,
-
-      104,  684,  698,  712,   77
+        0,  896,   46,   47,   55,   58,  891,  890,   61,   64,
+       50,   70,   66,   75,   85,   86,  109,  159,   96,  122,
+      129,  144,  899,  903,   60,  104,  903,  206,  903,  903,
+        0,   89,   52,  903,  903,    0,  903,  903,  903,  858,
+        0,  106,  903,  903,  870,  903,  138,    0,  882,    0,
+      903,  142,    0,  903,  172,    0,  903,  254,    0,  903,
+        0,  903,  174,   88,  903,  169,   92,  144,  903,  903,
+        0,  841,  170,    0,    0,    0,  178,  198,  903,    0,
+      856,   26,   76,  855,  852,  128,  857,  161,  842,  164,
+      851,  100,  164,  846,  853,  856,  903,    0,  903,    0,
+
+      201,  864,  846,    0,  903,  218,  856,  263,  268,  855,
+        0,  903,    0,  903,  221,  854,  224,    0,  903,  230,
+      853,  258,    0,  903,  903,  864,    0,  903,  903,  903,
+      903,  903,  903,    0,  903,    0,    0,    0,  903,  258,
+      262,    0,  903,  284,  903,  903,  289,  903,  903,  303,
+      903,  267,  282,    0,  903,    0,    0,    0,  306,    0,
+      836,  280,  832,  831,  831,  272,  829,  160,  841,  827,
+      830,  288,  836,  822,  823,   91,  822,  830,  831,  834,
+      818,  823,  817,  822,  814,  826,    0,  903,  815,  316,
+      300,  321,  829,  329,  332,  828,  335,  827,  338,  341,
+
+      826,  837,    0,    0,    0,  830,  344,  328,  348,  343,
+      356,  346,  359,  354,  820,  801,  810,  800,  812,  802,
+      810,  809,  808,  829,  793,  827,  808,  801,  802,  795,
+      804,  788,  788,  785,  798,  787,  794,  790,  786,  780,
+      783,  789,  788,  778,  789,  787,  784,  903,    0,    0,
+      359,  772,  780,  773,  769,  781,  767,  779,  798,  776,
+      764,    0,  763,  759,  771,  355,  766,  757,  761,  753,
+      766,    0,  752,  357,  751,  763,  749,    0,  753,    0,
+      752,  750,    0,  788,    0,    0,  740,    0,  756,  741,
+        0,  360,  741,  743,  364,  756,  755,  746,    0,  739,
+
+      740,  735,    0,  733,  767,  744,  733,    0,  729,    0,
+      365,    0,  729,  313,    0,  903,    0,  728,  741,  723,
+        0,  726,  727,  724,  723,  724,  721,  731,  721,    0,
+      719,  717,  731,  717,  712,  724,  375,    0,  710,  722,
+      721,  706,  707,  722,  709,  716,  703,  716,  717,    0,
+      701,  688,  691,    0,  703,  659,  644,  648,  635,  646,
+      635,  624,  634,    0,    0,  623,  621,    0,  627,  625,
+      581,  578,  564,  538,  528,    0,    0,  527,  525,  518,
+      507,  533,  526,    0,  349,  338,  339,    0,  335,  342,
+      337,  346,  903,  310,    0,  274,    0,    0,    0,    0,
+
+      282,  366,    0,  278,  256,  240,  241,  222,    0,  903,
+      395,  408,  421,  434,  447,  460,  473,  486,  499,  512,
+      517,  527,  540,  553,  566,  579,  590,  603,  614,  627,
+      639,  652,  664,  677,  690,  696,  706,  254,  219,  208,
+      719,  196,  193,  167,  144,  142,   55,  732
     } ;
 
-static yyconst short int yy_def[406] =
+static yyconst short int yy_def[449] =
     {   0,
-      379,    1,  380,  380,  381,  381,  382,  382,  383,  383,
-      384,  384,  385,  385,  386,  386,  387,  387,  379,  379,
-      379,  379,  379,  379,  379,  379,  388,  379,  379,  379,
-      379,  389,  379,  379,  379,  390,  379,  379,  379,  379,
-      379,  391,  379,  379,  379,  379,  392,  379,  393,  379,
-      379,  379,  394,  395,  379,  379,  379,  396,  379,  379,
-      379,  379,  397,  379,  379,  379,  379,  379,  379,  379,
-      379,  379,  379,  379,  398,  379,  379,  379,  379,  379,
-      379,  399,  399,  399,  399,  399,  399,  379,  379,  379,
-      379,  379,  379,  379,  379,  379,  379,  379,  379,  379,
-
-      379,  379,  379,  379,  379,  379,  379,  379,  379,  379,
-      388,  379,  400,  379,  389,  390,  379,  379,  379,  379,
-      379,  391,  379,  379,  379,  379,  379,  393,  379,  379,
-      379,  379,  379,  395,  379,  379,  379,  379,  379,  379,
-      379,  379,  379,  379,  379,  379,  379,  379,  401,  379,
-      379,  379,  379,  397,  379,  379,  379,  379,  379,  379,
-      379,  402,  379,  403,  379,  379,  379,  398,  379,  379,
-      379,  379,  379,  399,  399,  399,  399,  399,  399,  404,
-      379,  379,  379,  379,  379,  379,  379,  379,  379,  379,
-      379,  379,  379,  379,  379,  379,  379,  379,  379,  379,
-
-      379,  379,  379,  379,  379,  400,  379,  379,  405,  402,
-      403,  404,  404,  379,  379,  379,  379,  379,  379,  379,
-      379,  379,  379,  379,  379,  379,  379,  379,  379,  379,
-      379,  379,  379,  379,  379,  379,  379,  379,  379,  379,
-      379,  379,  379,  379,  379,  379,  379,  379,  379,  379,
-      379,  379,  379,  379,  379,  379,  379,  379,  379,  379,
-      379,  379,  379,  379,  379,  379,  379,  379,  379,  379,
-      379,  379,  379,  379,  379,  379,  379,  379,  379,  379,
-      379,  379,  379,  379,  379,  379,  379,  379,  379,  379,
-      379,  379,  379,  379,  379,  379,  379,  379,  379,  379,
-
-      379,  379,  379,  379,  379,  379,  379,  379,  379,  379,
-      379,  379,  379,  379,  379,  379,  379,  379,  379,  379,
-      379,  379,  379,  379,  379,  379,  379,  379,  379,  379,
-      379,  379,  379,  379,  379,  379,  379,  379,  379,  379,
-      379,  379,  379,  379,  379,  379,  379,  379,  379,  379,
-      379,  379,  379,  379,  379,  379,  379,  379,  379,  379,
-      379,  379,  379,  379,  379,  379,  379,  379,  379,  379,
-      379,  379,  379,  379,  379,  379,  379,  379,    0,  379,
-      379,  379,  379,  379,  379,  379,  379,  379,  379,  379,
-      379,  379,  379,  379,  379,  379,  379,  379,  379,  379,
-
-      379,  379,  379,  379,  379
+      410,    1,  411,  411,  412,  412,  413,  413,  414,  414,
+      415,  415,  416,  416,  417,  417,  418,  418,  419,  419,
+      420,  420,  410,  410,  410,  410,  410,  410,  410,  410,
+      421,  410,  410,  410,  410,  422,  410,  410,  410,  410,
+      423,  410,  410,  410,  424,  410,  424,  425,  410,  426,
+      410,  427,  428,  410,  429,  430,  410,  431,  432,  410,
+      433,  410,  410,  410,  410,  410,  410,  410,  410,  410,
+      434,  410,  410,  435,  435,  435,  435,  410,  410,  436,
+      436,  436,  436,  436,  436,  436,  436,  436,  436,  436,
+      436,  436,  436,  436,  436,  436,  410,  421,  410,  437,
+
+      410,  422,  410,  423,  410,  410,  424,  424,  424,  424,
+      425,  410,  426,  410,  410,  410,  410,  428,  410,  410,
+      410,  410,  430,  410,  410,  410,  438,  410,  410,  410,
+      410,  410,  410,  439,  410,  440,  432,  433,  410,  410,
+      410,  441,  410,  410,  410,  410,  410,  410,  410,  410,
+      410,  410,  410,  434,  410,  435,  435,  435,  435,  436,
+      436,  436,  436,  436,  436,  436,  436,  436,  436,  436,
+      436,  436,  436,  436,  436,  436,  436,  436,  436,  436,
+      436,  436,  436,  436,  436,  436,  437,  410,  410,  410,
+      410,  410,  410,  410,  410,  427,  410,  410,  410,  410,
+
+      429,  410,  442,  443,  440,  441,  410,  410,  410,  410,
+      410,  410,  435,  435,  436,  436,  436,  436,  436,  436,
+      436,  436,  436,  436,  436,  436,  436,  436,  436,  436,
+      436,  436,  436,  436,  436,  436,  436,  436,  436,  436,
+      436,  436,  436,  436,  436,  436,  410,  410,  444,  445,
+      410,  436,  436,  436,  436,  436,  436,  436,  436,  436,
+      436,  436,  436,  436,  436,  436,  436,  436,  436,  436,
+      436,  436,  436,  436,  436,  436,  436,  436,  436,  436,
+      436,  436,  436,  410,  446,  447,  436,  436,  436,  436,
+      436,  436,  436,  436,  436,  436,  436,  436,  436,  436,
+
+      436,  436,  436,  436,  436,  436,  436,  436,  436,  436,
+      436,  436,  436,  410,  439,  410,  436,  436,  436,  436,
+      436,  436,  436,  436,  436,  436,  436,  436,  436,  436,
+      436,  436,  436,  436,  436,  436,  410,  436,  436,  436,
+      436,  436,  436,  436,  436,  436,  436,  436,  436,  436,
+      436,  436,  436,  436,  410,  436,  436,  436,  436,  436,
+      436,  436,  436,  436,  436,  436,  436,  436,  436,  448,
+      436,  436,  436,  436,  436,  436,  436,  436,  436,  436,
+      436,  448,  410,  436,  436,  436,  436,  436,  436,  436,
+      436,  436,  410,  436,  436,  436,  436,  436,  436,  436,
+
+      436,  436,  436,  436,  436,  436,  436,  436,  436,    0,
+      410,  410,  410,  410,  410,  410,  410,  410,  410,  410,
+      410,  410,  410,  410,  410,  410,  410,  410,  410,  410,
+      410,  410,  410,  410,  410,  410,  410,  410,  410,  410,
+      410,  410,  410,  410,  410,  410,  410,  410
     } ;
 
-static yyconst short int yy_nxt[891] =
+static yyconst short int yy_nxt[959] =
     {   0,
-       20,   21,   22,   23,   24,   20,   25,   26,   20,   20,
-       27,   28,   29,   29,   30,   31,   32,   33,   20,   20,
-       27,   20,   20,   20,   20,   27,   27,   27,   27,   27,
-       27,   27,   27,   27,   27,   27,   27,   27,   27,   27,
-       27,   27,   27,   27,   27,   27,   27,   34,   35,   20,
-       37,   38,  112,   37,   38,  113,   39,   89,   90,   39,
-       43,   44,   45,   43,   44,   45,   91,   92,  182,   40,
-      163,   41,   40,  164,   41,   55,   56,   57,  183,   46,
-       47,   48,   46,   47,   48,   50,   51,  245,   50,   51,
-       52,  114,  114,   52,  188,   58,   55,   56,   57,  117,
-
-      118,  119,  120,  189,   46,   53,   48,   46,   53,   48,
-       60,   61,   60,   61,  209,   62,   58,   62,   83,   84,
-       85,  123,  124,   86,  125,  126,  184,   87,  129,  130,
-       58,  185,   58,   64,   65,   66,   67,   46,   68,   48,
-      131,  132,   69,  198,   83,   84,   85,  135,  136,   86,
-       70,  199,   71,   87,   72,  137,  138,  150,  151,  152,
-      153,  155,  156,   46,  159,   48,  157,  158,  160,  165,
-      215,  161,  161,  166,  216,  162,  167,  167,   73,  221,
-       74,   64,   65,   66,   67,  217,   68,  169,  170,  222,
-       69,  171,  172,  163,  175,  176,  164,  232,   70,  378,
-
-       71,  233,   72,  175,  177,  178,  176,  175,  176,  175,
-      176,  175,  176,   89,   90,   91,   92,  179,   89,   90,
-      180,   91,   92,  191,  195,  377,   73,  196,   74,   76,
-       77,   78,  200,   79,   80,  111,  192,  111,   81,  256,
-      193,  201,  114,  114,  117,  118,  119,  120,   46,  202,
-       48,   76,   77,   78,  256,   79,   80,  117,  118,  376,
-       81,  119,  120,  123,  124,  125,  126,  123,  124,  375,
-       46,  374,   48,   93,  125,  126,  129,  130,  131,  132,
-      129,  130,  131,  132,  135,  136,  137,  138,  135,  136,
-      137,  138,  372,   94,  371,   95,   96,   97,   98,  150,
-
-      151,  370,   99,  100,  101,  102,  103,  104,  105,  106,
-      107,  108,  369,  109,  110,  140,  152,  153,  150,  151,
-      152,  153,  368,  141,  155,  156,  157,  158,  155,  156,
-      157,  158,  367,  140,  161,  161,  142,  143,  161,  161,
-      366,  144,  167,  167,  167,  167,  169,  170,  145,  171,
-      172,  146,  365,  147,  364,  148,  149,  169,  170,  171,
-      172,  175,  176,  175,  177,  178,  176,  178,  176,  175,
-      177,  175,  176,  175,  213,  228,  175,  213,  159,  178,
-      213,  289,  160,  363,  295,  161,  161,  305,  362,  308,
-      228,  318,  211,  373,  211,  211,  289,  211,  211,  295,
-
-      211,  361,  305,  229,  308,  360,  318,  359,  373,   36,
-       36,   36,   36,   36,   36,   36,   36,   36,   36,   36,
-       36,   36,   36,   42,   42,   42,   42,   42,   42,   42,
-       42,   42,   42,   42,   42,   42,   42,   49,   49,   49,
-       49,   49,   49,   49,   49,   49,   49,   49,   49,   49,
-       49,   54,   54,   54,   54,   54,   54,   54,   54,   54,
-       54,   54,   54,   54,   54,   59,   59,   59,   59,   59,
-       59,   59,   59,   59,   59,   59,   59,   59,   59,   63,
-       63,   63,   63,   63,   63,   63,   63,   63,   63,   63,
-       63,   63,   63,   75,   75,   75,   75,   75,   75,   75,
-
-       75,   75,   75,   75,   75,   75,   75,   82,   82,   82,
-       82,   82,   82,   82,   82,   82,   82,   82,   82,   82,
-       82,  115,  115,  115,  115,  115,  115,  115,  115,  115,
-      115,  115,  358,  115,  115,  116,  357,  356,  116,  116,
-      116,  116,  355,  116,  116,  116,  116,  354,  116,  122,
-      353,  352,  351,  122,  122,  122,  122,  122,  122,  122,
-      122,  127,  127,  127,  127,  127,  127,  127,  127,  127,
-      127,  127,  127,  127,  127,  128,  350,  349,  128,  128,
-      128,  348,  128,  128,  128,  128,  128,  133,  133,  133,
-      133,  133,  133,  133,  133,  133,  133,  133,  133,  133,
-
-      133,  134,  347,  346,  345,  134,  134,  134,  134,  134,
-      134,  134,  134,  134,  139,  139,  139,  139,  139,  139,
-      139,  139,  139,  139,  139,  139,  139,  139,  154,  344,
-      343,  342,  341,  154,  340,  154,  154,  339,  154,  154,
-      338,  154,  168,  337,  336,  335,  168,  334,  333,  168,
-      168,  332,  168,  168,  331,  168,  174,  174,  174,  174,
-      174,  174,  174,  174,  174,  174,  174,  174,  330,  174,
-      206,  329,  206,  206,  206,  206,  206,  206,  206,  206,
-      206,  206,  206,  206,  210,  210,  210,  210,  210,  210,
-      210,  210,  210,  210,  210,  328,  210,  210,  211,  327,
-
-      211,  211,  211,  211,  211,  211,  211,  211,  211,  211,
-      211,  211,  212,  212,  212,  212,  212,  212,  212,  212,
-      212,  212,  212,  212,  212,  212,  326,  325,  324,  323,
-      322,  321,  320,  319,  317,  316,  315,  314,  313,  312,
-      311,  310,  309,  307,  306,  304,  303,  302,  301,  300,
-      299,  298,  297,  296,  294,  293,  292,  291,  290,  288,
-      287,  286,  285,  284,  283,  282,  281,  280,  279,  278,
-      277,  276,  275,  274,  273,  272,  271,  270,  269,  268,
-      267,  266,  265,  264,  263,  262,  261,  260,  259,  258,
-      257,  255,  254,  253,  252,  251,  250,  249,  248,  247,
-
-      246,  244,  243,  242,  241,  240,  239,  238,  237,  236,
-      235,  234,  231,  230,  227,  226,  225,  224,  223,  220,
-      219,  218,  214,  208,  207,  205,  204,  203,  197,  194,
-      190,  187,  186,  181,   88,  173,  121,   88,  379,   19,
-      379,  379,  379,  379,  379,  379,  379,  379,  379,  379,
-      379,  379,  379,  379,  379,  379,  379,  379,  379,  379,
-      379,  379,  379,  379,  379,  379,  379,  379,  379,  379,
-      379,  379,  379,  379,  379,  379,  379,  379,  379,  379,
-      379,  379,  379,  379,  379,  379,  379,  379,  379,  379
+       24,   25,   26,   25,   27,   24,   24,   28,   29,   24,
+       30,   24,   31,   32,   33,   33,   34,   35,   36,   37,
+       24,   24,   24,   31,   31,   24,   24,   24,   31,   31,
+       31,   31,   31,   31,   31,   31,   31,   31,   31,   31,
+       31,   31,   31,   31,   31,   31,   31,   31,   31,   31,
+       31,   38,   39,   24,   24,   42,   42,   46,   54,  162,
+       46,   78,   78,   78,  316,   51,  101,  101,   51,  163,
+       57,   43,   43,   44,   44,   43,   55,   44,   54,   57,
+       43,   47,   44,   43,   47,   44,   43,   52,   44,   43,
+       52,   44,   58,   60,   60,   43,   55,   44,   99,  148,
+
+       62,   58,  100,   72,   65,   78,   78,   78,  143,   73,
+      149,   58,   58,   62,  144,   63,   64,   65,  150,  105,
+      164,   43,   66,   44,  235,  165,   62,   67,  236,   72,
+       65,   68,  106,   75,   43,   73,   44,   76,  179,  109,
+      110,  109,   77,  115,  116,  115,  180,   43,   75,   44,
+      151,  315,   76,  286,   43,  152,   44,   77,  153,  153,
+       69,  168,   70,   62,  108,   63,   64,   65,  117,   43,
+      169,   44,   66,  120,  121,  120,  285,   67,  145,  145,
+      139,   68,  146,  146,   43,  140,   44,  157,  141,  141,
+      171,  158,  142,  175,  225,  147,  147,  181,  122,   78,
+
+       78,   78,  250,  172,  159,  249,  182,  173,  176,  226,
+       69,  177,   70,   79,  183,  101,  101,  205,   80,  190,
+      191,  190,  192,  193,  192,  195,  196,  195,  204,   80,
+       80,  197,  198,  197,   80,   80,   81,   80,   82,   83,
+       84,   85,   80,   80,   80,   86,   87,   88,   89,   90,
+       91,   92,   93,   94,   95,   80,   96,   97,  125,  200,
+      201,  200,  125,  203,  109,  110,  109,  409,  126,  109,
+      110,  109,  141,  141,  408,  125,  141,  141,  127,  407,
+      125,  153,  153,  128,  129,  207,  208,  207,  130,  108,
+      209,  210,  209,  406,  108,  131,  153,  153,  132,  230,
+
+      133,  134,  135,  136,  211,  212,  211,  213,  214,  213,
+      216,  222,  405,  105,  217,  403,  230,  190,  191,  190,
+      402,  223,  192,  193,  192,  218,  106,  337,  337,  231,
+      192,  193,  192,  195,  196,  195,  197,  198,  197,  197,
+      198,  197,  200,  201,  200,  207,  208,  207,  143,  209,
+      210,  209,  145,  148,  144,  401,  146,  211,  212,  211,
+      213,  214,  213,  157,  149,  139,  300,  158,  307,  147,
+      140,  320,  150,  141,  141,  323,  335,  404,  355,  400,
+      159,  399,  398,  300,  397,  307,  396,  395,  320,  337,
+      337,  394,  323,  335,  404,   41,   41,   41,   41,   41,
+
+       41,   41,   41,   41,   41,   41,   41,   41,   45,   45,
+       45,   45,   45,   45,   45,   45,   45,   45,   45,   45,
+       45,   48,   48,   48,   48,   48,   48,   48,   48,   48,
+       48,   48,   48,   48,   50,   50,   50,   50,   50,   50,
+       50,   50,   50,   50,   50,   50,   50,   53,   53,   53,
+       53,   53,   53,   53,   53,   53,   53,   53,   53,   53,
+       56,   56,   56,   56,   56,   56,   56,   56,   56,   56,
+       56,   56,   56,   59,   59,   59,   59,   59,   59,   59,
+       59,   59,   59,   59,   59,   59,   61,   61,   61,   61,
+       61,   61,   61,   61,   61,   61,   61,   61,   61,   71,
+
+       71,   71,   71,   71,   71,   71,   71,   71,   71,   71,
+       71,   71,   74,   74,   74,   74,   74,   74,   74,   74,
+       74,   74,   74,   74,   74,   98,   98,  102,  393,  102,
+      102,  102,  102,  102,  102,  102,  102,  383,  102,  102,
+      104,  104,  104,  104,  104,  104,  392,  104,  104,  104,
+      104,  391,  104,  107,  390,  107,  107,  107,  107,  107,
+      107,  107,  107,  107,  389,  107,  111,  111,  111,  111,
+      111,  111,  388,  111,  111,  111,  111,  111,  111,  113,
+      113,  387,  113,  113,  113,  113,  113,  113,  113,  113,
+      114,  114,  114,  114,  114,  114,  114,  114,  114,  114,
+
+      114,  386,  114,  118,  118,  118,  118,  118,  385,  118,
+      118,  118,  118,  118,  119,  119,  119,  119,  119,  119,
+      119,  119,  119,  119,  119,  384,  119,  123,  123,  383,
+      123,  123,  123,  123,  123,  123,  123,  123,  123,  124,
+      124,  124,  124,  124,  124,  124,  124,  124,  124,  124,
+      124,  124,  137,  137,  137,  137,  137,  381,  137,  137,
+      137,  137,  137,  137,  138,  138,  380,  379,  378,  377,
+      138,  138,  138,  138,  138,  376,  138,  154,  154,  375,
+      154,  374,  373,  154,  154,  154,  154,  154,  372,  154,
+      156,  156,  156,  156,  156,  156,  156,  156,  156,  156,
+
+      156,  371,  156,  160,  160,  160,  187,  370,  187,  187,
+      187,  187,  187,  187,  187,  187,  187,  187,  187,  206,
+      369,  206,  206,  206,  206,  206,  206,  206,  206,  368,
+      206,  206,  382,  382,  382,  382,  382,  382,  382,  382,
+      382,  382,  382,  382,  382,  367,  366,  365,  364,  363,
+      362,  361,  360,  359,  358,  357,  356,  354,  353,  352,
+      351,  350,  349,  348,  347,  346,  345,  344,  343,  342,
+      341,  340,  339,  338,  336,  334,  333,  332,  331,  330,
+      329,  328,  327,  326,  325,  324,  322,  321,  319,  318,
+      317,  314,  313,  312,  311,  310,  309,  308,  306,  305,
+
+      304,  303,  302,  301,  299,  298,  297,  296,  295,  294,
+      293,  292,  291,  290,  289,  288,  287,  284,  283,  282,
+      281,  280,  279,  278,  277,  276,  275,  274,  273,  272,
+      271,  270,  269,  268,  267,  266,  265,  264,  263,  262,
+      261,  260,  259,  258,  257,  256,  255,  254,  253,  252,
+      251,  248,  122,  199,  117,  194,  247,  246,  245,  244,
+      243,  242,  241,  240,  239,  238,  237,  234,  233,  232,
+      229,  228,  227,  224,  221,  220,  219,  215,  202,  199,
+      194,  108,  108,  189,  188,  186,  185,  184,  178,  174,
+      170,  167,  166,  161,  155,  112,  108,  103,  410,   49,
+
+       49,   40,   23,  410,  410,  410,  410,  410,  410,  410,
+      410,  410,  410,  410,  410,  410,  410,  410,  410,  410,
+      410,  410,  410,  410,  410,  410,  410,  410,  410,  410,
+      410,  410,  410,  410,  410,  410,  410,  410,  410,  410,
+      410,  410,  410,  410,  410,  410,  410,  410,  410,  410,
+      410,  410,  410,  410,  410,  410,  410,  410
     } ;
 
-static yyconst short int yy_chk[891] =
+static yyconst short int yy_chk[959] =
     {   0,
         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,    1,    1,    1,    1,    1,    1,
-        3,    3,   28,    4,    4,   28,    3,   22,   22,    4,
-        5,    5,    5,    6,    6,    6,   23,   23,   95,    3,
-       69,    3,    4,   69,    4,    9,    9,    9,   95,    5,
-        5,    5,    6,    6,    6,    7,    7,  405,    8,    8,
-        7,   29,   29,    8,   99,    9,   10,   10,   10,   37,
-
-       37,   38,   38,   99,    7,    7,    7,    8,    8,    8,
-       11,   11,   12,   12,  401,   11,   10,   12,   17,   17,
-       17,   43,   43,   17,   44,   44,   96,   17,   50,   50,
-       11,   96,   12,   13,   13,   13,   13,   17,   13,   17,
-       51,   51,   13,  105,   18,   18,   18,   55,   55,   18,
-       13,  105,   13,   18,   13,   56,   56,   60,   60,   61,
-       61,   64,   64,   18,   67,   18,   65,   65,   67,   70,
-      182,   67,   67,   70,  182,   67,   70,   70,   13,  186,
-       13,   14,   14,   14,   14,  182,   14,   76,   76,  186,
-       14,   77,   77,   81,   82,   82,   81,  195,   14,  377,
-
-       14,  195,   14,   83,   83,   84,   84,   85,   85,   86,
-       86,   87,   87,   89,   89,   90,   90,   87,   91,   91,
-       87,   92,   92,  101,  103,  376,   14,  103,   14,   15,
-       15,   15,  106,   15,   15,  388,  101,  388,   15,  223,
-      101,  106,  114,  114,  117,  117,  118,  118,   15,  106,
-       15,   16,   16,   16,  223,   16,   16,  119,  119,  375,
-       16,  120,  120,  123,  123,  124,  124,  125,  125,  374,
-       16,  373,   16,   25,  126,  126,  129,  129,  130,  130,
-      131,  131,  132,  132,  135,  135,  136,  136,  137,  137,
-      138,  138,  370,   25,  366,   25,   25,   25,   25,  150,
-
-      150,  364,   25,   25,   25,   25,   25,   25,   25,   25,
-       25,   25,  363,   25,   25,   58,  151,  151,  152,  152,
-      153,  153,  362,   58,  155,  155,  156,  156,  157,  157,
-      158,  158,  361,   58,  160,  160,   58,   58,  161,  161,
-      359,   58,  166,  166,  167,  167,  169,  169,   58,  170,
-      170,   58,  358,   58,  357,   58,   58,  171,  171,  172,
-      172,  174,  174,  175,  175,  176,  176,  177,  177,  178,
-      178,  179,  179,  180,  180,  192,  212,  212,  246,  213,
-      213,  260,  246,  355,  267,  246,  246,  282,  354,  285,
-      192,  299,  180,  371,  180,  212,  260,  212,  213,  267,
-
-      213,  353,  282,  192,  285,  351,  299,  350,  371,  380,
-      380,  380,  380,  380,  380,  380,  380,  380,  380,  380,
-      380,  380,  380,  381,  381,  381,  381,  381,  381,  381,
-      381,  381,  381,  381,  381,  381,  381,  382,  382,  382,
-      382,  382,  382,  382,  382,  382,  382,  382,  382,  382,
-      382,  383,  383,  383,  383,  383,  383,  383,  383,  383,
-      383,  383,  383,  383,  383,  384,  384,  384,  384,  384,
-      384,  384,  384,  384,  384,  384,  384,  384,  384,  385,
-      385,  385,  385,  385,  385,  385,  385,  385,  385,  385,
-      385,  385,  385,  386,  386,  386,  386,  386,  386,  386,
-
-      386,  386,  386,  386,  386,  386,  386,  387,  387,  387,
-      387,  387,  387,  387,  387,  387,  387,  387,  387,  387,
-      387,  389,  389,  389,  389,  389,  389,  389,  389,  389,
-      389,  389,  349,  389,  389,  390,  348,  347,  390,  390,
-      390,  390,  346,  390,  390,  390,  390,  344,  390,  391,
-      341,  340,  339,  391,  391,  391,  391,  391,  391,  391,
-      391,  392,  392,  392,  392,  392,  392,  392,  392,  392,
-      392,  392,  392,  392,  392,  393,  338,  337,  393,  393,
-      393,  336,  393,  393,  393,  393,  393,  394,  394,  394,
-      394,  394,  394,  394,  394,  394,  394,  394,  394,  394,
-
-      394,  395,  335,  333,  332,  395,  395,  395,  395,  395,
-      395,  395,  395,  395,  396,  396,  396,  396,  396,  396,
-      396,  396,  396,  396,  396,  396,  396,  396,  397,  331,
-      329,  328,  327,  397,  326,  397,  397,  325,  397,  397,
-      324,  397,  398,  323,  322,  321,  398,  319,  318,  398,
-      398,  317,  398,  398,  316,  398,  399,  399,  399,  399,
-      399,  399,  399,  399,  399,  399,  399,  399,  315,  399,
-      400,  313,  400,  400,  400,  400,  400,  400,  400,  400,
-      400,  400,  400,  400,  402,  402,  402,  402,  402,  402,
-      402,  402,  402,  402,  402,  312,  402,  402,  403,  311,
-
-      403,  403,  403,  403,  403,  403,  403,  403,  403,  403,
-      403,  403,  404,  404,  404,  404,  404,  404,  404,  404,
-      404,  404,  404,  404,  404,  404,  310,  309,  308,  307,
-      305,  304,  303,  301,  297,  295,  294,  293,  291,  290,
-      289,  287,  286,  284,  283,  280,  279,  277,  275,  274,
-      272,  270,  269,  268,  266,  264,  263,  262,  261,  259,
-      258,  256,  255,  254,  253,  252,  251,  250,  249,  248,
-      247,  243,  242,  241,  240,  239,  238,  237,  236,  235,
+        1,    1,    1,    1,    1,    3,    4,    5,   11,   82,
+        6,   25,   25,   25,  447,    9,   33,   33,   10,   82,
+       13,    3,    4,    3,    4,   11,   11,   11,   12,   14,
+        5,    5,    5,    6,    6,    6,    9,    9,    9,   10,
+       10,   10,   13,   15,   16,   12,   12,   12,   32,   67,
+
+       19,   14,   32,   19,   19,   26,   26,   26,   64,   19,
+       67,   15,   16,   17,   64,   17,   17,   17,   67,   42,
+       83,   19,   17,   19,  176,   83,   20,   17,  176,   20,
+       20,   17,   42,   21,   17,   20,   17,   21,   92,   47,
+       47,   47,   21,   52,   52,   52,   92,   20,   22,   20,
+       68,  446,   22,  445,   21,   68,   21,   22,   68,   68,
+       17,   86,   17,   18,   47,   18,   18,   18,   52,   22,
+       86,   22,   18,   55,   55,   55,  444,   18,   66,   73,
+       63,   18,   66,   73,   18,   63,   18,   77,   63,   63,
+       88,   77,   63,   90,  168,   66,   73,   93,   55,   78,
+
+       78,   78,  443,   88,   77,  442,   93,   88,   90,  168,
+       18,   90,   18,   28,   93,  101,  101,  440,   28,  106,
+      106,  106,  115,  115,  115,  117,  117,  117,  439,   28,
+       28,  120,  120,  120,   28,   28,   28,   28,   28,   28,
+       28,   28,   28,   28,   28,   28,   28,   28,   28,   28,
+       28,   28,   28,   28,   28,   28,   28,   28,   58,  122,
+      122,  122,   58,  438,  108,  108,  108,  408,   58,  109,
+      109,  109,  140,  140,  407,   58,  141,  141,   58,  406,
+       58,  152,  152,   58,   58,  144,  144,  144,   58,  108,
+      147,  147,  147,  405,  109,   58,  153,  153,   58,  172,
+
+       58,   58,   58,   58,  150,  150,  150,  159,  159,  159,
+      162,  166,  404,  191,  162,  401,  172,  190,  190,  190,
+      396,  166,  192,  192,  192,  162,  191,  314,  314,  172,
+      194,  194,  194,  195,  195,  195,  197,  197,  197,  199,
+      199,  199,  200,  200,  200,  207,  207,  207,  208,  209,
+      209,  209,  210,  212,  208,  394,  210,  211,  211,  211,
+      213,  213,  213,  214,  212,  251,  266,  214,  274,  210,
+      251,  292,  212,  251,  251,  295,  311,  402,  337,  392,
+      214,  391,  390,  266,  389,  274,  387,  386,  292,  337,
+      337,  385,  295,  311,  402,  411,  411,  411,  411,  411,
+
+      411,  411,  411,  411,  411,  411,  411,  411,  412,  412,
+      412,  412,  412,  412,  412,  412,  412,  412,  412,  412,
+      412,  413,  413,  413,  413,  413,  413,  413,  413,  413,
+      413,  413,  413,  413,  414,  414,  414,  414,  414,  414,
+      414,  414,  414,  414,  414,  414,  414,  415,  415,  415,
+      415,  415,  415,  415,  415,  415,  415,  415,  415,  415,
+      416,  416,  416,  416,  416,  416,  416,  416,  416,  416,
+      416,  416,  416,  417,  417,  417,  417,  417,  417,  417,
+      417,  417,  417,  417,  417,  417,  418,  418,  418,  418,
+      418,  418,  418,  418,  418,  418,  418,  418,  418,  419,
+
+      419,  419,  419,  419,  419,  419,  419,  419,  419,  419,
+      419,  419,  420,  420,  420,  420,  420,  420,  420,  420,
+      420,  420,  420,  420,  420,  421,  421,  422,  383,  422,
+      422,  422,  422,  422,  422,  422,  422,  382,  422,  422,
+      423,  423,  423,  423,  423,  423,  381,  423,  423,  423,
+      423,  380,  423,  424,  379,  424,  424,  424,  424,  424,
+      424,  424,  424,  424,  378,  424,  425,  425,  425,  425,
+      425,  425,  375,  425,  425,  425,  425,  425,  425,  426,
+      426,  374,  426,  426,  426,  426,  426,  426,  426,  426,
+      427,  427,  427,  427,  427,  427,  427,  427,  427,  427,
+
+      427,  373,  427,  428,  428,  428,  428,  428,  372,  428,
+      428,  428,  428,  428,  429,  429,  429,  429,  429,  429,
+      429,  429,  429,  429,  429,  371,  429,  430,  430,  370,
+      430,  430,  430,  430,  430,  430,  430,  430,  430,  431,
+      431,  431,  431,  431,  431,  431,  431,  431,  431,  431,
+      431,  431,  432,  432,  432,  432,  432,  369,  432,  432,
+      432,  432,  432,  432,  433,  433,  367,  366,  363,  362,
+      433,  433,  433,  433,  433,  361,  433,  434,  434,  360,
+      434,  359,  358,  434,  434,  434,  434,  434,  357,  434,
+      435,  435,  435,  435,  435,  435,  435,  435,  435,  435,
+
+      435,  356,  435,  436,  436,  436,  437,  355,  437,  437,
+      437,  437,  437,  437,  437,  437,  437,  437,  437,  441,
+      353,  441,  441,  441,  441,  441,  441,  441,  441,  352,
+      441,  441,  448,  448,  448,  448,  448,  448,  448,  448,
+      448,  448,  448,  448,  448,  351,  349,  348,  347,  346,
+      345,  344,  343,  342,  341,  340,  339,  336,  335,  334,
+      333,  332,  331,  329,  328,  327,  326,  325,  324,  323,
+      322,  320,  319,  318,  313,  309,  307,  306,  305,  304,
+      302,  301,  300,  298,  297,  296,  294,  293,  290,  289,
+      287,  284,  282,  281,  279,  277,  276,  275,  273,  271,
+
+      270,  269,  268,  267,  265,  264,  263,  261,  260,  259,
+      258,  257,  256,  255,  254,  253,  252,  247,  246,  245,
+      244,  243,  242,  241,  240,  239,  238,  237,  236,  235,
       234,  233,  232,  231,  230,  229,  228,  227,  226,  225,
-      224,  222,  221,  220,  219,  218,  217,  216,  215,  214,
-
-      210,  208,  205,  204,  203,  202,  201,  200,  199,  198,
-      197,  196,  194,  193,  191,  190,  189,  188,  187,  185,
-      184,  183,  181,  141,  115,  109,  108,  107,  104,  102,
-      100,   98,   97,   94,   88,   79,   39,   21,   19,  379,
-      379,  379,  379,  379,  379,  379,  379,  379,  379,  379,
-      379,  379,  379,  379,  379,  379,  379,  379,  379,  379,
-      379,  379,  379,  379,  379,  379,  379,  379,  379,  379,
-      379,  379,  379,  379,  379,  379,  379,  379,  379,  379,
-      379,  379,  379,  379,  379,  379,  379,  379,  379,  379
+      224,  223,  222,  221,  220,  219,  218,  217,  216,  215,
+      206,  202,  201,  198,  196,  193,  189,  186,  185,  184,
+      183,  182,  181,  180,  179,  178,  177,  175,  174,  173,
+      171,  170,  169,  167,  165,  164,  163,  161,  126,  121,
+      116,  110,  107,  103,  102,   96,   95,   94,   91,   89,
+       87,   85,   84,   81,   72,   49,   45,   40,   23,    8,
+
+        7,    2,  410,  410,  410,  410,  410,  410,  410,  410,
+      410,  410,  410,  410,  410,  410,  410,  410,  410,  410,
+      410,  410,  410,  410,  410,  410,  410,  410,  410,  410,
+      410,  410,  410,  410,  410,  410,  410,  410,  410,  410,
+      410,  410,  410,  410,  410,  410,  410,  410,  410,  410,
+      410,  410,  410,  410,  410,  410,  410,  410
     } ;
 
 static yy_state_type yy_last_accepting_state;
@@ -703,19 +732,20 @@ static char *yy_last_accepting_cpos;
 extern int yy_flex_debug;
 int yy_flex_debug = 1;
 
-static yyconst short int yy_rule_linenum[101] =
+static yyconst short int yy_rule_linenum[104] =
     {   0,
-      121,  122,  123,  124,  125,  126,  127,  128,  129,  130,
-      131,  132,  133,  134,  135,  136,  137,  138,  139,  140,
-      141,  142,  143,  144,  145,  146,  147,  148,  149,  150,
-      151,  152,  154,  155,  156,  157,  159,  160,  161,  166,
-      169,  172,  175,  176,  179,  182,  185,  193,  199,  215,
-      216,  227,  239,  240,  241,  258,  267,  269,  289,  304,
-      306,  326,  338,  342,  343,  344,  345,  346,  347,  348,
-      349,  350,  356,  367,  373,  374,  376,  378,  396,  402,
-      403,  405,  407,  425,  428,  431,  432,  435,  446,  457,
-      459,  461,  464,  465,  468,  488,  495,  496,  497,  517
-
+      218,  219,  220,  221,  222,  223,  224,  225,  226,  227,
+      228,  229,  230,  231,  232,  233,  234,  235,  236,  237,
+      238,  239,  240,  241,  242,  243,  244,  245,  246,  247,
+      248,  249,  250,  251,  253,  258,  260,  261,  262,  263,
+      264,  266,  268,  274,  288,  291,  294,  295,  298,  301,
+      304,  312,  318,  333,  334,  344,  349,  364,  365,  380,
+      381,  393,  403,  422,  438,  457,  469,  483,  484,  485,
+      486,  487,  488,  489,  490,  491,  502,  508,  519,  525,
+      526,  527,  529,  546,  552,  553,  554,  556,  573,  576,
+      579,  580,  583,  594,  595,  596,  609,  611,  616,  635,
+
+      642,  643,  662
     } ;
 
 /* The intent behind this definition is that it'll catch
@@ -753,6 +783,7 @@ char *yytext;
 #define YY_STACK_USED 1
 #line 26 "scan-gram.l"
 #include "system.h"
+#include "mbswidth.h"
 #include "complain.h"
 #include "quote.h"
 #include "getargs.h"
@@ -763,14 +794,101 @@ char *yytext;
 #define YY_USER_INIT                           \
 do {                                           \
   LOCATION_RESET (*yylloc);                    \
+  yylloc->file = infile;                       \
    /* This is only to avoid GCC warnings. */   \
   if (yycontrol) {;};                          \
 } while (0)
 
-#define YY_USER_ACTION  LOCATION_COLUMNS (*yylloc, yyleng)
-#define YY_LINES        LOCATION_LINES (*yylloc, yyleng);
+#define YY_USER_ACTION  extend_location (yylloc, yytext, yyleng);
 #define YY_STEP         LOCATION_STEP (*yylloc)
 
+#define YY_INPUT(buf, result, size) ((result) = no_cr_read (yyin, buf, size))
+
+
+/* Read bytes from FP into buffer BUF of size SIZE.  Return the
+   number of bytes read.  Remove '\r' from input, treating \r\n
+   and isolated \r as \n.  */
+
+static size_t
+no_cr_read (FILE *fp, char *buf, size_t size)
+{
+  size_t s = fread (buf, 1, size, fp);
+  if (s)
+    {
+      char *w = memchr (buf, '\r', s);
+      if (w)
+       {
+         char const *r = ++w;
+         char const *lim = buf + s;
+
+         for (;;)
+           {
+             /* Found an '\r'.  Treat it like '\n', but ignore any
+                '\n' that immediately follows.  */
+             w[-1] = '\n';
+             if (r == lim)
+               {
+                 int ch = getc (fp);
+                 if (ch != '\n' && ungetc (ch, fp) != ch)
+                   break;
+               }
+             else if (*r == '\n')
+               r++;
+
+             /* Copy until the next '\r'.  */
+             do
+               {
+                 if (r == lim)
+                   return w - buf;
+               }
+             while ((*w++ = *r++) != '\r');
+           }
+
+         return w - buf;
+       }
+    }
+
+  return s;
+}
+
+
+/* Extend *LOC to account for token TOKEN of size SIZE.  */
+
+static void
+extend_location (location_t *loc, char const *token, int size)
+{
+  int line = loc->last_line;
+  int column = loc->last_column;
+  char const *p0 = token;
+  char const *p = token;
+  char const *lim = token + size;
+
+  for (p = token; p < lim; p++)
+    switch (*p)
+      {
+      case '\r':
+       /* \r shouldn't survive no_cr_read.  */
+       abort ();
+
+      case '\n':
+       line++;
+       column = 1;
+       p0 = p + 1;
+       break;
+
+      case '\t':
+       column += mbsnwidth (p0, p - p0, 0);
+       column += 8 - ((column - 1) & 7);
+       p0 = p + 1;
+       break;
+      }
+
+  loc->last_line = line;
+  loc->last_column = column + mbsnwidth (p0, p - p0, 0);
+}
+
+
+
 /* STRING_OBSTACK -- Used to store all the characters that we need to
    keep (to construct ID, STRINGS etc.).  Use the following macros to
    use it.
@@ -804,27 +922,43 @@ scanner_last_string_free (void)
 }
 
 
-static int braces_level = 0;
 static int percent_percent_count = 0;
 
-static void handle_dollar PARAMS ((braced_code_t code_kind,
-                                  char *cp, location_t location));
-static void handle_at PARAMS ((braced_code_t code_kind,
-                              char *cp, location_t location));
+/* Within well-formed rules, RULE_LENGTH is the number of values in
+   the current rule so far, which says where to find `$0' with respect
+   to the top of the stack.  It is not the same as the rule->length in
+   the case of mid rule actions.
+
+   Outside of well-formed rules, RULE_LENGTH has an undefined value.  */
+static int rule_length;
+
+static void handle_dollar (braced_code_t code_kind,
+                          char *cp, location_t location);
+static void handle_at (braced_code_t code_kind,
+                      char *cp, location_t location);
+static void handle_syncline (char *args, location_t *location);
+static int convert_ucn_to_byte (char const *hex_text);
 
 #define SC_COMMENT 1
+#define SC_LINE_COMMENT 2
+#define SC_YACC_COMMENT 3
 
-#define SC_STRING 2
-#define SC_CHARACTER 3
+#define SC_STRING 4
+#define SC_CHARACTER 5
 
-#define SC_ESCAPED_STRING 4
-#define SC_ESCAPED_CHARACTER 5
+#define SC_ESCAPED_STRING 6
+#define SC_ESCAPED_CHARACTER 7
 
-#define SC_BRACED_CODE 6
-#define SC_PROLOGUE 7
-#define SC_EPILOGUE 8
+#define SC_BRACED_CODE 8
+#define SC_PROLOGUE 9
+#define SC_EPILOGUE 10
 
-#line 828 "lex.yy.c"
+/* POSIX says that a tag must be both an id and a C union member, but
+   historically almost any character is allowed in a tag.  We disallow
+   NUL and newline, as this simplifies our implementation.  */
+/* Zero or more instances of backslash-newline.  Following GCC, allow
+   white space between the backslash and the newline.  */
+#line 962 "scan-gram.c"
 
 /* Macros after this point can all be overridden by user definitions in
  * section 1.
@@ -978,6 +1112,9 @@ YY_MALLOC_DECL
 #endif
 
 #define YY_RULE_SETUP \
+       if ( yyleng > 0 ) \
+               yy_current_buffer->yy_at_bol = \
+                               (yytext[yyleng - 1] == '\n'); \
        YY_USER_ACTION
 
 YY_DECL
@@ -986,30 +1123,21 @@ YY_DECL
        register char *yy_cp, *yy_bp;
        register int yy_act;
 
-#line 97 "scan-gram.l"
+#line 203 "scan-gram.l"
 
 
+  int braces_level IF_LINT (= 0);
+
   /* At each yylex invocation, mark the current position as the
      start of the next token.  */
-#define TR_POS 0
-#if TR_POS
-  fprintf (stderr, "FOO1: %p: ", yylloc);
-  LOCATION_PRINT (stderr, *yylloc);
-  fprintf (stderr, "\n");
-#endif
   YY_STEP;
-#if TR_POS
-  fprintf (stderr, "BAR1: ");
-  LOCATION_PRINT (stderr, *yylloc);
-  fprintf (stderr, "\n");
-#endif
 
 
 
   /*----------------------------.
   | Scanning Bison directives.  |
   `----------------------------*/
-#line 1013 "lex.yy.c"
+#line 1141 "scan-gram.c"
 
        if ( yy_init )
                {
@@ -1048,6 +1176,7 @@ YY_DECL
                yy_bp = yy_cp;
 
                yy_current_state = yy_start;
+               yy_current_state += YY_AT_BOL();
 yy_match:
                do
                        {
@@ -1060,13 +1189,13 @@ yy_match:
                        while ( yy_chk[yy_base[yy_current_state] + yy_c] != yy_current_state )
                                {
                                yy_current_state = (int) yy_def[yy_current_state];
-                               if ( yy_current_state >= 380 )
+                               if ( yy_current_state >= 411 )
                                        yy_c = yy_meta[(unsigned int) yy_c];
                                }
                        yy_current_state = yy_nxt[yy_base[yy_current_state] + (unsigned int) yy_c];
                        ++yy_cp;
                        }
-               while ( yy_base[yy_current_state] != 840 );
+               while ( yy_base[yy_current_state] != 903 );
 
 yy_find_action:
                yy_act = yy_accept[yy_current_state];
@@ -1086,13 +1215,13 @@ do_action:      /* This label is used only to access EOF actions. */
                        {
                        if ( yy_act == 0 )
                                fprintf( stderr, "--scanner backing up\n" );
-                       else if ( yy_act < 101 )
+                       else if ( yy_act < 104 )
                                fprintf( stderr, "--accepting rule at line %d (\"%s\")\n",
                                         yy_rule_linenum[yy_act], yytext );
-                       else if ( yy_act == 101 )
+                       else if ( yy_act == 104 )
                                fprintf( stderr, "--accepting default rule (\"%s\")\n",
                                         yytext );
-                       else if ( yy_act == 102 )
+                       else if ( yy_act == 105 )
                                fprintf( stderr, "--(end of buffer or a NUL)\n" );
                        else
                                fprintf( stderr, "--EOF (start condition %d)\n", YY_START );
@@ -1111,246 +1240,281 @@ do_action:    /* This label is used only to access EOF actions. */
 
 case 1:
 YY_RULE_SETUP
-#line 121 "scan-gram.l"
+#line 218 "scan-gram.l"
 return PERCENT_NONASSOC;
        YY_BREAK
 case 2:
 YY_RULE_SETUP
-#line 122 "scan-gram.l"
+#line 219 "scan-gram.l"
 return PERCENT_DEBUG;
        YY_BREAK
 case 3:
 YY_RULE_SETUP
-#line 123 "scan-gram.l"
+#line 220 "scan-gram.l"
 return PERCENT_DEFINE;
        YY_BREAK
 case 4:
 YY_RULE_SETUP
-#line 124 "scan-gram.l"
+#line 221 "scan-gram.l"
 return PERCENT_DEFINES;
        YY_BREAK
 case 5:
 YY_RULE_SETUP
-#line 125 "scan-gram.l"
+#line 222 "scan-gram.l"
 return PERCENT_DESTRUCTOR;
        YY_BREAK
 case 6:
 YY_RULE_SETUP
-#line 126 "scan-gram.l"
+#line 223 "scan-gram.l"
 return PERCENT_DPREC;
        YY_BREAK
 case 7:
 YY_RULE_SETUP
-#line 127 "scan-gram.l"
+#line 224 "scan-gram.l"
 return PERCENT_ERROR_VERBOSE;
        YY_BREAK
 case 8:
 YY_RULE_SETUP
-#line 128 "scan-gram.l"
+#line 225 "scan-gram.l"
 return PERCENT_EXPECT;
        YY_BREAK
 case 9:
 YY_RULE_SETUP
-#line 129 "scan-gram.l"
+#line 226 "scan-gram.l"
 return PERCENT_FILE_PREFIX;
        YY_BREAK
 case 10:
 YY_RULE_SETUP
-#line 130 "scan-gram.l"
+#line 227 "scan-gram.l"
 return PERCENT_YACC;
        YY_BREAK
 case 11:
 YY_RULE_SETUP
-#line 131 "scan-gram.l"
+#line 228 "scan-gram.l"
 return PERCENT_GLR_PARSER;
        YY_BREAK
 case 12:
 YY_RULE_SETUP
-#line 132 "scan-gram.l"
+#line 229 "scan-gram.l"
 return PERCENT_LEFT;
        YY_BREAK
 case 13:
 YY_RULE_SETUP
-#line 133 "scan-gram.l"
+#line 230 "scan-gram.l"
 return PERCENT_LOCATIONS;
        YY_BREAK
 case 14:
 YY_RULE_SETUP
-#line 134 "scan-gram.l"
+#line 231 "scan-gram.l"
 return PERCENT_MERGE;
        YY_BREAK
 case 15:
 YY_RULE_SETUP
-#line 135 "scan-gram.l"
+#line 232 "scan-gram.l"
 return PERCENT_NAME_PREFIX;
        YY_BREAK
 case 16:
 YY_RULE_SETUP
-#line 136 "scan-gram.l"
+#line 233 "scan-gram.l"
 return PERCENT_NO_LINES;
        YY_BREAK
 case 17:
 YY_RULE_SETUP
-#line 137 "scan-gram.l"
+#line 234 "scan-gram.l"
 return PERCENT_NONASSOC;
        YY_BREAK
 case 18:
 YY_RULE_SETUP
-#line 138 "scan-gram.l"
+#line 235 "scan-gram.l"
 return PERCENT_NTERM;
        YY_BREAK
 case 19:
 YY_RULE_SETUP
-#line 139 "scan-gram.l"
+#line 236 "scan-gram.l"
 return PERCENT_OUTPUT;
        YY_BREAK
 case 20:
 YY_RULE_SETUP
-#line 140 "scan-gram.l"
-return PERCENT_PREC;
+#line 237 "scan-gram.l"
+return PERCENT_PARSE_PARAM;
        YY_BREAK
 case 21:
 YY_RULE_SETUP
-#line 141 "scan-gram.l"
-return PERCENT_PRINTER;
+#line 238 "scan-gram.l"
+rule_length--; return PERCENT_PREC;
        YY_BREAK
 case 22:
 YY_RULE_SETUP
-#line 142 "scan-gram.l"
-return PERCENT_PURE_PARSER;
+#line 239 "scan-gram.l"
+return PERCENT_PRINTER;
        YY_BREAK
 case 23:
 YY_RULE_SETUP
-#line 143 "scan-gram.l"
-return PERCENT_RIGHT;
+#line 240 "scan-gram.l"
+return PERCENT_PURE_PARSER;
        YY_BREAK
 case 24:
 YY_RULE_SETUP
-#line 144 "scan-gram.l"
-return PERCENT_SKELETON;
+#line 241 "scan-gram.l"
+return PERCENT_RIGHT;
        YY_BREAK
 case 25:
 YY_RULE_SETUP
-#line 145 "scan-gram.l"
-return PERCENT_START;
+#line 242 "scan-gram.l"
+return PERCENT_LEX_PARAM;
        YY_BREAK
 case 26:
 YY_RULE_SETUP
-#line 146 "scan-gram.l"
-return PERCENT_TOKEN;
+#line 243 "scan-gram.l"
+return PERCENT_SKELETON;
        YY_BREAK
 case 27:
 YY_RULE_SETUP
-#line 147 "scan-gram.l"
-return PERCENT_TOKEN;
+#line 244 "scan-gram.l"
+return PERCENT_START;
        YY_BREAK
 case 28:
 YY_RULE_SETUP
-#line 148 "scan-gram.l"
-return PERCENT_TOKEN_TABLE;
+#line 245 "scan-gram.l"
+return PERCENT_TOKEN;
        YY_BREAK
 case 29:
 YY_RULE_SETUP
-#line 149 "scan-gram.l"
-return PERCENT_TYPE;
+#line 246 "scan-gram.l"
+return PERCENT_TOKEN;
        YY_BREAK
 case 30:
 YY_RULE_SETUP
-#line 150 "scan-gram.l"
-return PERCENT_UNION;
+#line 247 "scan-gram.l"
+return PERCENT_TOKEN_TABLE;
        YY_BREAK
 case 31:
 YY_RULE_SETUP
-#line 151 "scan-gram.l"
-return PERCENT_VERBOSE;
+#line 248 "scan-gram.l"
+return PERCENT_TYPE;
        YY_BREAK
 case 32:
 YY_RULE_SETUP
-#line 152 "scan-gram.l"
-return PERCENT_YACC;
+#line 249 "scan-gram.l"
+return PERCENT_UNION;
        YY_BREAK
 case 33:
 YY_RULE_SETUP
-#line 154 "scan-gram.l"
-return EQUAL;
+#line 250 "scan-gram.l"
+return PERCENT_VERBOSE;
        YY_BREAK
 case 34:
 YY_RULE_SETUP
-#line 155 "scan-gram.l"
-return COLON;
+#line 251 "scan-gram.l"
+return PERCENT_YACC;
        YY_BREAK
 case 35:
 YY_RULE_SETUP
-#line 156 "scan-gram.l"
-return PIPE;
+#line 253 "scan-gram.l"
+{
+    complain_at (*yylloc, _("invalid directive: %s"), quote (yytext));
+    YY_STEP;
+  }
        YY_BREAK
 case 36:
 YY_RULE_SETUP
-#line 157 "scan-gram.l"
-return SEMICOLON;
+#line 258 "scan-gram.l"
+handle_syncline (yytext + strlen ("#line "), yylloc); YY_STEP;
        YY_BREAK
 case 37:
 YY_RULE_SETUP
-#line 159 "scan-gram.l"
-YY_LINES; YY_STEP;
+#line 260 "scan-gram.l"
+return EQUAL;
        YY_BREAK
 case 38:
 YY_RULE_SETUP
-#line 160 "scan-gram.l"
-YY_STEP;
+#line 261 "scan-gram.l"
+rule_length = 0; return COLON;
        YY_BREAK
 case 39:
 YY_RULE_SETUP
-#line 161 "scan-gram.l"
+#line 262 "scan-gram.l"
+rule_length = 0; return PIPE;
+       YY_BREAK
+case 40:
+YY_RULE_SETUP
+#line 263 "scan-gram.l"
+return COMMA;
+       YY_BREAK
+case 41:
+YY_RULE_SETUP
+#line 264 "scan-gram.l"
+return SEMICOLON;
+       YY_BREAK
+case 42:
+YY_RULE_SETUP
+#line 266 "scan-gram.l"
+YY_STEP;
+       YY_BREAK
+case 43:
+YY_RULE_SETUP
+#line 268 "scan-gram.l"
 {
     yylval->symbol = symbol_get (yytext, *yylloc);
+    rule_length++;
     return ID;
   }
        YY_BREAK
-case 40:
+case 44:
 YY_RULE_SETUP
-#line 166 "scan-gram.l"
-yylval->integer = strtol (yytext, 0, 10); return INT;
+#line 274 "scan-gram.l"
+{
+    unsigned long num;
+    errno = 0;
+    num = strtoul (yytext, 0, 10);
+    if (INT_MAX < num || errno)
+      {
+       complain_at (*yylloc, _("integer out of range: %s"), quote (yytext));
+       num = INT_MAX;
+      }
+    yylval->integer = num;
+    return INT;
+  }
        YY_BREAK
 /* Characters.  We don't check there is only one.  */
-case 41:
+case 45:
 YY_RULE_SETUP
-#line 169 "scan-gram.l"
+#line 288 "scan-gram.l"
 YY_OBS_GROW; yy_push_state (SC_ESCAPED_CHARACTER);
        YY_BREAK
 /* Strings. */
-case 42:
+case 46:
 YY_RULE_SETUP
-#line 172 "scan-gram.l"
+#line 291 "scan-gram.l"
 YY_OBS_GROW; yy_push_state (SC_ESCAPED_STRING);
        YY_BREAK
 /* Comments. */
-case 43:
+case 47:
 YY_RULE_SETUP
-#line 175 "scan-gram.l"
-yy_push_state (SC_COMMENT);
+#line 294 "scan-gram.l"
+BEGIN SC_YACC_COMMENT;
        YY_BREAK
-case 44:
+case 48:
 YY_RULE_SETUP
-#line 176 "scan-gram.l"
+#line 295 "scan-gram.l"
 YY_STEP;
        YY_BREAK
 /* Prologue. */
-case 45:
+case 49:
 YY_RULE_SETUP
-#line 179 "scan-gram.l"
+#line 298 "scan-gram.l"
 yy_push_state (SC_PROLOGUE);
        YY_BREAK
 /* Code in between braces.  */
-case 46:
+case 50:
 YY_RULE_SETUP
-#line 182 "scan-gram.l"
-YY_OBS_GROW; ++braces_level; yy_push_state (SC_BRACED_CODE);
+#line 301 "scan-gram.l"
+YY_OBS_GROW; braces_level = 0; yy_push_state (SC_BRACED_CODE);
        YY_BREAK
 /* A type. */
-case 47:
+case 51:
 YY_RULE_SETUP
-#line 185 "scan-gram.l"
+#line 304 "scan-gram.l"
 {
     obstack_grow (&string_obstack, yytext + 1, yyleng - 2);
     YY_OBS_FINISH;
@@ -1358,120 +1522,139 @@ YY_RULE_SETUP
     return TYPE;
   }
        YY_BREAK
-case 48:
+case 52:
 YY_RULE_SETUP
-#line 193 "scan-gram.l"
+#line 312 "scan-gram.l"
 {
     if (++percent_percent_count == 2)
       yy_push_state (SC_EPILOGUE);
     return PERCENT_PERCENT;
   }
        YY_BREAK
-case 49:
+case 53:
 YY_RULE_SETUP
-#line 199 "scan-gram.l"
+#line 318 "scan-gram.l"
 {
-    LOCATION_PRINT (stderr, *yylloc);
-    fprintf (stderr, ": invalid character: `%c'\n", *yytext);
+    complain_at (*yylloc, _("invalid character: %s"), quote (yytext));
     YY_STEP;
   }
        YY_BREAK
 
-/*------------------------------------------------------------.
-  | Whatever the start condition (but those which correspond to |
-  | entity `swallowed' by Bison: SC_ESCAPED_STRING and          |
-  | SC_ESCAPED_CHARACTER), no M4 character must escape as is.   |
-  `------------------------------------------------------------*/
+/*-------------------------------------------------------------------.
+  | Whatever the start condition (but those which correspond to        |
+  | entities `swallowed' by Bison: SC_YACC_COMMENT, SC_ESCAPED_STRING, |
+  | and SC_ESCAPED_CHARACTER), no M4 character must escape as is.      |
+  `-------------------------------------------------------------------*/
 
 
-case 50:
+case 54:
 YY_RULE_SETUP
-#line 215 "scan-gram.l"
-if (YY_START != SC_COMMENT) obstack_sgrow (&string_obstack, "@<:@");
+#line 333 "scan-gram.l"
+obstack_sgrow (&string_obstack, "@<:@");
        YY_BREAK
-case 51:
+case 55:
 YY_RULE_SETUP
-#line 216 "scan-gram.l"
-if (YY_START != SC_COMMENT) obstack_sgrow (&string_obstack, "@:>@");
+#line 334 "scan-gram.l"
+obstack_sgrow (&string_obstack, "@:>@");
        YY_BREAK
 
-/*-----------------------------------------------------------.
-  | Scanning a C comment. The initial `/ *' is already eaten.  |
-  `-----------------------------------------------------------*/
+/*---------------------------------------------------------------.
+  | Scanning a Yacc comment.  The initial `/ *' is already eaten.  |
+  `---------------------------------------------------------------*/
 
 
-case 52:
+case 56:
 YY_RULE_SETUP
-#line 227 "scan-gram.l"
-{ /* End of the comment. */
-    if (yy_top_state () == INITIAL)
-      {
-       YY_STEP;
-      }
-    else
-      {
-       YY_OBS_GROW;
-      }
-    yy_pop_state ();
+#line 344 "scan-gram.l"
+{
+    YY_STEP;
+    BEGIN INITIAL;
   }
        YY_BREAK
-case 53:
+case 57:
 YY_RULE_SETUP
-#line 239 "scan-gram.l"
-if (yy_top_state () != INITIAL) YY_OBS_GROW;
+#line 349 "scan-gram.l"
+;
        YY_BREAK
-case 54:
+case YY_STATE_EOF(SC_YACC_COMMENT):
+#line 351 "scan-gram.l"
+{
+    complain_at (*yylloc, _("unexpected end of file in a comment"));
+    BEGIN INITIAL;
+  }
+       YY_BREAK
+
+/*------------------------------------------------------------.
+  | Scanning a C comment.  The initial `/ *' is already eaten.  |
+  `------------------------------------------------------------*/
+
+
+case 58:
 YY_RULE_SETUP
-#line 240 "scan-gram.l"
-if (yy_top_state () != INITIAL) YY_OBS_GROW; YY_LINES;
+#line 364 "scan-gram.l"
+YY_OBS_GROW; yy_pop_state ();
        YY_BREAK
-case 55:
+case 59:
 YY_RULE_SETUP
-#line 241 "scan-gram.l"
-/* Stray `*'. */if (yy_top_state () != INITIAL) YY_OBS_GROW;
+#line 365 "scan-gram.l"
+YY_OBS_GROW;
        YY_BREAK
 case YY_STATE_EOF(SC_COMMENT):
-#line 243 "scan-gram.l"
+#line 367 "scan-gram.l"
 {
-    LOCATION_PRINT (stderr, *yylloc);
-    fprintf (stderr, ": unexpected end of file in a comment\n");
+    complain_at (*yylloc, _("unexpected end of file in a comment"));
     yy_pop_state ();
   }
        YY_BREAK
 
+/*--------------------------------------------------------------.
+  | Scanning a line comment.  The initial `//' is already eaten.  |
+  `--------------------------------------------------------------*/
+
+
+case 60:
+YY_RULE_SETUP
+#line 380 "scan-gram.l"
+YY_OBS_GROW; yy_pop_state ();
+       YY_BREAK
+case 61:
+YY_RULE_SETUP
+#line 381 "scan-gram.l"
+YY_OBS_GROW;
+       YY_BREAK
+case YY_STATE_EOF(SC_LINE_COMMENT):
+#line 382 "scan-gram.l"
+yy_pop_state ();
+       YY_BREAK
+
 /*----------------------------------------------------------------.
   | Scanning a C string, including its escapes.  The initial `"' is |
   | already eaten.                                                  |
   `----------------------------------------------------------------*/
 
 
-case 56:
+case 62:
 YY_RULE_SETUP
-#line 258 "scan-gram.l"
+#line 393 "scan-gram.l"
 {
     assert (yy_top_state () == INITIAL);
     YY_OBS_GROW;
     YY_OBS_FINISH;
     yylval->string = last_string;
     yy_pop_state ();
+    rule_length++;
     return STRING;
   }
        YY_BREAK
-case 57:
+case 63:
 YY_RULE_SETUP
-#line 267 "scan-gram.l"
+#line 403 "scan-gram.l"
 YY_OBS_GROW;
        YY_BREAK
-case 58:
-YY_RULE_SETUP
-#line 269 "scan-gram.l"
-obstack_1grow (&string_obstack, '\n'); YY_LINES;
-       YY_BREAK
 case YY_STATE_EOF(SC_ESCAPED_STRING):
-#line 271 "scan-gram.l"
+#line 405 "scan-gram.l"
 {
-    LOCATION_PRINT (stderr, *yylloc);
-    fprintf (stderr, ": unexpected end of file in a string\n");
+    complain_at (*yylloc, _("unexpected end of file in a string"));
     assert (yy_top_state () == INITIAL);
     YY_OBS_FINISH;
     yylval->string = last_string;
@@ -1486,9 +1669,9 @@ case YY_STATE_EOF(SC_ESCAPED_STRING):
   `---------------------------------------------------------------*/
 
 
-case 59:
+case 64:
 YY_RULE_SETUP
-#line 289 "scan-gram.l"
+#line 422 "scan-gram.l"
 {
     YY_OBS_GROW;
     assert (yy_top_state () == INITIAL);
@@ -1500,25 +1683,20 @@ YY_RULE_SETUP
                                    (unsigned char) last_string[1], *yylloc);
       YY_OBS_FREE;
       yy_pop_state ();
+      rule_length++;
       return ID;
     }
   }
        YY_BREAK
-case 60:
+case 65:
 YY_RULE_SETUP
-#line 304 "scan-gram.l"
+#line 438 "scan-gram.l"
 YY_OBS_GROW;
        YY_BREAK
-case 61:
-YY_RULE_SETUP
-#line 306 "scan-gram.l"
-obstack_1grow (&string_obstack, '\n'); YY_LINES;
-       YY_BREAK
 case YY_STATE_EOF(SC_ESCAPED_CHARACTER):
-#line 308 "scan-gram.l"
+#line 440 "scan-gram.l"
 {
-    LOCATION_PRINT (stderr, *yylloc);
-    fprintf (stderr, ": unexpected end of file in a character\n");
+    complain_at (*yylloc, _("unexpected end of file in a character literal"));
     assert (yy_top_state () == INITIAL);
     YY_OBS_FINISH;
     yylval->string = last_string;
@@ -1532,81 +1710,106 @@ case YY_STATE_EOF(SC_ESCAPED_CHARACTER):
   `----------------------------*/
 
 
-case 62:
+case 66:
 YY_RULE_SETUP
-#line 326 "scan-gram.l"
+#line 457 "scan-gram.l"
 {
-    long c = strtol (yytext + 1, 0, 8);
-    if (c > 255)
+    unsigned long c = strtoul (yytext + 1, 0, 8);
+    if (UCHAR_MAX < c)
       {
-       LOCATION_PRINT (stderr, *yylloc);
-       fprintf (stderr, ": invalid escape: %s\n", quote (yytext));
+       complain_at (*yylloc, _("invalid escape sequence: %s"),
+                    quote (yytext));
        YY_STEP;
       }
     else
       obstack_1grow (&string_obstack, c);
   }
        YY_BREAK
-case 63:
+case 67:
 YY_RULE_SETUP
-#line 338 "scan-gram.l"
+#line 469 "scan-gram.l"
 {
-    obstack_1grow (&string_obstack, strtol (yytext + 2, 0, 16));
+    unsigned long c;
+    errno = 0;
+    c = strtoul (yytext + 2, 0, 16);
+    if (UCHAR_MAX < c || errno)
+      {
+       complain_at (*yylloc, _("invalid escape sequence: %s"),
+                    quote (yytext));
+       YY_STEP;
+      }
+    else
+      obstack_1grow (&string_obstack, c);
   }
        YY_BREAK
-case 64:
+case 68:
 YY_RULE_SETUP
-#line 342 "scan-gram.l"
+#line 483 "scan-gram.l"
 obstack_1grow (&string_obstack, '\a');
        YY_BREAK
-case 65:
+case 69:
 YY_RULE_SETUP
-#line 343 "scan-gram.l"
+#line 484 "scan-gram.l"
 obstack_1grow (&string_obstack, '\b');
        YY_BREAK
-case 66:
+case 70:
 YY_RULE_SETUP
-#line 344 "scan-gram.l"
+#line 485 "scan-gram.l"
 obstack_1grow (&string_obstack, '\f');
        YY_BREAK
-case 67:
+case 71:
 YY_RULE_SETUP
-#line 345 "scan-gram.l"
+#line 486 "scan-gram.l"
 obstack_1grow (&string_obstack, '\n');
        YY_BREAK
-case 68:
+case 72:
 YY_RULE_SETUP
-#line 346 "scan-gram.l"
+#line 487 "scan-gram.l"
 obstack_1grow (&string_obstack, '\r');
        YY_BREAK
-case 69:
+case 73:
 YY_RULE_SETUP
-#line 347 "scan-gram.l"
+#line 488 "scan-gram.l"
 obstack_1grow (&string_obstack, '\t');
        YY_BREAK
-case 70:
+case 74:
 YY_RULE_SETUP
-#line 348 "scan-gram.l"
+#line 489 "scan-gram.l"
 obstack_1grow (&string_obstack, '\v');
        YY_BREAK
-case 71:
+case 75:
 YY_RULE_SETUP
-#line 349 "scan-gram.l"
+#line 490 "scan-gram.l"
 obstack_1grow (&string_obstack, yytext[1]);
        YY_BREAK
-case 72:
+case 76:
 YY_RULE_SETUP
-#line 350 "scan-gram.l"
+#line 491 "scan-gram.l"
 {
-    LOCATION_PRINT (stderr, *yylloc);
-    fprintf (stderr, ": unrecognized escape: %s\n", quote (yytext));
+    int c = convert_ucn_to_byte (yytext);
+    if (c < 0)
+      {
+       complain_at (*yylloc, _("invalid escape sequence: %s"),
+                    quote (yytext));
+       YY_STEP;
+      }
+    else
+      obstack_1grow (&string_obstack, c);
+  }
+       YY_BREAK
+case 77:
+YY_RULE_SETUP
+#line 502 "scan-gram.l"
+{
+    complain_at (*yylloc, _("unrecognized escape sequence: %s"),
+                quote (yytext));
     YY_OBS_GROW;
   }
        YY_BREAK
 /* FLex wants this rule, in case of a `\<<EOF>>'. */
-case 73:
+case 78:
 YY_RULE_SETUP
-#line 356 "scan-gram.l"
+#line 508 "scan-gram.l"
 YY_OBS_GROW;
        YY_BREAK
 
@@ -1616,41 +1819,40 @@ YY_OBS_GROW;
   `----------------------------------------------------------*/
 
 
-case 74:
+case 79:
 YY_RULE_SETUP
-#line 367 "scan-gram.l"
+#line 519 "scan-gram.l"
 {
     YY_OBS_GROW;
     assert (yy_top_state () != INITIAL);
     yy_pop_state ();
   }
        YY_BREAK
-case 75:
+case 80:
 YY_RULE_SETUP
-#line 373 "scan-gram.l"
+#line 525 "scan-gram.l"
 YY_OBS_GROW;
        YY_BREAK
-case 76:
+case 81:
 YY_RULE_SETUP
-#line 374 "scan-gram.l"
+#line 526 "scan-gram.l"
 YY_OBS_GROW;
        YY_BREAK
-/* FLex wants this rule, in case of a `\<<EOF>>'. */
-case 77:
+case 82:
 YY_RULE_SETUP
-#line 376 "scan-gram.l"
+#line 527 "scan-gram.l"
 YY_OBS_GROW;
        YY_BREAK
-case 78:
+/* Needed for `\<<EOF>>', `\\<<newline>>[', and `\\<<newline>>]'.  */
+case 83:
 YY_RULE_SETUP
-#line 378 "scan-gram.l"
-YY_OBS_GROW; YY_LINES;
+#line 529 "scan-gram.l"
+YY_OBS_GROW;
        YY_BREAK
 case YY_STATE_EOF(SC_CHARACTER):
-#line 380 "scan-gram.l"
+#line 531 "scan-gram.l"
 {
-    LOCATION_PRINT (stderr, *yylloc);
-    fprintf (stderr, ": unexpected end of file in a character\n");
+    complain_at (*yylloc, _("unexpected end of file in a character literal"));
     assert (yy_top_state () != INITIAL);
     yy_pop_state ();
   }
@@ -1662,41 +1864,40 @@ case YY_STATE_EOF(SC_CHARACTER):
   `----------------------------------------------------------------*/
 
 
-case 79:
+case 84:
 YY_RULE_SETUP
-#line 396 "scan-gram.l"
+#line 546 "scan-gram.l"
 {
     assert (yy_top_state () != INITIAL);
     YY_OBS_GROW;
     yy_pop_state ();
   }
        YY_BREAK
-case 80:
+case 85:
 YY_RULE_SETUP
-#line 402 "scan-gram.l"
+#line 552 "scan-gram.l"
 YY_OBS_GROW;
        YY_BREAK
-case 81:
+case 86:
 YY_RULE_SETUP
-#line 403 "scan-gram.l"
+#line 553 "scan-gram.l"
 YY_OBS_GROW;
        YY_BREAK
-/* FLex wants this rule, in case of a `\<<EOF>>'. */
-case 82:
+case 87:
 YY_RULE_SETUP
-#line 405 "scan-gram.l"
+#line 554 "scan-gram.l"
 YY_OBS_GROW;
        YY_BREAK
-case 83:
+/* Needed for `\<<EOF>>', `\\<<newline>>[', and `\\<<newline>>]'.  */
+case 88:
 YY_RULE_SETUP
-#line 407 "scan-gram.l"
-YY_OBS_GROW; YY_LINES;
+#line 556 "scan-gram.l"
+YY_OBS_GROW;
        YY_BREAK
 case YY_STATE_EOF(SC_STRING):
-#line 409 "scan-gram.l"
+#line 558 "scan-gram.l"
 {
-    LOCATION_PRINT (stderr, *yylloc);
-    fprintf (stderr, ": unexpected end of file in a string\n");
+    complain_at (*yylloc, _("unexpected end of file in a string"));
     assert (yy_top_state () != INITIAL);
     yy_pop_state ();
   }
@@ -1708,32 +1909,32 @@ case YY_STATE_EOF(SC_STRING):
 
 
 /* Characters.  We don't check there is only one.  */
-case 84:
+case 89:
 YY_RULE_SETUP
-#line 425 "scan-gram.l"
+#line 573 "scan-gram.l"
 YY_OBS_GROW; yy_push_state (SC_CHARACTER);
        YY_BREAK
 /* Strings. */
-case 85:
+case 90:
 YY_RULE_SETUP
-#line 428 "scan-gram.l"
+#line 576 "scan-gram.l"
 YY_OBS_GROW; yy_push_state (SC_STRING);
        YY_BREAK
 /* Comments. */
-case 86:
+case 91:
 YY_RULE_SETUP
-#line 431 "scan-gram.l"
+#line 579 "scan-gram.l"
 YY_OBS_GROW; yy_push_state (SC_COMMENT);
        YY_BREAK
-case 87:
+case 92:
 YY_RULE_SETUP
-#line 432 "scan-gram.l"
-YY_OBS_GROW;
+#line 580 "scan-gram.l"
+YY_OBS_GROW; yy_push_state (SC_LINE_COMMENT);
        YY_BREAK
 /* Not comments. */
-case 88:
+case 93:
 YY_RULE_SETUP
-#line 435 "scan-gram.l"
+#line 583 "scan-gram.l"
 YY_OBS_GROW;
        YY_BREAK
 
@@ -1743,58 +1944,55 @@ YY_OBS_GROW;
   `---------------------------------------------------------------*/
 
 
-case 89:
+case 94:
+YY_RULE_SETUP
+#line 594 "scan-gram.l"
+YY_OBS_GROW; braces_level++;
+       YY_BREAK
+case 95:
+YY_RULE_SETUP
+#line 595 "scan-gram.l"
+YY_OBS_GROW; braces_level--;
+       YY_BREAK
+case 96:
 YY_RULE_SETUP
-#line 446 "scan-gram.l"
+#line 596 "scan-gram.l"
 {
     YY_OBS_GROW;
-    if (--braces_level == 0)
+    braces_level--;
+    if (braces_level < 0)
       {
        yy_pop_state ();
        YY_OBS_FINISH;
        yylval->string = last_string;
+       rule_length++;
        return BRACED_CODE;
       }
   }
        YY_BREAK
-case 90:
-YY_RULE_SETUP
-#line 457 "scan-gram.l"
-YY_OBS_GROW; braces_level++;
-       YY_BREAK
-case 91:
+case 97:
 YY_RULE_SETUP
-#line 459 "scan-gram.l"
+#line 609 "scan-gram.l"
 { handle_dollar (current_braced_code,
                                                   yytext, *yylloc); }
        YY_BREAK
-case 92:
+case 98:
 YY_RULE_SETUP
-#line 461 "scan-gram.l"
+#line 611 "scan-gram.l"
 { handle_at (current_braced_code,
                                               yytext, *yylloc); }
        YY_BREAK
-case 93:
-YY_RULE_SETUP
-#line 464 "scan-gram.l"
-YY_OBS_GROW;
-       YY_BREAK
-case 94:
-YY_RULE_SETUP
-#line 465 "scan-gram.l"
-YY_OBS_GROW; YY_LINES;
-       YY_BREAK
-/* A lose $, or /, or etc. */
-case 95:
+/* `"<"{splice}"<"' tokenizes `<<%' correctly (as `<<' `%') rather
+     than incorrrectly (as `<' `<%').  */
+case 99:
 YY_RULE_SETUP
-#line 468 "scan-gram.l"
+#line 616 "scan-gram.l"
 YY_OBS_GROW;
        YY_BREAK
 case YY_STATE_EOF(SC_BRACED_CODE):
-#line 470 "scan-gram.l"
+#line 618 "scan-gram.l"
 {
-    LOCATION_PRINT (stderr, *yylloc);
-    fprintf (stderr, ": unexpected end of file in a braced code\n");
+    complain_at (*yylloc, _("unexpected end of file in `{ ... }'"));
     yy_pop_state ();
     YY_OBS_FINISH;
     yylval->string = last_string;
@@ -1807,9 +2005,9 @@ case YY_STATE_EOF(SC_BRACED_CODE):
   `--------------------------------------------------------------*/
 
 
-case 96:
+case 100:
 YY_RULE_SETUP
-#line 488 "scan-gram.l"
+#line 635 "scan-gram.l"
 {
     yy_pop_state ();
     YY_OBS_FINISH;
@@ -1817,26 +2015,20 @@ YY_RULE_SETUP
     return PROLOGUE;
   }
        YY_BREAK
-case 97:
+case 101:
 YY_RULE_SETUP
-#line 495 "scan-gram.l"
+#line 642 "scan-gram.l"
 YY_OBS_GROW;
        YY_BREAK
-case 98:
+case 102:
 YY_RULE_SETUP
-#line 496 "scan-gram.l"
+#line 643 "scan-gram.l"
 YY_OBS_GROW;
        YY_BREAK
-case 99:
-YY_RULE_SETUP
-#line 497 "scan-gram.l"
-YY_OBS_GROW; YY_LINES;
-       YY_BREAK
 case YY_STATE_EOF(SC_PROLOGUE):
-#line 499 "scan-gram.l"
+#line 645 "scan-gram.l"
 {
-    LOCATION_PRINT (stderr, *yylloc);
-    fprintf (stderr, ": unexpected end of file in a prologue\n");
+    complain_at (*yylloc, _("unexpected end of file in `%%{ ... %%}'"));
     yy_pop_state ();
     YY_OBS_FINISH;
     yylval->string = last_string;
@@ -1846,17 +2038,17 @@ case YY_STATE_EOF(SC_PROLOGUE):
 
 /*---------------------------------------------------------------.
   | Scanning the epilogue (everything after the second "%%", which |
-  | has already been eaten                                       |
+  | has already been eaten).                                       |
   `---------------------------------------------------------------*/
 
 
-case 100:
+case 103:
 YY_RULE_SETUP
-#line 517 "scan-gram.l"
+#line 662 "scan-gram.l"
 YY_OBS_GROW;
        YY_BREAK
 case YY_STATE_EOF(SC_EPILOGUE):
-#line 519 "scan-gram.l"
+#line 664 "scan-gram.l"
 {
     yy_pop_state ();
     YY_OBS_FINISH;
@@ -1865,12 +2057,12 @@ case YY_STATE_EOF(SC_EPILOGUE):
   }
        YY_BREAK
 
-case 101:
+case 104:
 YY_RULE_SETUP
-#line 528 "scan-gram.l"
+#line 673 "scan-gram.l"
 YY_FATAL_ERROR( "flex scanner jammed" );
        YY_BREAK
-#line 1874 "lex.yy.c"
+#line 2066 "scan-gram.c"
 case YY_STATE_EOF(INITIAL):
        yyterminate();
 
@@ -2150,10 +2342,11 @@ static yy_state_type yy_get_previous_state()
        register char *yy_cp;
 
        yy_current_state = yy_start;
+       yy_current_state += YY_AT_BOL();
 
        for ( yy_cp = yytext_ptr + YY_MORE_ADJ; yy_cp < yy_c_buf_p; ++yy_cp )
                {
-               register YY_CHAR yy_c = (*yy_cp ? yy_ec[YY_SC_TO_UI(*yy_cp)] : 1);
+               register YY_CHAR yy_c = (*yy_cp ? yy_ec[YY_SC_TO_UI(*yy_cp)] : 55);
                if ( yy_accept[yy_current_state] )
                        {
                        yy_last_accepting_state = yy_current_state;
@@ -2162,7 +2355,7 @@ static yy_state_type yy_get_previous_state()
                while ( yy_chk[yy_base[yy_current_state] + yy_c] != yy_current_state )
                        {
                        yy_current_state = (int) yy_def[yy_current_state];
-                       if ( yy_current_state >= 380 )
+                       if ( yy_current_state >= 411 )
                                yy_c = yy_meta[(unsigned int) yy_c];
                        }
                yy_current_state = yy_nxt[yy_base[yy_current_state] + (unsigned int) yy_c];
@@ -2188,7 +2381,7 @@ yy_state_type yy_current_state;
        register int yy_is_jam;
        register char *yy_cp = yy_c_buf_p;
 
-       register YY_CHAR yy_c = 1;
+       register YY_CHAR yy_c = 55;
        if ( yy_accept[yy_current_state] )
                {
                yy_last_accepting_state = yy_current_state;
@@ -2197,11 +2390,11 @@ yy_state_type yy_current_state;
        while ( yy_chk[yy_base[yy_current_state] + yy_c] != yy_current_state )
                {
                yy_current_state = (int) yy_def[yy_current_state];
-               if ( yy_current_state >= 380 )
+               if ( yy_current_state >= 411 )
                        yy_c = yy_meta[(unsigned int) yy_c];
                }
        yy_current_state = yy_nxt[yy_base[yy_current_state] + (unsigned int) yy_c];
-       yy_is_jam = (yy_current_state == 379);
+       yy_is_jam = (yy_current_state == 410);
 
        return yy_is_jam ? 0 : yy_current_state;
        }
@@ -2320,6 +2513,7 @@ static int input()
        *yy_c_buf_p = '\0';     /* preserve yytext */
        yy_hold_char = *++yy_c_buf_p;
 
+       yy_current_buffer->yy_at_bol = (c == '\n');
 
        return c;
        }
@@ -2760,7 +2954,7 @@ int main()
        return 0;
        }
 #endif
-#line 528 "scan-gram.l"
+#line 673 "scan-gram.l"
 
 
 /*------------------------------------------------------------------.
@@ -2799,19 +2993,15 @@ handle_action_dollar (char *text, location_t location)
       obstack_fgrow1 (&string_obstack,
                      "]b4_lhs_value([%s])[", type_name);
     }
-  else if (isdigit (*cp) || *cp == '-')
+  else
     {
-      /* RULE_LENGTH is the number of values in the current rule so
-        far, which says where to find `$0' with respect to the top of
-        the stack.  It is not the same as the rule->length in the
-        case of mid rule actions.  */
-      int rule_length = symbol_list_length (current_rule->next);
-      int n = strtol (cp, &cp, 10);
-
-      if (n > rule_length)
-       complain_at (location, _("invalid value: %s%d"), "$", n);
-      else
+      long num;
+      errno = 0;
+      num = strtol (cp, 0, 10);
+
+      if (INT_MIN <= num && num <= rule_length && ! errno)
        {
+         int n = num;
          if (!type_name && n > 0)
            type_name = symbol_list_n_type_name_get (current_rule, location,
                                                     n);
@@ -2824,16 +3014,14 @@ handle_action_dollar (char *text, location_t location)
                          "]b4_rhs_value([%d], [%d], [%s])[",
                          rule_length, n, type_name);
        }
-    }
-  else
-    {
-      complain_at (location, _("%s is invalid"), quote (text));
+      else
+       complain_at (location, _("integer out of range: %s"), quote (text));
     }
 }
 
 
 /*---------------------------------------------------------------.
-| TEXT is expexted tp be $$ in some code associated to a symbol: |
+| TEXT is expected to be $$ in some code associated to a symbol: |
 | destructor or printer.                                         |
 `---------------------------------------------------------------*/
 
@@ -2844,7 +3032,7 @@ handle_symbol_code_dollar (char *text, location_t location)
   if (*cp == '$')
     obstack_sgrow (&string_obstack, "]b4_dollar_dollar[");
   else
-    complain_at (location, _("%s is invalid"), quote (text));
+    complain_at (location, _("invalid value: %s"), quote (text));
 }
 
 
@@ -2886,30 +3074,26 @@ handle_action_at (char *text, location_t location)
     {
       obstack_sgrow (&string_obstack, "]b4_lhs_location[");
     }
-  else if (isdigit (*cp) || *cp == '-')
-    {
-      /* RULE_LENGTH is the number of values in the current rule so
-        far, which says where to find `$0' with respect to the top of
-        the stack.  It is not the same as the rule->length in the
-        case of mid rule actions.  */
-      int rule_length = symbol_list_length (current_rule->next);
-      int n = strtol (cp, &cp, 10);
-
-      if (n > rule_length)
-       complain_at (location, _("invalid value: %s%d"), "@", n);
-      else
-       obstack_fgrow2 (&string_obstack, "]b4_rhs_location([%d], [%d])[",
-                       rule_length, n);
-    }
   else
     {
-      complain_at (location, _("%s is invalid"), quote (text));
+      long num;
+      errno = 0;
+      num = strtol (cp, 0, 10);
+
+      if (INT_MIN <= num && num <= rule_length && ! errno)
+       {
+         int n = num;
+         obstack_fgrow2 (&string_obstack, "]b4_rhs_location([%d], [%d])[",
+                         rule_length, n);
+       }
+      else
+       complain_at (location, _("integer out of range: %s"), quote (text));
     }
 }
 
 
 /*---------------------------------------------------------------.
-| TEXT is expexted tp be @$ in some code associated to a symbol: |
+| TEXT is expected to be @$ in some code associated to a symbol: |
 | destructor or printer.                                         |
 `---------------------------------------------------------------*/
 
@@ -2920,7 +3104,7 @@ handle_symbol_code_at (char *text, location_t location)
   if (*cp == '$')
     obstack_sgrow (&string_obstack, "]b4_at_dollar[");
   else
-    complain_at (location, _("%s is invalid"), quote (text));
+    complain_at (location, _("invalid value: %s"), quote (text));
 }
 
 
@@ -2947,6 +3131,80 @@ handle_at (braced_code_t braced_code_kind,
 }
 
 
+/*------------------------------------------------------------------.
+| Convert universal character name UCN to a single-byte character,  |
+| and return that character.  Return -1 if UCN does not correspond  |
+| to a single-byte character.                                      |
+`------------------------------------------------------------------*/
+
+static int
+convert_ucn_to_byte (char const *ucn)
+{
+  unsigned long code = strtoul (ucn + 2, 0, 16);
+
+  /* FIXME: Currently we assume Unicode-compatible unibyte characters
+     on ASCII hosts (i.e., Latin-1 on hosts with 8-bit bytes).  On
+     non-ASCII hosts we support only the portable C character set.
+     These limitations should be removed once we add support for
+     multibyte characters.  */
+
+  if (UCHAR_MAX < code)
+    return -1;
+
+#if ! ('$' == 0x24 && '@' == 0x40 && '`' == 0x60 && '~' == 0x7e)
+  {
+    /* A non-ASCII host.  Use CODE to index into a table of the C
+       basic execution character set, which is guaranteed to exist on
+       all Standard C platforms.  This table also includes '$', '@',
+       and '`', which not in the basic execution character set but
+       which are unibyte characters on all the platforms that we know
+       about.  */
+    static signed char const table[] =
+      {
+       '\0',   -1,   -1,   -1,   -1,   -1,   -1, '\a',
+       '\b', '\t', '\n', '\v', '\f', '\r',   -1,   -1,
+         -1,   -1,   -1,   -1,   -1,   -1,   -1,   -1,
+         -1,   -1,   -1,   -1,   -1,   -1,   -1,   -1,
+        ' ',  '!',  '"',  '#',  '$',  '%',  '&', '\'',
+        '(',  ')',  '*',  '+',  ',',  '-',  '.',  '/',
+        '0',  '1',  '2',  '3',  '4',  '5',  '6',  '7',
+        '8',  '9',  ':',  ';',  '<',  '=',  '>',  '?',
+        '@',  'A',  'B',  'C',  'D',  'E',  'F',  'G',
+        'H',  'I',  'J',  'K',  'L',  'M',  'N',  'O',
+        'P',  'Q',  'R',  'S',  'T',  'U',  'V',  'W',
+        'X',  'Y',  'Z',  '[', '\\',  ']',  '^',  '_',
+        '`',  'a',  'b',  'c',  'd',  'e',  'f',  'g',
+        'h',  'i',  'j',  'k',  'l',  'm',  'n',  'o',
+        'p',  'q',  'r',  's',  't',  'u',  'v',  'w',
+        'x',  'y',  'z',  '{',  '|',  '}',  '~'
+      };
+
+    code = code < sizeof table ? table[code] : -1;
+  }
+#endif
+
+  return code;
+}
+
+
+/*----------------------------------------------------------------.
+| Handle `#line INT "FILE"'.  ARGS has already skipped `#line '.  |
+`----------------------------------------------------------------*/
+
+static void
+handle_syncline (char *args, location_t *location)
+{
+  int lineno = strtol (args, &args, 10);
+  const char *file = NULL;
+  file = strchr (args, '"') + 1;
+  *strchr (file, '"') = 0;
+  /* FIXME: Leaking...  Can't free, as some locations are still
+     pointing to the old file name.  */
+  infile = xstrdup (file);
+  location->file = infile;
+  location->last_line = lineno;
+}
+
 /*-------------------------.
 | Initialize the scanner.  |
 `-------------------------*/