diff options
| author | Marcus Boerger <helly@php.net> | 2003-09-18 11:50:05 +0000 |
|---|---|---|
| committer | Marcus Boerger <helly@php.net> | 2003-09-18 11:50:05 +0000 |
| commit | 71ba442768e53a5940100f87044840d68dc4fda9 (patch) | |
| tree | dee3f281f2eb7fc34a80550832d26026ae892cc5 /Zend/zend_operators.c | |
| parent | d7fdf15a413de33953a2060b22c58b87f2f06abb (diff) | |
| download | php-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.c | 32 |
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); |
