From efa059c5a4611629890e28987a83aa781952b78c Mon Sep 17 00:00:00 2001 From: "Justin M. Keyes" Date: Sat, 1 Aug 2015 23:33:54 -0400 Subject: test: call scandir_next_with_dots() more than once Also cosmetic reduction. --- src/nvim/path.c | 25 +++++++++---------------- 1 file changed, 9 insertions(+), 16 deletions(-) (limited to 'src') diff --git a/src/nvim/path.c b/src/nvim/path.c index 9d9cd933b4..72980fcd0e 100644 --- a/src/nvim/path.c +++ b/src/nvim/path.c @@ -484,23 +484,16 @@ static size_t path_expand(garray_T *gap, const char_u *path, int flags) static const char *scandir_next_with_dots(Directory *dir) { static int count = 0; - const char *entry = NULL; - if (dir == NULL) { + if (dir == NULL) { // initialize count = 0; - } else { - count += 1; - if (count == 1) { - entry = "."; - } else if (count == 2) { - entry = ".."; - } else { - entry = os_scandir_next(dir); - if (entry == NULL) { - count = 0; - } - } + return NULL; + } + + count += 1; + if (count == 1 || count == 2) { + return (count == 1) ? "." : ".."; } - return entry; + return os_scandir_next(dir); } /// Implementation of path_expand(). @@ -623,7 +616,7 @@ static size_t do_path_expand(garray_T *gap, const char_u *path, || os_isdir(*buf == NUL ? (char_u *)"." : (char_u *)buf)) { // Find all matching entries. char_u *name; - scandir_next_with_dots(NULL); + scandir_next_with_dots(NULL /* initialize */); while((name = (char_u *) scandir_next_with_dots(&dir)) && name != NULL) { if ((name[0] != '.' || starts_with_dot) && ((regmatch.regprog != NULL && vim_regexec(®match, name, 0)) -- cgit