~ chicken-core (chicken-5) 70751f38b9ef596ad25dd84cc66549b24abd2471


commit 70751f38b9ef596ad25dd84cc66549b24abd2471
Author:     Peter Bex <peter@more-magic.net>
AuthorDate: Mon Aug 30 12:20:03 2021 +0200
Commit:     felix <felix@call-with-current-continuation.org>
CommitDate: Tue Aug 31 11:04:39 2021 +0200

    Drop custom opendir/readdir implementation in Windows
    
    Windows doesn't have these functions, but MinGW provides
    them as part of its crt library.
    
    Our own stub implementation had some issues which caused
    an error to trigger a loop which resulted in a hanging
    process when running chicken-install -update-db
    
    Signed-off-by: felix <felix@call-with-current-continuation.org>

diff --git a/NEWS b/NEWS
index c30c4395..00e79659 100644
--- a/NEWS
+++ b/NEWS
@@ -3,7 +3,8 @@
 - Core libraries
   - The srfi-17 module now exports the `getter-with-setter` and `setter`
     procedures, not just the set! macro (thanks to Lassi Kortela)
-
+  - Fix hang in chicken-install -update-db on Windows (thanks to Mark
+    Fisher for reporting and Jani Hakala for debugging and patch).
 
 5.3.0rc1
 
diff --git a/file.scm b/file.scm
index 18ce00f1..56e4c909 100644
--- a/file.scm
+++ b/file.scm
@@ -65,86 +65,8 @@
 # define C_mkdir(str)       C_fix(mkdir(C_c_string(str)))
 #endif
 
-#if !defined(_WIN32) || defined(__CYGWIN__)
-# include <sys/types.h>
-# include <dirent.h>
-#else
-struct dirent
-{
-    char *              d_name;
-};
-
-typedef struct
-{
-    struct _finddata_t  fdata;
-    int                 handle;
-    struct dirent       current;
-} DIR;
-
-static DIR * C_fcall
-opendir(const char *name)
-{
-    int name_len = strlen(name);
-    int what_len = name_len + 3;
-    DIR *dir = (DIR *)malloc(sizeof(DIR));
-    char *what;
-    if (!dir)
-    {
-	errno = ENOMEM;
-	return NULL;
-    }
-    what = (char *)malloc(what_len);
-    if (!what)
-    {
-	free(dir);
-	errno = ENOMEM;
-	return NULL;
-    }
-    C_strlcpy(what, name, what_len);
-    if (strchr("\\/", name[name_len - 1]))
-	C_strlcat(what, "*", what_len);
-    else
-	C_strlcat(what, "\\*", what_len);
-
-    dir->handle = _findfirst(what, &dir->fdata);
-    if (dir->handle == -1)
-    {
-	free(what);
-	free(dir);
-	return NULL;
-    }
-    dir->current.d_name = NULL; /* as the first-time indicator */
-    free(what);
-    return dir;
-}
-
-static int C_fcall
-closedir(DIR * dir)
-{
-    if (dir)
-    {
-	int res = _findclose(dir->handle);
-	free(dir);
-	return res;
-    }
-    return -1;
-}
-
-static struct dirent * C_fcall
-readdir(DIR * dir)
-{
-    if (dir)
-    {
-	if (!dir->current.d_name /* first time after opendir */
-	     || _findnext(dir->handle, &dir->fdata) != -1)
-	{
-	    dir->current.d_name = dir->fdata.name;
-	    return &dir->current;
-	}
-    }
-    return NULL;
-}
-#endif
+#include <sys/types.h>
+#include <dirent.h>
 
 #define C_opendir(s,h)      C_set_block_item(h, 0, (C_word) opendir(C_c_string(s)))
 #define C_readdir(h,e)      C_set_block_item(e, 0, (C_word) readdir((DIR *)C_block_item(h, 0)))
Trap