summaryrefslogtreecommitdiff
diff options
context:
space:
mode:
authorXinchen Hui <laruence@php.net>2012-08-12 10:40:41 +0800
committerXinchen Hui <laruence@php.net>2012-08-12 10:40:41 +0800
commitd11fa44d626809f1160cafdaddd73d4c45516a2c (patch)
tree55f1fccfd6528499e7c8833fcdfdb0548b1ea60a
parent66a6d1b97b682a37e0d1f2654d7dcbe2eabbbcc7 (diff)
parent222ab9da1aa086a47279d29c16a8ebea514257fe (diff)
downloadphp-git-d11fa44d626809f1160cafdaddd73d4c45516a2c.tar.gz
Merge branch 'Bug-62328' of https://github.com/leight/php-src
-rw-r--r--Zend/tests/bug62328.phpt22
-rw-r--r--Zend/zend.c6
2 files changed, 28 insertions, 0 deletions
diff --git a/Zend/tests/bug62328.phpt b/Zend/tests/bug62328.phpt
new file mode 100644
index 0000000000..c56ddc2c69
--- /dev/null
+++ b/Zend/tests/bug62328.phpt
@@ -0,0 +1,22 @@
+--TEST--
+Bug #62328 (cast_object takes precedence over __toString)
+--FILE--
+<?php
+
+class SplFileInfo62328 extends SplFileInfo
+{
+ public function __toString()
+ {
+ return '__toString';
+ }
+}
+
+$fi = new SplFileInfo62328(__FILE__);
+
+echo (string)$fi . PHP_EOL;
+echo (string)$fi->__toString() . PHP_EOL;
+
+?>
+--EXPECT--
+__toString
+__toString
diff --git a/Zend/zend.c b/Zend/zend.c
index 18c4f11604..be30e92e7d 100644
--- a/Zend/zend.c
+++ b/Zend/zend.c
@@ -258,6 +258,12 @@ ZEND_API void zend_make_printable_zval(zval *expr, zval *expr_copy, int *use_cop
{
TSRMLS_FETCH();
+ if (Z_OBJCE_P(expr)->__tostring) {
+ if (zend_std_cast_object_tostring(expr, expr_copy, IS_STRING TSRMLS_CC) == SUCCESS) {
+ break;
+ }
+ }
+
if (Z_OBJ_HANDLER_P(expr, cast_object)) {
zval *val;