helly           Wed Feb 13 12:01:16 2008 UTC

  Added files:                 
    /php-src/ext/spl/tests      dit_002.phpt 

  Modified files:              
    /php-src/ext/spl    spl.php spl_directory.c spl_directory.h 
  Log:
  - Make this behave like in <= 5.2.5 and test for it
  
  
http://cvs.php.net/viewvc.cgi/php-src/ext/spl/spl.php?r1=1.83&r2=1.84&diff_format=u
Index: php-src/ext/spl/spl.php
diff -u php-src/ext/spl/spl.php:1.83 php-src/ext/spl/spl.php:1.84
--- php-src/ext/spl/spl.php:1.83        Mon Feb  4 21:37:43 2008
+++ php-src/ext/spl/spl.php     Wed Feb 13 12:01:16 2008
@@ -1030,8 +1030,8 @@
  */
 class RecursiveDirectoryIterator extends DirectoryIterator implements 
RecursiveIterator
 {
-       const CURRENT_AS_SELF       0x00000000; /* make 
RecursiveDirectoryTree::current() return getSelf() */
-       const CURRENT_AS_FILEINFO   0x00000010; /* make 
RecursiveDirectoryTree::current() return SplFileInfo */
+       const CURRENT_AS_FILEINFO   0x00000000; /* make 
RecursiveDirectoryTree::current() return SplFileInfo */
+       const CURRENT_AS_SELF       0x00000010; /* make 
RecursiveDirectoryTree::current() return getSelf() */
        const CURRENT_AS_PATHNAME   0x00000020; /* make 
RecursiveDirectoryTree::current() return getPathname() */
 
        const KEY_AS_PATHNAME       0x00000000; /* make 
RecursiveDirectoryTree::key() return getPathname() */
http://cvs.php.net/viewvc.cgi/php-src/ext/spl/spl_directory.c?r1=1.148&r2=1.149&diff_format=u
Index: php-src/ext/spl/spl_directory.c
diff -u php-src/ext/spl/spl_directory.c:1.148 
php-src/ext/spl/spl_directory.c:1.149
--- php-src/ext/spl/spl_directory.c:1.148       Mon Feb  4 19:39:07 2008
+++ php-src/ext/spl/spl_directory.c     Wed Feb 13 12:01:16 2008
@@ -16,7 +16,7 @@
    +----------------------------------------------------------------------+
  */
 
-/* $Id: spl_directory.c,v 1.148 2008/02/04 19:39:07 helly Exp $ */
+/* $Id: spl_directory.c,v 1.149 2008/02/13 12:01:16 helly Exp $ */
 
 #ifdef HAVE_CONFIG_H
 # include "config.h"
@@ -602,7 +602,7 @@
        php_set_error_handling(EH_THROW, spl_ce_RuntimeException TSRMLS_CC);
 
        if (ctor_flags & DIT_CTOR_FLAGS) {
-               flags = 0;
+               flags = 
SPL_FILE_DIR_KEY_AS_PATHNAME|SPL_FILE_DIR_CURRENT_AS_FILEINFO;
                parsed = zend_parse_parameters(ZEND_NUM_ARGS() TSRMLS_CC, 
"t|l", &path, &len, &path_type, &flags);
        } else {
                flags = 
SPL_FILE_DIR_KEY_AS_PATHNAME|SPL_FILE_DIR_CURRENT_AS_SELF;
@@ -1214,6 +1214,28 @@
 }
 /* }}} */
 
+/* {{{ proto int FilesystemIterator::getFlags() U
+   Get handling flags */
+SPL_METHOD(FilesystemIterator, getFlags)
+{
+       spl_filesystem_object *intern = 
(spl_filesystem_object*)zend_object_store_get_object(getThis() TSRMLS_CC);
+
+       RETURN_LONG(intern->flags);
+} /* }}} */
+
+/* {{{ proto void FilesystemIterator::setFlags(long $flags) U
+   Set handling flags */
+SPL_METHOD(FilesystemIterator, setFlags)
+{
+       spl_filesystem_object *intern = 
(spl_filesystem_object*)zend_object_store_get_object(getThis() TSRMLS_CC);
+       long flags;
+
+       zend_parse_parameters(ZEND_NUM_ARGS() TSRMLS_CC, "l", &flags);
+
+       intern->flags &= 
~(SPL_FILE_DIR_KEY_MODE_MASK|SPL_FILE_DIR_CURRENT_MODE_MASK);
+       intern->flags |= 
((SPL_FILE_DIR_KEY_MODE_MASK|SPL_FILE_DIR_CURRENT_MODE_MASK) & flags);
+} /* }}} */
+
 /* {{{ proto bool RecursiveDirectoryIterator::hasChildren([bool $allow_links = 
false]) U
    Returns whether current entry is a directory and not '.' or '..' */
 SPL_METHOD(RecursiveDirectoryIterator, hasChildren)
@@ -1703,12 +1725,19 @@
        ZEND_ARG_INFO(0, allow_links)
 ZEND_END_ARG_INFO()
 
+static
+ZEND_BEGIN_ARG_INFO_EX(arginfo_r_dir_setFlags, 0, 0, 0)
+       ZEND_ARG_INFO(0, flags)
+ZEND_END_ARG_INFO()
+
 static const zend_function_entry spl_FilesystemIterator_functions[] = {
        SPL_ME(FilesystemIterator, __construct,   arginfo_r_dir___construct, 
ZEND_ACC_PUBLIC)
        SPL_ME(FilesystemIterator, rewind,        NULL, ZEND_ACC_PUBLIC)
        SPL_ME(FilesystemIterator, next,          NULL, ZEND_ACC_PUBLIC)
        SPL_ME(FilesystemIterator, key,           NULL, ZEND_ACC_PUBLIC)
        SPL_ME(FilesystemIterator, current,       NULL, ZEND_ACC_PUBLIC)
+       SPL_ME(FilesystemIterator, getFlags,      NULL, ZEND_ACC_PUBLIC)
+       SPL_ME(FilesystemIterator, setFlags,      arginfo_r_dir_setFlags, 
ZEND_ACC_PUBLIC)
        {NULL, NULL, NULL}
 };
 
http://cvs.php.net/viewvc.cgi/php-src/ext/spl/spl_directory.h?r1=1.41&r2=1.42&diff_format=u
Index: php-src/ext/spl/spl_directory.h
diff -u php-src/ext/spl/spl_directory.h:1.41 
php-src/ext/spl/spl_directory.h:1.42
--- php-src/ext/spl/spl_directory.h:1.41        Mon Feb  4 21:37:43 2008
+++ php-src/ext/spl/spl_directory.h     Wed Feb 13 12:01:16 2008
@@ -16,7 +16,7 @@
    +----------------------------------------------------------------------+
  */
 
-/* $Id: spl_directory.h,v 1.41 2008/02/04 21:37:43 helly Exp $ */
+/* $Id: spl_directory.h,v 1.42 2008/02/13 12:01:16 helly Exp $ */
 
 #ifndef SPL_DIRECTORY_H
 #define SPL_DIRECTORY_H
@@ -118,8 +118,8 @@
 #define SPL_FILE_OBJECT_SKIP_EMPTY         0x00000006 /* skip empty lines */
 #define SPL_FILE_OBJECT_READ_CSV           0x00000008 /* read via fgetcsv */
 
-#define SPL_FILE_DIR_CURRENT_AS_SELF       0x00000000 /* make 
RecursiveDirectoryTree::current() return getSelf() */
-#define SPL_FILE_DIR_CURRENT_AS_FILEINFO   0x00000010 /* make 
RecursiveDirectoryTree::current() return SplFileInfo */
+#define SPL_FILE_DIR_CURRENT_AS_FILEINFO   0x00000000 /* make 
RecursiveDirectoryTree::current() return SplFileInfo */
+#define SPL_FILE_DIR_CURRENT_AS_SELF       0x00000010 /* make 
RecursiveDirectoryTree::current() return getSelf() */
 #define SPL_FILE_DIR_CURRENT_AS_PATHNAME   0x00000020 /* make 
RecursiveDirectoryTree::current() return getPathname() */
 #define SPL_FILE_DIR_CURRENT_MODE_MASK     0x000000F0 /* mask 
RecursiveDirectoryTree::current() */
 #define SPL_FILE_DIR_CURRENT(intern,mode)  
((intern->flags&SPL_FILE_DIR_CURRENT_MODE_MASK)==mode)

http://cvs.php.net/viewvc.cgi/php-src/ext/spl/tests/dit_002.phpt?view=markup&rev=1.1
Index: php-src/ext/spl/tests/dit_002.phpt
+++ php-src/ext/spl/tests/dit_002.phpt
--TEST--
SPL: DirectoryIterator defaults
--SKIPIF--
<?php if (!extension_loaded("spl")) print "skip"; ?>
--FILE--
<?php

$classes = array(
        'DirectoryIterator' => 0,
        'FilesystemIterator' => 1,
        'RecursiveDirectoryIterator' => 1,
        'GlobIterator' => 1,
);

foreach ($classes as $class => $flags) {
        echo "===$class===\n";
        $ref = new ReflectionClass($class);
        $obj = $ref->newInstance('glob://*');
        echo get_class($obj->current()) . "\n";
        if ($flags)
        {
                var_dump($obj->getFlags());
                $flags = array(
                        FilesystemIterator::CURRENT_AS_FILEINFO => 0,
                        FilesystemIterator::CURRENT_AS_SELF     => 0,
                        FilesystemIterator::CURRENT_AS_PATHNAME => 1,
                );
                foreach($flags as $flag => $isstring) {
                        $obj->setFlags($flag);
                        $obj->rewind();
                        var_dump($obj->getFlags());
                        if ($isstring) {
                                $val = $obj->current();
                                if (is_string($val) || is_unicode($val)) {
                                        var_dump(true);
                                } else {
                                        var_dump($val);
                                }
                        } else {
                                echo get_class($obj->current()) . "\n";
                        }
                }
        }
}
?>
===DONE===
--EXPECT--
===DirectoryIterator===
DirectoryIterator
===FilesystemIterator===
SplFileInfo
int(0)
int(0)
SplFileInfo
int(16)
FilesystemIterator
int(32)
bool(true)
===RecursiveDirectoryIterator===
SplFileInfo
int(0)
int(0)
SplFileInfo
int(16)
RecursiveDirectoryIterator
int(32)
bool(true)
===GlobIterator===
SplFileInfo
int(0)
int(0)
SplFileInfo
int(16)
GlobIterator
int(32)
bool(true)
===DONE===

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

Reply via email to