summaryrefslogtreecommitdiff
path: root/Zend/zend_operators.c
diff options
context:
space:
mode:
authorMarcus Boerger <helly@php.net>2003-09-18 11:50:05 +0000
committerMarcus Boerger <helly@php.net>2003-09-18 11:50:05 +0000
commit71ba442768e53a5940100f87044840d68dc4fda9 (patch)
treedee3f281f2eb7fc34a80550832d26026ae892cc5 /Zend/zend_operators.c
parentd7fdf15a413de33953a2060b22c58b87f2f06abb (diff)
downloadphp-git-71ba442768e53a5940100f87044840d68dc4fda9.tar.gz
Fallback to default behaviour for unsupported object type conversions
Diffstat (limited to 'Zend/zend_operators.c')
-rw-r--r--Zend/zend_operators.c32
1 files changed, 18 insertions, 14 deletions
diff --git a/Zend/zend_operators.c b/Zend/zend_operators.c
index 8f3b73fcdc..60ac369320 100644
--- a/Zend/zend_operators.c
+++ b/Zend/zend_operators.c
@@ -297,11 +297,12 @@ ZEND_API void convert_to_long_base(zval *op, int base)
case IS_OBJECT:
if (op->value.obj.handlers->cast_object) {
TSRMLS_FETCH();
- op->value.obj.handlers->cast_object(op, op, IS_LONG, 1 TSRMLS_CC);
- } else {
- zval_dtor(op);
- op->value.lval = 1;
+ if (op->value.obj.handlers->cast_object(op, op, IS_LONG, 1 TSRMLS_CC) == SUCCESS) {
+ break;
+ }
}
+ zval_dtor(op);
+ op->value.lval = 1;
break;
default:
zend_error(E_WARNING, "Cannot convert to ordinal value");
@@ -349,11 +350,12 @@ ZEND_API void convert_to_double(zval *op)
case IS_OBJECT:
if (op->value.obj.handlers->cast_object) {
TSRMLS_FETCH();
- op->value.obj.handlers->cast_object(op, op, IS_DOUBLE, 1 TSRMLS_CC);
- } else {
- zval_dtor(op);
- op->value.dval = 1; /* TBI!! */
+ if (op->value.obj.handlers->cast_object(op, op, IS_DOUBLE, 1 TSRMLS_CC) == SUCCESS) {
+ break;
+ }
}
+ zval_dtor(op);
+ op->value.dval = 1; /* TBI!! */
break;
default:
zend_error(E_WARNING, "Cannot convert to real value (type=%d)", op->type);
@@ -370,8 +372,9 @@ ZEND_API void convert_to_null(zval *op)
if (op->type == IS_OBJECT) {
if (op->value.obj.handlers->cast_object) {
TSRMLS_FETCH();
- op->value.obj.handlers->cast_object(op, op, IS_NULL, 1 TSRMLS_CC);
- return;
+ if (op->value.obj.handlers->cast_object(op, op, IS_NULL, 1 TSRMLS_CC) == SUCCESS) {
+ return;
+ }
}
}
@@ -422,11 +425,12 @@ ZEND_API void convert_to_boolean(zval *op)
case IS_OBJECT:
if (op->value.obj.handlers->cast_object) {
TSRMLS_FETCH();
- op->value.obj.handlers->cast_object(op, op, IS_BOOL, 1 TSRMLS_CC);
- } else {
- zval_dtor(op);
- op->value.lval = 1; /* TBI!! */
+ if (op->value.obj.handlers->cast_object(op, op, IS_BOOL, 1 TSRMLS_CC) == SUCCESS) {
+ break;
+ }
}
+ zval_dtor(op);
+ op->value.lval = 1; /* TBI!! */
break;
default:
zval_dtor(op);