Fixes parsing larger numbers on 64bit platforms.
This commit is contained in:
parent
be4cd99a36
commit
c32c3f88f0
1 changed files with 4 additions and 4 deletions
|
@ -129,10 +129,10 @@ include ^{WHITE}*include{WHITE}*\".*\"{WHITE}*;
|
|||
|
||||
0x{XIGIT}+ {
|
||||
char *e;
|
||||
long int l;
|
||||
unsigned long int l;
|
||||
errno = 0;
|
||||
l = strtoul(yytext+2, &e, 16);
|
||||
if (e && *e || errno == ERANGE || (long int)(int) l != l)
|
||||
if (e && *e || errno == ERANGE || (unsigned long int)(unsigned int) l != l)
|
||||
cf_error("Number out of range");
|
||||
cf_lval.i = l;
|
||||
return NUM;
|
||||
|
@ -140,10 +140,10 @@ include ^{WHITE}*include{WHITE}*\".*\"{WHITE}*;
|
|||
|
||||
{DIGIT}+ {
|
||||
char *e;
|
||||
long int l;
|
||||
unsigned long int l;
|
||||
errno = 0;
|
||||
l = strtoul(yytext, &e, 10);
|
||||
if (e && *e || errno == ERANGE || (long int)(int) l != l)
|
||||
if (e && *e || errno == ERANGE || (unsigned long int)(unsigned int) l != l)
|
||||
cf_error("Number out of range");
|
||||
cf_lval.i = l;
|
||||
return NUM;
|
||||
|
|
Loading…
Reference in a new issue