iliaa           Mon Jan 27 15:39:31 2003 EDT

  Added files:                 
    /php4/main  php_scandir.c php_scandir.h 

  Modified files:              
    /php4/win32 readdir.h readdir.c 
    /php4       configure.in 
    /php4/main  php_ini.c 
  Log:
  Moved the scandir code into it's own files so that it can be used by other
  OSes where libc does not have a native scandir() implementation.
  
  
Index: php4/win32/readdir.h
diff -u php4/win32/readdir.h:1.7 php4/win32/readdir.h:1.8
--- php4/win32/readdir.h:1.7    Sat Jan 25 20:39:18 2003
+++ php4/win32/readdir.h        Mon Jan 27 15:39:30 2003
@@ -39,10 +39,5 @@
 int readdir_r(DIR *, struct dirent *, struct dirent **);
 int closedir(DIR *);
 int rewinddir(DIR *);
-int scandir(const char *dirname,
-                       struct dirent **namelist[],
-                       int (*selector) (const struct dirent *entry),
-                       int (*compare) (const struct dirent **a, const struct dirent 
**b));
-int alphasort(const struct dirent **a, const struct dirent **b);
 
 #endif /* READDIR_H */
Index: php4/win32/readdir.c
diff -u php4/win32/readdir.c:1.9 php4/win32/readdir.c:1.10
--- php4/win32/readdir.c:1.9    Sat Jan 25 20:39:18 2003
+++ php4/win32/readdir.c        Mon Jan 27 15:39:30 2003
@@ -141,83 +141,3 @@
 
 return 0;
 }
-
-int alphasort(const struct dirent **a, const struct dirent **b)
-{
-       return strcoll((*a)->d_name,(*b)->d_name);
-}
-
-int scandir(const char *dirname,
-                       struct dirent **namelist[],
-                       int (*selector) (const struct dirent *entry),
-                       int (*compare) (const struct dirent **a, const struct dirent 
**b))
-{
-       DIR *dirp = NULL;
-       struct dirent **vector = NULL;
-       struct dirent *dp = NULL;
-       int vector_size = 0;
-
-       int nfiles = 0;
-       int fail = 0;
-
-       if (namelist == NULL)
-               return -1;
-
-       dirp = opendir(dirname);
-       if (dirp == NULL)
-               return -1;
-
-       for (dp = readdir(dirp); dp != NULL; dp = readdir(dirp))
-       {
-               int dsize = 0;
-               struct dirent *newdp = NULL;
-
-               if (selector && (*selector)(dp) == 0)
-                       continue;
-
-               if (nfiles == vector_size)
-               {
-                       struct dirent **newv;
-                       if (vector_size == 0)
-                               vector_size = 10;
-                       else
-                               vector_size *= 2;
-
-                       newv = (struct dirent **) realloc (vector, vector_size * 
sizeof (struct dirent *));
-                       if (newv == NULL)
-                       {
-                               fail = 1;
-                               break;
-                       }
-                       vector = newv;
-               }
-
-               dsize = sizeof (struct dirent) + ((strlen(dp->d_name) + 1) * 
sizeof(char));
-               newdp = (struct dirent *) malloc(dsize);
-
-               if (newdp == NULL)
-               {
-                       fail = 1;
-                       break;
-               }
-
-               vector[nfiles++] = (struct dirent *) memcpy(newdp, dp, dsize);
-       }
-
-       closedir(dirp);
-
-       if (fail)
-       {
-               while (nfiles-- > 0) free(vector[nfiles]);
-               free(vector);
-               return -1;
-       }
-
-
-       *namelist = vector;
-
-       if (compare)
-               qsort (*namelist,nfiles,sizeof (struct dirent *),compare);
-
-       return nfiles;
-}
Index: php4/configure.in
diff -u php4/configure.in:1.415 php4/configure.in:1.416
--- php4/configure.in:1.415     Thu Jan 23 01:42:43 2003
+++ php4/configure.in   Mon Jan 27 15:39:30 2003
@@ -1,4 +1,4 @@
-dnl ## $Id: configure.in,v 1.415 2003/01/23 06:42:43 sniper Exp $ -*- sh -*-
+dnl ## $Id: configure.in,v 1.416 2003/01/27 20:39:30 iliaa Exp $ -*- sh -*-
 dnl ## Process this file with autoconf to produce a configure script.
 
 divert(1)
@@ -445,6 +445,7 @@
 
 AC_FUNC_VPRINTF
 AC_CHECK_FUNCS(
+alphasort \
 asctime_r \
 chroot \
 ctime_r \
@@ -480,6 +481,7 @@
 rand_r \
 regcomp \
 res_search \
+scandir \
 setitimer \
 setlocale \
 localeconv \
@@ -1093,7 +1095,7 @@
 PHP_ADD_SOURCES(TSRM, TSRM.c tsrm_strtok_r.c tsrm_virtual_cwd.c)
 
 PHP_ADD_SOURCES(main, main.c snprintf.c spprintf.c php_sprintf.c \
-       safe_mode.c fopen_wrappers.c alloca.c \
+       safe_mode.c fopen_wrappers.c alloca.c  php_scandir.c \
        php_ini.c SAPI.c rfc1867.c php_content_types.c strlcpy.c \
        strlcat.c mergesort.c reentrancy.c php_variables.c php_ticks.c \
        streams.c network.c php_open_temporary_file.c php_logos.c \
Index: php4/main/php_ini.c
diff -u php4/main/php_ini.c:1.111 php4/main/php_ini.c:1.112
--- php4/main/php_ini.c:1.111   Sat Jan 25 20:39:18 2003
+++ php4/main/php_ini.c Mon Jan 27 15:39:30 2003
@@ -16,7 +16,7 @@
    +----------------------------------------------------------------------+
  */
 
-/* $Id: php_ini.c,v 1.111 2003/01/26 01:39:18 shane Exp $ */
+/* $Id: php_ini.c,v 1.112 2003/01/27 20:39:30 iliaa Exp $ */
 
 /* Check CWD for php.ini */
 #define INI_CHECK_CWD
@@ -31,12 +31,10 @@
 #include "SAPI.h"
 #include "php_main.h"
 
-#ifdef PHP_WIN32
-#include "readdir.h"
-/* this makes no sence, vc6 errors if this declaration is not here */
-extern int alphasort(const struct dirent **a, const struct dirent **b);
+#if !HAVE_SCANDIR || !HAVE_ALPHASORT
+ #include "php_scandir.h"
 #else
-#include "dirent.h"
+ #include <dirent.h>
 #endif
 
 #ifndef S_ISREG

Index: php4/main/php_scandir.c
+++ php4/main/php_scandir.c
/* 
   +----------------------------------------------------------------------+
   | PHP Version 4                                                        |
   +----------------------------------------------------------------------+
   | Copyright (c) 1997-2003 The PHP Group                                |
   +----------------------------------------------------------------------+
   | This source file is subject to version 2.02 of the PHP license,      |
   | that is bundled with this package in the file LICENSE, and is        |
   | available at through the world-wide-web at                           |
   | http://www.php.net/license/2_02.txt.                                 |
   | If you did not receive a copy of the PHP license and are unable to   |
   | obtain it through the world-wide-web, please send a note to          |
   | [EMAIL PROTECTED] so we can mail you a copy immediately.               |
   +----------------------------------------------------------------------+
   | Author: Shane Caraveo <[EMAIL PROTECTED]>                            |
   |         Ilia Alshanetsky <[EMAIL PROTECTED]>                          |
   +----------------------------------------------------------------------+
 */

#include "php_scandir.h"
#include "php_config.h"

#ifndef HAVE_SCANDIR
 #include <sys/types.h>

 #ifdef HAVE_DIRENT_H
  #include <dirent.h>
 #endif

 #ifdef PHP_WIN32
  #include "win32/readdir.h"
 #endif  

 #include <stdlib.h>
 #include <search.h>
#endif

#ifndef HAVE_ALPHASORT
int alphasort(const struct dirent **a, const struct dirent **b)
{
        return strcoll((*a)->d_name,(*b)->d_name);
}
#endif

#ifndef HAVE_SCANDIR
int scandir(const char *dirname, struct dirent **namelist[], int (*selector) (const 
struct dirent *entry), int (*compare) (const struct dirent **a, const struct dirent 
**b))
{
        DIR *dirp = NULL;
        struct dirent **vector = NULL;
        struct dirent *dp = NULL;
        int vector_size = 0;
        int nfiles = 0;

        if (namelist == NULL) {
                return -1;
        }

        if (!(dirp = opendir(dirname))) {
                return -1;
        }

        while ((dp = readdir(dirp)) != NULL) {
                int dsize = 0;
                struct dirent *newdp = NULL;

                if (selector && (*selector)(dp) == 0) {
                        continue;
                }

                if (nfiles == vector_size) {
                        struct dirent **newv;
                        if (vector_size == 0) {
                                vector_size = 10;
                        } else { 
                                vector_size *= 2;
                        }

                        newv = (struct dirent **) realloc (vector, vector_size * 
sizeof (struct dirent *));
                        if (!newv) {
                                return -1;
                        }
                        vector = newv;
                }

                dsize = sizeof (struct dirent) + ((strlen(dp->d_name) + 1) * 
sizeof(char));
                newdp = (struct dirent *) malloc(dsize);

                if (newdp == NULL) {
                        goto fail;
                }

                vector[nfiles++] = (struct dirent *) memcpy(newdp, dp, dsize);
        }

        closedir(dirp);

        *namelist = vector;

        if (compare) {
                qsort (*namelist, nfiles, sizeof(struct dirent *), compare);
        }

        return nfiles;

fail:
        while (nfiles-- > 0) {
                free(vector[nfiles]);
        }
        free(vector);
        return -1;      
}
#endif

Index: php4/main/php_scandir.h
+++ php4/main/php_scandir.h
#include <sys/types.h>
#include "php_config.h"

#ifdef HAVE_DIRENT_H
# include <dirent.h>
#endif

#ifdef PHP_WIN32
#include "win32/readdir.h"
#endif

#ifndef HAVE_ALPHASORT 
int alphasort(const struct dirent **a, const struct dirent **b);
#endif

#ifndef HAVE_SCANDIR
int scandir(const char *dirname, struct dirent **namelist[], int (*selector) (const 
struct dirent *entry), int (*compare) (const struct dirent **a, const struct dirent 
**b));
#endif



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

Reply via email to