mirror of
https://git.savannah.gnu.org/git/bison.git
synced 2026-03-09 12:23:04 +00:00
bison: check for int overflow in token numbers
* src/symtab.c: Include intprops.h (symbol_user_token_number_set): Don’t allow user_token_number == INT_MAX because too much other code adds 1 to the user token number. (symbols_token_translations_init): Complain on integer overflow instead of indulging in undefined behavior.
This commit is contained in:
10
src/symtab.c
10
src/symtab.c
@@ -30,6 +30,7 @@
|
||||
#include "complain.h"
|
||||
#include "getargs.h"
|
||||
#include "gram.h"
|
||||
#include "intprops.h"
|
||||
#include "quote.h"
|
||||
|
||||
|
||||
@@ -549,6 +550,9 @@ symbol_user_token_number_set (symbol *sym, int user_token_number, location loc)
|
||||
&& *user_token_numberp != user_token_number)
|
||||
complain (&loc, complaint, _("redefining user token number of %s"),
|
||||
sym->tag);
|
||||
else if (user_token_number == INT_MAX)
|
||||
complain (&loc, complaint, _("user token number of %s too large"),
|
||||
sym->tag);
|
||||
else
|
||||
{
|
||||
*user_token_numberp = user_token_number;
|
||||
@@ -1005,7 +1009,11 @@ symbols_token_translations_init (void)
|
||||
{
|
||||
sym_content *this = symbols[i]->content;
|
||||
if (this->user_token_number == USER_NUMBER_UNDEFINED)
|
||||
this->user_token_number = ++max_user_token_number;
|
||||
{
|
||||
if (INT_ADD_WRAPV (max_user_token_number, 1, &max_user_token_number))
|
||||
complain (NULL, fatal, _("token number too large"));
|
||||
this->user_token_number = max_user_token_number;
|
||||
}
|
||||
if (this->user_token_number > max_user_token_number)
|
||||
max_user_token_number = this->user_token_number;
|
||||
}
|
||||
|
||||
Reference in New Issue
Block a user