summaryrefslogtreecommitdiff
path: root/Zend/zend.c
diff options
context:
space:
mode:
authorMarcus Boerger <helly@php.net>2003-11-08 14:06:08 +0000
committerMarcus Boerger <helly@php.net>2003-11-08 14:06:08 +0000
commit316854323d63ed98cb0ce289a5ffd17f9ee938d0 (patch)
treef70748696fd9420dd73445493f3dccf5e05b9759 /Zend/zend.c
parented451570470ebaf24ffe2a2d20403c6749d32318 (diff)
downloadphp-git-316854323d63ed98cb0ce289a5ffd17f9ee938d0.tar.gz
Handle exceptions in casting more gracefully.
This fixes bug #26166
Diffstat (limited to 'Zend/zend.c')
-rw-r--r--Zend/zend.c6
1 files changed, 6 insertions, 0 deletions
diff --git a/Zend/zend.c b/Zend/zend.c
index 2e5d37cfc8..fe0070d4aa 100644
--- a/Zend/zend.c
+++ b/Zend/zend.c
@@ -230,6 +230,12 @@ ZEND_API void zend_make_printable_zval(zval *expr, zval *expr_copy, int *use_cop
if (expr->value.obj.handlers->cast_object(expr, expr_copy, IS_STRING, 0 TSRMLS_CC) == SUCCESS) {
break;
}
+ if (EG(exception)) {
+ zval_dtor(expr_copy);
+ expr_copy->value.str.len = 0;
+ expr_copy->value.str.val = empty_string;
+ 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);