summaryrefslogtreecommitdiff
diff options
context:
space:
mode:
authorShane Caraveo <shane@php.net>2003-01-26 01:39:18 +0000
committerShane Caraveo <shane@php.net>2003-01-26 01:39:18 +0000
commit82f6cef483d3effcdef42f1602f24d8f3aa329fc (patch)
treefb7dc52fae6921550f7cd768351bd0557cedd11b
parent436ad07b9806c09893f4583432c996748ac568f4 (diff)
downloadphp-git-82f6cef483d3effcdef42f1602f24d8f3aa329fc.tar.gz
Fix broken build by adding scandir and alphasort for win32
-rw-r--r--main/php_ini.c6
-rw-r--r--win32/readdir.c80
-rw-r--r--win32/readdir.h6
3 files changed, 91 insertions, 1 deletions
diff --git a/main/php_ini.c b/main/php_ini.c
index 0ca2f5841b..ed9ac9cb98 100644
--- a/main/php_ini.c
+++ b/main/php_ini.c
@@ -31,7 +31,13 @@
#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);
+#else
#include "dirent.h"
+#endif
#ifndef S_ISREG
#define S_ISREG(mode) (((mode) & S_IFMT) == S_IFREG)
diff --git a/win32/readdir.c b/win32/readdir.c
index e33d19bde5..78db689b29 100644
--- a/win32/readdir.c
+++ b/win32/readdir.c
@@ -141,3 +141,83 @@ int rewinddir(DIR *dp)
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;
+}
diff --git a/win32/readdir.h b/win32/readdir.h
index aed9a44788..b63015355a 100644
--- a/win32/readdir.h
+++ b/win32/readdir.h
@@ -39,6 +39,10 @@ struct dirent *readdir(DIR *);
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 */