+2002-05-20 Paul Hilfinger <Hilfinger@CS.Berkeley.EDU>
+
+ * data/bison.simple (yyr1): Don't use yy_token_number_type as element
+ type; it isn't always big enough, since it doesn't necessarily
+ include non-terminals.
+ (yytranslate): Expand definition of yy_token_number_type, so that
+ the latter can be removed.
+ (yy_token_number_type): Remove, only one use.
+ * data/bison.c++ (r1_): Parallel change to yyr1 in bison.simple---
+ don't use TokenNumberType as element type.
+
+ * tests/regression.at: Modify expected output to agree with change
+ to yyr1 and yytranslate.
+
2002-05-13 Florian Krohm <florian@edamail.fishkill.ibm.com>
* src/reader.c (parse_action): Use copy_character instead of
static const short defgoto_[[]];
static const short table_[[]];
static const short check_[[]];
- static const TokenNumberType r1_[[]];
+ static const b4_uint_type(b4_r1_max) r1_[[]];
static const b4_uint_type(b4_r2_max) r2_[[]];
#if YYDEBUG || YYERROR_VERBOSE
};
/* YYR1[[YYN]] -- Symbol number of symbol that rule YYN derives. */
-const yy::b4_name::TokenNumberType
+const b4_uint_type(b4_r1_max)
yy::b4_name::r1_[[]] =
{
b4_r1
#define YYUNDEFTOK b4_undef_token_number
#define YYMAXUTOK b4_user_token_number_max
-typedef b4_uint_type(b4_translate_max) yy_token_number_type;
#define YYTRANSLATE(X) \
((unsigned)(X) <= YYMAXUTOK ? yytranslate[[X]] : YYUNDEFTOK)
/* YYTRANSLATE[[YYLEX]] -- Bison symbol number corresponding to YYLEX. */
-static const yy_token_number_type yytranslate[[]] =
+static const b4_uint_type(b4_translate_max) yytranslate[[]] =
{
b4_translate
};
};
/* YYR1[[YYN]] -- Symbol number of symbol that rule YYN derives. */
-static const yy_token_number_type yyr1[[]] =
+static const b4_uint_type(b4_r1_max) yyr1[[]] =
{
b4_r1
};
# Check only the tables. We don't use --no-parser, because it is
# still to be implemented in the experimental branch of Bison.
AT_CHECK([[sed -n 's/ *$//;/^static const.*\[\] =/,/^}/p' input.c]], 0,
-[[static const yy_token_number_type yytranslate[] =
+[[static const unsigned char yytranslate[] =
{
0, 2, 2, 2, 2, 2, 2, 2, 2, 2,
2, 2, 2, 2, 2, 2, 2, 2, 2, 2,
{
0, 256, 257, 258, 259, 260, 261, -1
};
-static const yy_token_number_type yyr1[] =
+static const unsigned char yyr1[] =
{
0, 7, 8, 9, 9, 10, 11
};