X-Git-Url: http://nsz.repo.hu/git/?a=blobdiff_plain;f=src%2Fregex%2Fglob.c;h=5b6ff1247f437416e1a95dae05ba26f9e269fb91;hb=769f53598e781ffc89191520f3f8a93cb58db91f;hp=550f655ca8090f434631a0b50e609fc403fe7cb9;hpb=da88b16a221c9d327e1bfa61dd6f4f08dacce57a;p=musl diff --git a/src/regex/glob.c b/src/regex/glob.c index 550f655c..5b6ff124 100644 --- a/src/regex/glob.c +++ b/src/regex/glob.c @@ -7,8 +7,6 @@ #include #include #include -#include -#include #include "libc.h" struct match @@ -58,7 +56,8 @@ static int match_in_dir(const char *d, const char *p, int flags, int (*errfunc)( char *p2; size_t l = strlen(d); int literal; - int fnm_flags= ((flags & GLOB_NOESCAPE) ? FNM_NOESCAPE : 0) | FNM_PERIOD; + int fnm_flags= ((flags & GLOB_NOESCAPE) ? FNM_NOESCAPE : 0) + | ((!(flags & GLOB_PERIOD)) ? FNM_PERIOD : 0); int error; if ((p2 = strchr(p, '/'))) { @@ -116,7 +115,7 @@ static int match_in_dir(const char *d, const char *p, int flags, int (*errfunc)( } else { int mark = 0; if (flags & GLOB_MARK) { - if (de->d_type) + if (de->d_type && !S_ISLNK(de->d_type<<12)) mark = S_ISDIR(de->d_type<<12); else { struct stat st; @@ -155,7 +154,7 @@ static int sort(const void *a, const void *b) return strcmp(*(const char **)a, *(const char **)b); } -int glob(const char *pat, int flags, int (*errfunc)(const char *path, int err), glob_t *g) +int glob(const char *restrict pat, int flags, int (*errfunc)(const char *path, int err), glob_t *restrict g) { const char *p=pat, *d; struct match head = { .next = NULL }, *tail = &head; @@ -170,8 +169,6 @@ int glob(const char *pat, int flags, int (*errfunc)(const char *path, int err), d = ""; } - if (strlen(p) > PATH_MAX) return GLOB_NOSPACE; - if (!errfunc) errfunc = ignore_err; if (!(flags & GLOB_APPEND)) { @@ -180,6 +177,8 @@ int glob(const char *pat, int flags, int (*errfunc)(const char *path, int err), g->gl_pathv = NULL; } + if (strnlen(p, PATH_MAX+1) > PATH_MAX) return GLOB_NOSPACE; + if (*p) error = match_in_dir(d, p, flags, errfunc, &tail); if (error == GLOB_NOSPACE) { freelist(&head);