errno = 0;
zendlval->value.lval = strtol(yytext, NULL, 0);
if (errno == ERANGE) { /* overflow */
- zendlval->value.dval = strtod(yytext,NULL);
+ zendlval->value.dval = zend_string_to_double(yytext, yyleng);
zendlval->type = IS_DOUBLE;
return T_DNUMBER;
} else {
}
<ST_IN_SCRIPTING>{DNUM}|{EXPONENT_DNUM} {
- zendlval->value.dval = strtod(yytext,NULL);
+ zendlval->value.dval = zend_string_to_double(yytext, yyleng);
zendlval->type = IS_DOUBLE;
return T_DNUMBER;
}
#include "ext/bcmath/number.h"
#endif
+ZEND_API double zend_string_to_double(const char *number, zend_uint length)
+{
+ zend_uint i=0;
+ double divisor = 10.0;
+ double result = 0.0;
+ double exponent;
+
+ if (!length) {
+ return result;
+ }
+
+ for (i=0; i<length; i++) {
+ if ((number[i] <= '9' && number[i] >= '0')) {
+ result *= 10;
+ result += number[i] - '0';
+ } else if (number[i] == '.') {
+ i++;
+ break;
+ } else if (toupper(number[i]) == 'E') {
+ exponent = (double) atoi(&number[i+1]);
+ result *= pow(10.0, exponent);
+ return result;
+ } else {
+ return result;
+ }
+ }
+
+ for (; i<length; i++) {
+ if ((number[i] <= '9' && number[i] >= '0')) {
+ result += (number[i] - '0') / divisor;
+ divisor *= 10;
+ } else if (toupper(number[i]) == 'E') {
+ exponent = (double) atoi(&number[i+1]);
+ result *= pow(10.0, exponent);
+ return result;
+ } else {
+ return result;
+ }
+ }
+ return result;
+}
+
ZEND_API void convert_scalar_to_number(zval *op)
{
ZEND_API int add_char_to_string(zval *result, zval *op1, zval *op2);
ZEND_API int add_string_to_string(zval *result, zval *op1, zval *op2);
#define convert_to_string(op) _convert_to_string((op) ZEND_FILE_LINE_CC)
+
+ZEND_API double zend_string_to_double(const char *number, zend_uint length);
END_EXTERN_C()
ZEND_API int zval_is_true(zval *op);