+2005-10-28 Paul Eggert <eggert@cs.ucla.edu>
+
+ * savedir.c (savedir): Don't assume that xrealloc etc. leave
+ errno alone. Problem reported by Frederic Jolliton.
+
2005-10-28 Simon Josefsson <jas@extundo.com>
* inet_ntop.h, inet_ntop.c: Make it work under mingw32: Add
2005-10-19 Simon Josefsson <jas@extundo.com>
- * gc.h, gc-gnulib.c, gc-libgcrypt.c: Support MD4.
+ * gc.h, gc-gnulib.c, gc-libgcrypt.c: Support MD4.
2005-10-18 Simon Josefsson <jas@extundo.com>
savedir (const char *dir)
{
DIR *dirp;
- struct dirent *dp;
char *name_space;
size_t allocated = NAME_SIZE_DEFAULT;
size_t used = 0;
name_space = xmalloc (allocated);
- errno = 0;
- while ((dp = readdir (dirp)) != NULL)
+ for (;;)
{
+ struct dirent const *dp;
+ char const *entry;
+
+ errno = 0;
+ dp = readdir (dirp);
+ if (! dp)
+ break;
+
/* Skip "", ".", and "..". "" is returned by at least one buggy
implementation: Solaris 2.4 readdir on NFS file systems. */
- char const *entry = dp->d_name;
+ entry = dp->d_name;
if (entry[entry[0] != '.' ? 0 : entry[1] != '.' ? 1 : 2] != '\0')
{
size_t entry_size = strlen (entry) + 1;