summaryrefslogtreecommitdiff
path: root/ext/bcmath/bcmath.c
diff options
context:
space:
mode:
authorXinchen Hui <laruence@gmail.com>2014-05-05 14:26:23 +0800
committerXinchen Hui <laruence@gmail.com>2014-05-05 14:26:23 +0800
commitfee9d4cafd02cb37177179b216fb21baf7041d30 (patch)
tree28fea6dd63ecd9429d295435c716e798e204189e /ext/bcmath/bcmath.c
parent7e3989f3014eba41fcdc44535723833029dc1ecf (diff)
downloadphp-git-fee9d4cafd02cb37177179b216fb21baf7041d30.tar.gz
Refactor bcmath
Diffstat (limited to 'ext/bcmath/bcmath.c')
-rw-r--r--ext/bcmath/bcmath.c35
1 files changed, 9 insertions, 26 deletions
diff --git a/ext/bcmath/bcmath.c b/ext/bcmath/bcmath.c
index 9369897c7f..4b8c7c5f18 100644
--- a/ext/bcmath/bcmath.c
+++ b/ext/bcmath/bcmath.c
@@ -230,9 +230,7 @@ PHP_FUNCTION(bcadd)
result->n_scale = scale;
}
- Z_STRVAL_P(return_value) = bc_num2str(result);
- Z_STRLEN_P(return_value) = strlen(Z_STRVAL_P(return_value));
- Z_TYPE_P(return_value) = IS_STRING;
+ RETVAL_STR(bc_num2str(result));
bc_free_num(&first);
bc_free_num(&second);
bc_free_num(&result);
@@ -269,9 +267,7 @@ PHP_FUNCTION(bcsub)
result->n_scale = scale;
}
- Z_STRVAL_P(return_value) = bc_num2str(result);
- Z_STRLEN_P(return_value) = strlen(Z_STRVAL_P(return_value));
- Z_TYPE_P(return_value) = IS_STRING;
+ RETVAL_STR(bc_num2str(result));
bc_free_num(&first);
bc_free_num(&second);
bc_free_num(&result);
@@ -308,9 +304,7 @@ PHP_FUNCTION(bcmul)
result->n_scale = scale;
}
- Z_STRVAL_P(return_value) = bc_num2str(result);
- Z_STRLEN_P(return_value) = strlen(Z_STRVAL_P(return_value));
- Z_TYPE_P(return_value) = IS_STRING;
+ RETVAL_STR(bc_num2str(result));
bc_free_num(&first);
bc_free_num(&second);
bc_free_num(&result);
@@ -347,9 +341,7 @@ PHP_FUNCTION(bcdiv)
if (result->n_scale > scale) {
result->n_scale = scale;
}
- Z_STRVAL_P(return_value) = bc_num2str(result);
- Z_STRLEN_P(return_value) = strlen(Z_STRVAL_P(return_value));
- Z_TYPE_P(return_value) = IS_STRING;
+ RETVAL_STR(bc_num2str(result));
break;
case -1: /* division by zero */
php_error_docref(NULL TSRMLS_CC, E_WARNING, "Division by zero");
@@ -383,9 +375,7 @@ PHP_FUNCTION(bcmod)
switch (bc_modulo(first, second, &result, 0 TSRMLS_CC)) {
case 0:
- Z_STRVAL_P(return_value) = bc_num2str(result);
- Z_STRLEN_P(return_value) = strlen(Z_STRVAL_P(return_value));
- Z_TYPE_P(return_value) = IS_STRING;
+ RETVAL_STR(bc_num2str(result));
break;
case -1:
php_error_docref(NULL TSRMLS_CC, E_WARNING, "Division by zero");
@@ -427,9 +417,7 @@ PHP_FUNCTION(bcpowmod)
if (result->n_scale > scale) {
result->n_scale = scale;
}
- Z_STRVAL_P(return_value) = bc_num2str(result);
- Z_STRLEN_P(return_value) = strlen(Z_STRVAL_P(return_value));
- Z_TYPE_P(return_value) = IS_STRING;
+ RETVAL_STR(bc_num2str(result));
} else {
RETVAL_FALSE;
}
@@ -471,9 +459,7 @@ PHP_FUNCTION(bcpow)
result->n_scale = scale;
}
- Z_STRVAL_P(return_value) = bc_num2str(result);
- Z_STRLEN_P(return_value) = strlen(Z_STRVAL_P(return_value));
- Z_TYPE_P(return_value) = IS_STRING;
+ RETVAL_STR(bc_num2str(result));
bc_free_num(&first);
bc_free_num(&second);
bc_free_num(&result);
@@ -506,9 +492,7 @@ PHP_FUNCTION(bcsqrt)
if (result->n_scale > scale) {
result->n_scale = scale;
}
- Z_STRVAL_P(return_value) = bc_num2str(result);
- Z_STRLEN_P(return_value) = strlen(Z_STRVAL_P(return_value));
- Z_TYPE_P(return_value) = IS_STRING;
+ RETVAL_STR(bc_num2str(result));
} else {
php_error_docref(NULL TSRMLS_CC, E_WARNING, "Square root of negative number");
}
@@ -541,8 +525,7 @@ PHP_FUNCTION(bccomp)
bc_str2num(&first, left, scale TSRMLS_CC);
bc_str2num(&second, right, scale TSRMLS_CC);
- Z_LVAL_P(return_value) = bc_compare(first, second);
- Z_TYPE_P(return_value) = IS_LONG;
+ RETVAL_LONG(bc_compare(first, second));
bc_free_num(&first);
bc_free_num(&second);