X-Git-Url: http://nsz.repo.hu/git/?a=blobdiff_plain;ds=inline;f=src%2Fdirent%2Fscandir.c;h=7ee195dd8ab31d3cbaf38179aab9a3936b58d711;hb=c5d118ebbcfe41d928d8ffc913bc532c59237189;hp=aad813ac792b574b02d32b8d2b50eb2fd391d483;hpb=dae17a1aaf25d8333e729173d86659066607d87d;p=musl diff --git a/src/dirent/scandir.c b/src/dirent/scandir.c index aad813ac..7ee195dd 100644 --- a/src/dirent/scandir.c +++ b/src/dirent/scandir.c @@ -1,10 +1,9 @@ #include #include #include -#include +#include #include #include -#include int scandir(const char *path, struct dirent ***res, int (*sel)(const struct dirent *), @@ -12,7 +11,7 @@ int scandir(const char *path, struct dirent ***res, { DIR *d = opendir(path); struct dirent *de, **names=0, **tmp; - size_t cnt=0, len=0, size; + size_t cnt=0, len=0; int old_errno = errno; if (!d) return -1; @@ -26,10 +25,9 @@ int scandir(const char *path, struct dirent ***res, if (!tmp) break; names = tmp; } - size = offsetof(struct dirent,d_name) + strlen(de->d_name) + 1; - names[cnt] = malloc(size); + names[cnt] = malloc(de->d_reclen); if (!names[cnt]) break; - memcpy(names[cnt++], de, size); + memcpy(names[cnt++], de, de->d_reclen); } closedir(d); @@ -46,4 +44,4 @@ int scandir(const char *path, struct dirent ***res, return cnt; } -LFS64(scandir); +weak_alias(scandir, scandir64);