mirror of
https://git.savannah.gnu.org/git/bison.git
synced 2026-03-15 07:13:02 +00:00
Port to GCC 2.95. First two problems reported by Michael Deutschmann in
<http://lists.gnu.org/archive/html/bug-bison/2006-09/msg00018.html>. * src/parse-gram.y (symbol_declaration): Don't put statements before declarations; it's not portable to C89. * src/scan-code.l (handle_action_at): Likewise. * src/scan-code.l: Always initialize braces_level; the old code left it uninitialized and therefore had undefined behavior. Don't attempt to redefine 'assert', since it runs afoul of systems where standard headers (mistakenly) include <assert.h>. Instead, define and use our own alternative, called 'aver'. * src/reader.c: Don't include assert.h, since we no longer use assert. * src/scan-code.l: Likewise. * src/system.h (assert): Remove, replacing with.... (aver): New function, taking a bool arg. All uses changed. * src/tables.c (pack_vector): Ensure that aver arg is bool, not merely an integer.
This commit is contained in:
@@ -383,7 +383,7 @@ symbol_user_token_number_set (symbol *sym, int user_token_number, location loc)
|
||||
{
|
||||
int *user_token_numberp;
|
||||
|
||||
assert (sym->class == token_sym);
|
||||
aver (sym->class == token_sym);
|
||||
|
||||
if (sym->user_token_number != USER_NUMBER_ALIAS)
|
||||
user_token_numberp = &sym->user_token_number;
|
||||
@@ -546,7 +546,7 @@ symbol_pack (symbol *this)
|
||||
this->number = this->alias->number = 0;
|
||||
else
|
||||
{
|
||||
assert (this->alias->number != NUMBER_UNDEFINED);
|
||||
aver (this->alias->number != NUMBER_UNDEFINED);
|
||||
this->number = this->alias->number;
|
||||
}
|
||||
}
|
||||
@@ -555,7 +555,7 @@ symbol_pack (symbol *this)
|
||||
return true;
|
||||
}
|
||||
else /* this->class == token_sym */
|
||||
assert (this->number != NUMBER_UNDEFINED);
|
||||
aver (this->number != NUMBER_UNDEFINED);
|
||||
|
||||
symbols[this->number] = this;
|
||||
return true;
|
||||
|
||||
Reference in New Issue
Block a user