helly           Sat Nov 22 15:46:46 2003 EDT

  Modified files:              
    /spl        spl_directory.c 
  Log:
  - current() returns self
  - add __toString() casting
  
  
Index: spl/spl_directory.c
diff -u spl/spl_directory.c:1.13 spl/spl_directory.c:1.14
--- spl/spl_directory.c:1.13    Tue Nov 18 17:14:19 2003
+++ spl/spl_directory.c Sat Nov 22 15:46:46 2003
@@ -16,7 +16,7 @@
    +----------------------------------------------------------------------+
  */
 
-/* $Id: spl_directory.c,v 1.13 2003/11/18 22:14:19 helly Exp $ */
+/* $Id: spl_directory.c,v 1.14 2003/11/22 20:46:46 helly Exp $ */
 
 #ifdef HAVE_CONFIG_H
 # include "config.h"
@@ -292,18 +292,11 @@
 }
 /* }}} */
 
-/* {{{ proto string|false DirectoryIterator::current()
+/* {{{ proto DirectoryIterator DirectoryIterator::current()
    Return this (needed for Iterator interface) */
 SPL_METHOD(DirectoryIterator, current)
 {
-       zval *object = getThis();
-       spl_ce_dir_object *intern = 
(spl_ce_dir_object*)zend_object_store_get_object(object TSRMLS_CC);
-
-       if (intern->entry.d_name[0]) {
-               RETURN_STRING(intern->entry.d_name, 1);
-       } else {
-               RETURN_FALSE;
-       }
+       REPLACE_ZVAL_VALUE(&return_value, getThis(), 1);
 }
 /* }}} */
 
@@ -518,7 +511,8 @@
        object->refcount++;
        iterator->intern.data = (void*)object;
        iterator->intern.funcs = &spl_ce_dir_it_funcs;
-       MAKE_STD_ZVAL(iterator->current);
+       iterator->current = object;
+       object->refcount++;
        iterator->object = dir_object;
        
        return (zend_object_iterator*)iterator;
@@ -580,12 +574,8 @@
        spl_ce_dir_object   *object   = iterator->object;
        
        object->index++;
-       zval_dtor(iterator->current);
        if (!object->dirp || !php_stream_readdir(object->dirp, &object->entry)) {
                object->entry.d_name[0] = '\0';
-               ZVAL_NULL(iterator->current);
-       } else {
-               ZVAL_STRING(iterator->current, object->entry.d_name, 1);
        }
 }
 /* }}} */
@@ -601,12 +591,8 @@
        if (object->dirp) {
                php_stream_rewinddir(object->dirp);
        }
-       zval_dtor(iterator->current);
        if (!object->dirp || !php_stream_readdir(object->dirp, &object->entry)) {
                object->entry.d_name[0] = '\0';
-               ZVAL_NULL(iterator->current);
-       } else {
-               ZVAL_STRING(iterator->current, object->entry.d_name, 1);
        }
 }
 /* }}} */
@@ -684,6 +670,25 @@
 }
 /* }}} */
 
+/* {{{ spl_ce_dir_cast */
+static int spl_ce_dir_cast(zval *readobj, zval *writeobj, int type, int should_free 
TSRMLS_DC)
+{
+       zval free_obj;
+       spl_ce_dir_object   *dir_object = 
(spl_ce_dir_object*)zend_object_store_get_object(readobj TSRMLS_CC);
+
+       if (type ==IS_STRING && *dir_object->entry.d_name) {
+               if (should_free) {
+                       free_obj = *writeobj;
+               }
+               ZVAL_STRING(writeobj, dir_object->entry.d_name, 1);
+               if (should_free) {
+                       zval_dtor(&free_obj);
+               }
+               return SUCCESS;
+       }
+       return FAILURE;
+}
+/* }}} */
 
 /* {{{ PHP_MINIT_FUNCTION(spl_directory)
  */
@@ -693,6 +698,7 @@
        zend_class_implements(spl_ce_DirectoryIterator TSRMLS_CC, 1, zend_ce_iterator);
        memcpy(&spl_ce_dir_handlers, zend_get_std_object_handlers(), 
sizeof(zend_object_handlers));
        spl_ce_dir_handlers.clone_obj = spl_ce_dir_object_clone;
+       spl_ce_dir_handlers.cast_object = spl_ce_dir_cast;
 
        spl_ce_DirectoryIterator->get_iterator = spl_ce_dir_get_iterator;
 

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

Reply via email to