diff options
Diffstat (limited to 'ext/standard/math.c')
| -rw-r--r-- | ext/standard/math.c | 78 | 
1 files changed, 29 insertions, 49 deletions
| diff --git a/ext/standard/math.c b/ext/standard/math.c index ba7e3944aa..f903615d75 100644 --- a/ext/standard/math.c +++ b/ext/standard/math.c @@ -1,7 +1,5 @@  /*     +----------------------------------------------------------------------+ -   | PHP Version 7                                                        | -   +----------------------------------------------------------------------+     | Copyright (c) The PHP Group                                          |     +----------------------------------------------------------------------+     | This source file is subject to version 3.01 of the PHP license,      | @@ -283,18 +281,16 @@ static double php_expm1(double x)  }  /* }}}*/ -/* {{{ proto int abs(int number) +/* {{{ proto int|float abs(int number)     Return the absolute value of the number */  PHP_FUNCTION(abs)  {  	zval *value;  	ZEND_PARSE_PARAMETERS_START(1, 1) -		Z_PARAM_ZVAL(value) +		Z_PARAM_NUMBER(value)  	ZEND_PARSE_PARAMETERS_END(); -	convert_scalar_to_number_ex(value); -  	if (Z_TYPE_P(value) == IS_DOUBLE) {  		RETURN_DOUBLE(fabs(Z_DVAL_P(value)));  	} else if (Z_TYPE_P(value) == IS_LONG) { @@ -303,8 +299,9 @@ PHP_FUNCTION(abs)  		} else {  			RETURN_LONG(Z_LVAL_P(value) < 0 ? -Z_LVAL_P(value) : Z_LVAL_P(value));  		} +	} else { +		ZEND_ASSERT(0 && "Unexpected type");  	} -	RETURN_FALSE;  }  /* }}} */ @@ -315,17 +312,16 @@ PHP_FUNCTION(ceil)  	zval *value;  	ZEND_PARSE_PARAMETERS_START(1, 1) -		Z_PARAM_ZVAL(value) +		Z_PARAM_NUMBER(value)  	ZEND_PARSE_PARAMETERS_END(); -	convert_scalar_to_number_ex(value); -  	if (Z_TYPE_P(value) == IS_DOUBLE) {  		RETURN_DOUBLE(ceil(Z_DVAL_P(value)));  	} else if (Z_TYPE_P(value) == IS_LONG) {  		RETURN_DOUBLE(zval_get_double(value)); +	} else { +		ZEND_ASSERT(0 && "Unexpected type");  	} -	RETURN_FALSE;  }  /* }}} */ @@ -336,21 +332,20 @@ PHP_FUNCTION(floor)  	zval *value;  	ZEND_PARSE_PARAMETERS_START(1, 1) -		Z_PARAM_ZVAL(value) +		Z_PARAM_NUMBER(value)  	ZEND_PARSE_PARAMETERS_END(); -	convert_scalar_to_number_ex(value); -  	if (Z_TYPE_P(value) == IS_DOUBLE) {  		RETURN_DOUBLE(floor(Z_DVAL_P(value)));  	} else if (Z_TYPE_P(value) == IS_LONG) {  		RETURN_DOUBLE(zval_get_double(value)); +	} else { +		ZEND_ASSERT(0 && "Unexpected type");  	} -	RETURN_FALSE;  }  /* }}} */ -/* {{{ proto float round(float number [, int precision [, int mode]]) +/* {{{ proto float|false round(float number [, int precision [, int mode]])     Returns the number rounded to specified precision */  PHP_FUNCTION(round)  { @@ -683,7 +678,7 @@ PHP_FUNCTION(log1p)  }  /* }}} */ -/* {{{ proto float log(float number, [float base]) +/* {{{ proto float|false log(float number, [float base])     Returns the natural logarithm of the number, or the base log if base is specified */  PHP_FUNCTION(log)  { @@ -846,7 +841,7 @@ PHPAPI zend_long _php_math_basetolong(zval *arg, int base)  /*   * Convert a string representation of a base(2-36) number to a zval.   */ -PHPAPI int _php_math_basetozval(zval *arg, int base, zval *ret) +PHPAPI void _php_math_basetozval(zend_string *str, int base, zval *ret)  {  	zend_long num = 0;  	double fnum = 0; @@ -856,11 +851,8 @@ PHPAPI int _php_math_basetozval(zval *arg, int base, zval *ret)  	int cutlim;  	int invalidchars = 0; -	if (Z_TYPE_P(arg) != IS_STRING || base < 2 || base > 36) { -		return FAILURE; -	} -	s = Z_STRVAL_P(arg); -	e = s + Z_STRLEN_P(arg); +	s = ZSTR_VAL(str); +	e = s + ZSTR_LEN(str);  	/* Skip leading whitespace */  	while (s < e && isspace(*s)) s++; @@ -920,7 +912,6 @@ PHPAPI int _php_math_basetozval(zval *arg, int base, zval *ret)  	} else {  		ZVAL_LONG(ret, num);  	} -	return SUCCESS;  }  /* }}} */ @@ -994,54 +985,45 @@ PHPAPI zend_string * _php_math_zvaltobase(zval *arg, int base)  }  /* }}} */ -/* {{{ proto int bindec(string binary_number) +/* {{{ proto int|float bindec(string binary_number)     Returns the decimal equivalent of the binary number */  PHP_FUNCTION(bindec)  { -	zval *arg; +	zend_string *arg;  	ZEND_PARSE_PARAMETERS_START(1, 1) -		Z_PARAM_ZVAL(arg) +		Z_PARAM_STR(arg)  	ZEND_PARSE_PARAMETERS_END(); -	convert_to_string_ex(arg); -	if (_php_math_basetozval(arg, 2, return_value) == FAILURE) { -		RETURN_FALSE; -	} +	_php_math_basetozval(arg, 2, return_value);  }  /* }}} */ -/* {{{ proto int hexdec(string hexadecimal_number) +/* {{{ proto int|flat hexdec(string hexadecimal_number)     Returns the decimal equivalent of the hexadecimal number */  PHP_FUNCTION(hexdec)  { -	zval *arg; +	zend_string *arg;  	ZEND_PARSE_PARAMETERS_START(1, 1) -		Z_PARAM_ZVAL(arg) +		Z_PARAM_STR(arg)  	ZEND_PARSE_PARAMETERS_END(); -	convert_to_string_ex(arg); -	if (_php_math_basetozval(arg, 16, return_value) == FAILURE) { -		RETURN_FALSE; -	} +	_php_math_basetozval(arg, 16, return_value);  }  /* }}} */ -/* {{{ proto int octdec(string octal_number) +/* {{{ proto int|float octdec(string octal_number)     Returns the decimal equivalent of an octal string */  PHP_FUNCTION(octdec)  { -	zval *arg; +	zend_string *arg;  	ZEND_PARSE_PARAMETERS_START(1, 1) -		Z_PARAM_ZVAL(arg) +		Z_PARAM_STR(arg)  	ZEND_PARSE_PARAMETERS_END(); -	convert_to_string_ex(arg); -	if (_php_math_basetozval(arg, 8, return_value) == FAILURE) { -		RETURN_FALSE; -	} +	_php_math_basetozval(arg, 8, return_value);  }  /* }}} */ @@ -1096,7 +1078,7 @@ PHP_FUNCTION(dechex)  }  /* }}} */ -/* {{{ proto string base_convert(string number, int frombase, int tobase) +/* {{{ proto string|false base_convert(string number, int frombase, int tobase)     Converts a number in a string from any base <= 36 to any base <= 36 */  PHP_FUNCTION(base_convert)  { @@ -1123,9 +1105,7 @@ PHP_FUNCTION(base_convert)  		RETURN_FALSE;  	} -	if(_php_math_basetozval(number, (int)frombase, &temp) == FAILURE) { -		RETURN_FALSE; -	} +	_php_math_basetozval(Z_STR_P(number), (int)frombase, &temp);  	result = _php_math_zvaltobase(&temp, (int)tobase);  	RETVAL_STR(result);  } | 
