summaryrefslogtreecommitdiff
diff options
context:
space:
mode:
-rw-r--r--Zend/zend.c9
-rw-r--r--Zend/zend_operators.c32
2 files changed, 23 insertions, 18 deletions
diff --git a/Zend/zend.c b/Zend/zend.c
index f78c922742..407b76b915 100644
--- a/Zend/zend.c
+++ b/Zend/zend.c
@@ -227,11 +227,12 @@ ZEND_API void zend_make_printable_zval(zval *expr, zval *expr_copy, int *use_cop
case IS_OBJECT:
if (expr->value.obj.handlers->cast_object) {
TSRMLS_FETCH();
- expr->value.obj.handlers->cast_object(expr, expr_copy, IS_STRING, 0 TSRMLS_CC);
- } else {
- expr_copy->value.str.val = (char *) emalloc(sizeof("Object id #")-1 + MAX_LENGTH_OF_LONG);
- expr_copy->value.str.len = sprintf(expr_copy->value.str.val, "Object id #%ld", (long)expr->value.obj.handle);
+ if (expr->value.obj.handlers->cast_object(expr, expr_copy, IS_STRING, 0 TSRMLS_CC) == SUCCESS) {
+ break;
+ }
}
+ expr_copy->value.str.val = (char *) emalloc(sizeof("Object id #")-1 + MAX_LENGTH_OF_LONG);
+ expr_copy->value.str.len = sprintf(expr_copy->value.str.val, "Object id #%ld", (long)expr->value.obj.handle);
#if 0
/* FIXME: This might break BC for some people */
expr_copy->value.str.len = sizeof("Object")-1;
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);