dmitry          Wed Aug 17 07:36:32 2005 EDT

  Modified files:              
    /php-src/ext/simplexml/tests        004.phpt 
    /php-src/ext/standard       string.c 
    /php-src/tests/classes      tostring.phpt 
    /php-src/tests/reflection   005.phpt 
  Log:
  trim() should accept objects with __toString() method
  
  
http://cvs.php.net/diff.php/php-src/ext/simplexml/tests/004.phpt?r1=1.6&r2=1.7&ty=u
Index: php-src/ext/simplexml/tests/004.phpt
diff -u php-src/ext/simplexml/tests/004.phpt:1.6 
php-src/ext/simplexml/tests/004.phpt:1.7
--- php-src/ext/simplexml/tests/004.phpt:1.6    Mon Mar 29 14:58:01 2004
+++ php-src/ext/simplexml/tests/004.phpt        Wed Aug 17 07:36:28 2005
@@ -63,3 +63,33 @@
 )
 string(11) "CDATA block"
 ===DONE===
+--UEXPECT--
+SimpleXMLElement Object
+(
+    [elem1] => SimpleXMLElement Object
+        (
+            [comment] => SimpleXMLElement Object
+                (
+                )
+
+            [elem2] => SimpleXMLElement Object
+                (
+                    [elem3] => SimpleXMLElement Object
+                        (
+                            [elem4] => SimpleXMLElement Object
+                                (
+                                    [test] => SimpleXMLElement Object
+                                        (
+                                        )
+
+                                )
+
+                        )
+
+                )
+
+        )
+
+)
+unicode(11) "CDATA block"
+===DONE===
http://cvs.php.net/diff.php/php-src/ext/standard/string.c?r1=1.460&r2=1.461&ty=u
Index: php-src/ext/standard/string.c
diff -u php-src/ext/standard/string.c:1.460 php-src/ext/standard/string.c:1.461
--- php-src/ext/standard/string.c:1.460 Wed Aug 17 06:26:02 2005
+++ php-src/ext/standard/string.c       Wed Aug 17 07:36:30 2005
@@ -18,7 +18,7 @@
    +----------------------------------------------------------------------+
  */
 
-/* $Id: string.c,v 1.460 2005/08/17 10:26:02 rolland Exp $ */
+/* $Id: string.c,v 1.461 2005/08/17 11:36:30 dmitry Exp $ */
 
 /* Synced with php 3.0 revision 1.193 1999-06-16 [ssb] */
 
@@ -737,30 +737,31 @@
  */
 static void php_do_trim(INTERNAL_FUNCTION_PARAMETERS, int mode)
 {
-       void            *str;
-       int32_t         str_len;
-       zend_uchar      str_type;
-       void            *what;
-       int32_t         what_len;
-       zend_uchar      what_type;
-       int                     argc = ZEND_NUM_ARGS();
+       zval **str, **what;
+       int  argc = ZEND_NUM_ARGS();
 
-       if ( zend_parse_parameters(argc TSRMLS_CC, "T|T", &str, &str_len, 
&str_type,
-                                                                 &what, 
&what_len, &what_type) == FAILURE ) {
-               return;
+       if (argc < 1 || argc > 2 || zend_get_parameters_ex(argc, &str, &what) 
== FAILURE) {
+               WRONG_PARAM_COUNT;
        }
 
-       if ( argc > 1 ) {
-               if ( str_type == IS_UNICODE ) {
-                       php_u_trim(str, str_len, what, what_len, return_value, 
mode TSRMLS_CC);
+       convert_to_text_ex(str);
+
+       if (argc > 1) {
+               if (Z_TYPE_PP(str) != Z_TYPE_PP(what)) {
+                       zend_error(E_WARNING, "%v() expects parameter 2 to be 
string (legacy, Unicode, or binary), %s given",
+                                       get_active_function_name(TSRMLS_C),
+                                       zend_zval_type_name(*what));
+               }
+               if (Z_TYPE_PP(str) == IS_UNICODE) {
+                       php_u_trim(Z_USTRVAL_PP(str), Z_USTRLEN_PP(str), 
Z_USTRVAL_PP(what), Z_USTRLEN_PP(what), return_value, mode TSRMLS_CC);
                } else {
-                       php_trim(str, str_len, what, what_len, str_type, 
return_value, mode TSRMLS_CC);
+                       php_trim(Z_STRVAL_PP(str), Z_STRLEN_PP(str), 
Z_STRVAL_PP(what), Z_STRLEN_PP(what), Z_TYPE_PP(str), return_value, mode 
TSRMLS_CC);
                }
        } else {
-               if ( str_type == IS_UNICODE ) {
-                       php_u_trim(str, str_len, NULL, 0, return_value, mode 
TSRMLS_CC);
+               if (Z_TYPE_PP(str) == IS_UNICODE) {
+                       php_u_trim(Z_USTRVAL_PP(str), Z_USTRLEN_PP(str), NULL, 
0, return_value, mode TSRMLS_CC);
                } else {
-                       php_trim(str, str_len, NULL, 0, str_type, return_value, 
mode TSRMLS_CC);
+                       php_trim(Z_STRVAL_PP(str), Z_STRLEN_PP(str), NULL, 0, 
Z_TYPE_PP(str), return_value, mode TSRMLS_CC);
                }
        }
 }
http://cvs.php.net/diff.php/php-src/tests/classes/tostring.phpt?r1=1.5&r2=1.6&ty=u
Index: php-src/tests/classes/tostring.phpt
diff -u php-src/tests/classes/tostring.phpt:1.5 
php-src/tests/classes/tostring.phpt:1.6
--- php-src/tests/classes/tostring.phpt:1.5     Sun Mar 28 09:09:47 2004
+++ php-src/tests/classes/tostring.phpt Wed Aug 17 07:36:32 2005
@@ -84,3 +84,36 @@
 string(1%d) "Object id #%d"
 ====test9====
 Object id #%d====DONE!====
+--UEXPECTF--
+====test1====
+test1 Object
+(
+)
+string(1%d) "Object id #%d"
+object(test1)#%d (%d) {
+}
+====test2====
+test2 Object
+(
+)
+test2::__toString()
+Converted
+object(test2)#%d (%d) {
+}
+====test3====
+test2::__toString()
+Converted
+====test4====
+string:Object id #%d====test5====
+1Object id #%d====test6====
+Object id #%dObject id #2====test7====
+test2::__toString()
+
+Warning: Illegal offset type in %stostring.php on line %d
+====test8====
+
+Notice: Object of class test2 to string conversion in %stostring.php on line %d
+unicode(6) "Object"
+unicode(1%d) "Object id #%d"
+====test9====
+Object id #%d====DONE!====
http://cvs.php.net/diff.php/php-src/tests/reflection/005.phpt?r1=1.1&r2=1.2&ty=u
Index: php-src/tests/reflection/005.phpt
diff -u php-src/tests/reflection/005.phpt:1.1 
php-src/tests/reflection/005.phpt:1.2
--- php-src/tests/reflection/005.phpt:1.1       Sun Feb 13 08:50:30 2005
+++ php-src/tests/reflection/005.phpt   Wed Aug 17 07:36:32 2005
@@ -52,3 +52,10 @@
 bool(false)
 string(22) "* Comment for A::baz()"
 ===DONE===
+--UEXPECT--
+unicode(19) "Comment for class A"
+unicode(15) "Method A::bla()"
+bool(false)
+bool(false)
+unicode(22) "* Comment for A::baz()"
+===DONE===

-- 
PHP CVS Mailing List (http://www.php.net/)
To unsubscribe, visit: http://www.php.net/unsub.php

Reply via email to