]> granicus.if.org Git - php/commitdiff
Fixed autoconversion of negative values to double (Fix bug #11685)
authorZeev Suraski <zeev@php.net>
Tue, 26 Jun 2001 21:11:35 +0000 (21:11 +0000)
committerZeev Suraski <zeev@php.net>
Tue, 26 Jun 2001 21:11:35 +0000 (21:11 +0000)
Zend/zend_operators.c

index 11d72f6dc4da3a97e038d464a89f74c181912933..7cf3409e422f97e9ac4511d729e41f72a300db98 100644 (file)
@@ -611,7 +611,7 @@ ZEND_API int add_function(zval *result, zval *op1, zval *op2)
        if (op1->type == IS_LONG && op2->type == IS_LONG) {
                double dval = (double) op1->value.lval + (double) op2->value.lval;
 
-               if (dval > (double) LONG_MAX) {
+               if ((dval > (double) LONG_MAX) || (dval < (double) LONG_MIN)) {
                        result->value.dval = dval;
                        result->type = IS_DOUBLE;
                } else {
@@ -648,7 +648,7 @@ ZEND_API int sub_function(zval *result, zval *op1, zval *op2)
        if (op1->type == IS_LONG && op2->type == IS_LONG) {
                double dval = (double) op1->value.lval - (double) op2->value.lval;
 
-               if (dval < (double) LONG_MIN) {
+               if ((dval < (double) LONG_MIN) || (dval > (double) LONG_MAX)) {
                        result->value.dval = dval;
                        result->type = IS_DOUBLE;
                } else {
@@ -685,7 +685,7 @@ ZEND_API int mul_function(zval *result, zval *op1, zval *op2)
        if (op1->type == IS_LONG && op2->type == IS_LONG) {
                double dval = (double) op1->value.lval * (double) op2->value.lval;
 
-               if (dval > (double) LONG_MAX) {
+               if ((dval > (double) LONG_MAX) || (dval < (double) LONG_MIN)) {
                        result->value.dval = dval;
                        result->type = IS_DOUBLE;
                } else {