diff options
| author | Bernhard Reutner-Fischer <rep.dot.nop@gmail.com> | 2008-10-18 12:48:09 +0000 | 
|---|---|---|
| committer | Bernhard Reutner-Fischer <rep.dot.nop@gmail.com> | 2008-10-18 12:48:09 +0000 | 
| commit | 5016062735e34d4474e9c0305b51ebae90ab7a4a (patch) | |
| tree | 525b2ffc888996060be10c579f2d0056275e3206 /libc/misc | |
| parent | dce2384770a6e791312cb3330233d733ed1b0949 (diff) | |
- sync fix for scandir errno handling to scandir64 (r23600)
  Thanks to Peter S. Mazinger for mentioning this.
Diffstat (limited to 'libc/misc')
| -rw-r--r-- | libc/misc/dirent/scandir.c | 23 | ||||
| -rw-r--r-- | libc/misc/dirent/scandir64.c | 22 | 
2 files changed, 28 insertions, 17 deletions
| diff --git a/libc/misc/dirent/scandir.c b/libc/misc/dirent/scandir.c index ad997b121..9b0f7385a 100644 --- a/libc/misc/dirent/scandir.c +++ b/libc/misc/dirent/scandir.c @@ -13,10 +13,10 @@  #include "dirstream.h"  /* Experimentally off - libc_hidden_proto(memcpy) */ -libc_hidden_proto(readdir)  libc_hidden_proto(opendir)  libc_hidden_proto(closedir)  libc_hidden_proto(qsort) +libc_hidden_proto(readdir)  int scandir(const char *dir, struct dirent ***namelist,  	int (*selector) (const struct dirent *), @@ -40,14 +40,12 @@ int scandir(const char *dir, struct dirent ***namelist,  	if (! use_it)  	{ -  		use_it = (*selector) (current); -  		/* -		 * The selector function might have changed errno. -		 * It was zero before and it need to be again to make -		 * the latter tests work. -		 */ - 		if (! use_it) -			__set_errno (0); +	    use_it = (*selector) (current); +	    /* The selector function might have changed errno. +	     * It was zero before and it need to be again to make +	     * the latter tests work.  */ +	    if (! use_it) +		__set_errno (0);  	}  	if (use_it)  	{ @@ -64,20 +62,21 @@ int scandir(const char *dir, struct dirent ***namelist,  		    names_size = 10;  		else  		    names_size *= 2; -		new = (struct dirent **) realloc (names, names_size * sizeof (struct dirent *)); +		new = (struct dirent **) realloc (names, +					names_size * sizeof (struct dirent *));  		if (new == NULL)  		    break;  		names = new;  	    } -	    dsize = ¤t->d_name[_D_ALLOC_NAMLEN (current)] - (char *) current; +	    dsize = ¤t->d_name[_D_ALLOC_NAMLEN(current)] - (char*)current;  	    vnew = (struct dirent *) malloc (dsize);  	    if (vnew == NULL)  		break;  	    names[pos++] = (struct dirent *) memcpy (vnew, current, dsize);  	} -	} +    }      if (unlikely(errno != 0))      { diff --git a/libc/misc/dirent/scandir64.c b/libc/misc/dirent/scandir64.c index 083d2de18..de294c63a 100644 --- a/libc/misc/dirent/scandir64.c +++ b/libc/misc/dirent/scandir64.c @@ -53,8 +53,19 @@ int scandir64(const char *dir, struct dirent64 ***namelist,      __set_errno (0);      pos = 0; -    while ((current = readdir64 (dp)) != NULL) -	if (selector == NULL || (*selector) (current)) +    while ((current = readdir64 (dp)) != NULL) { +	int use_it = selector == NULL; + +	if (! use_it) +	{ +	    use_it = (*selector) (current); +	    /* The selector function might have changed errno. +	     * It was zero before and it need to be again to make +	     * the latter tests work.  */ +	    if (! use_it) +		__set_errno (0); +	} +	if (use_it)  	{  	    struct dirent64 *vnew;  	    size_t dsize; @@ -69,20 +80,21 @@ int scandir64(const char *dir, struct dirent64 ***namelist,  		    names_size = 10;  		else  		    names_size *= 2; -		new = (struct dirent64 **) realloc (names, names_size * sizeof (struct dirent64 *)); +		new = (struct dirent64 **) realloc (names, +				      names_size * sizeof (struct dirent64 *));  		if (new == NULL)  		    break;  		names = new;  	    } -	    dsize = ¤t->d_name[_D_ALLOC_NAMLEN (current)] - (char *) current; +	    dsize = ¤t->d_name[_D_ALLOC_NAMLEN(current)] - (char*)current;  	    vnew = (struct dirent64 *) malloc (dsize);  	    if (vnew == NULL)  		break;  	    names[pos++] = (struct dirent64 *) memcpy (vnew, current, dsize);  	} - +    }      if (unlikely(errno != 0))      {  	save = errno; | 
