From: Stanislav Malyshev Date: Tue, 14 Nov 2000 17:54:11 +0000 (+0000) Subject: Better 0x handling - not change non-0x number behaviour X-Git-Tag: php-4.0.4RC3~198 X-Git-Url: https://granicus.if.org/sourcecode?a=commitdiff_plain;h=0b6a8d0458d37d39f6416935c9e4526f31d7a8bd;p=php Better 0x handling - not change non-0x number behaviour --- diff --git a/Zend/zend_language_scanner.l b/Zend/zend_language_scanner.l index 1e02fc4818..b537c08141 100644 --- a/Zend/zend_language_scanner.l +++ b/Zend/zend_language_scanner.l @@ -1001,19 +1001,12 @@ ANY_CHAR (.|[\n]) } -{LNUM}|{HNUM} { +{LNUM} { errno = 0; - zendlval->value.lval = strtoul(yytext, NULL, 0); + zendlval->value.lval = strtol(yytext, NULL, 0); if (errno == ERANGE) { /* overflow */ - if(yytext[0] == 0 && (yytext[1] == 'x' || yytext[1] == 'X') ) { - /* strtod for 0x'es returns trash */ - zendlval->value.lval = LONG_MAX; /* maximal long */ - zendlval->type = IS_LONG; - zend_error(E_NOTICE,"Hex number is too big: %s",yytext); - } else { - zendlval->value.dval = strtod(yytext,NULL); - zendlval->type = IS_DOUBLE; - } + zendlval->value.dval = strtod(yytext,NULL); + zendlval->type = IS_DOUBLE; return T_DNUMBER; } else { zendlval->type = IS_LONG; @@ -1021,6 +1014,20 @@ ANY_CHAR (.|[\n]) } } +{HNUM} { + errno = 0; + zendlval->value.lval = strtoul(yytext, NULL, 16); + if (errno == ERANGE) { /* overflow */ + /* not trying strtod - it returns trans on 0x-es */ + zendlval->value.lval = LONG_MAX; /* maximal long */ + zend_error(E_NOTICE,"Hex number is too big: %s",yytext); + } else { + zendlval->type = IS_LONG; + } + zendlval->type = IS_LONG; + return T_LNUMBER; +} + {LNUM}|{HNUM} { /* treat numbers (almost) as strings inside encapsulated strings */ zendlval->value.str.val = (char *)estrndup(yytext, yyleng); zendlval->value.str.len = yyleng;