diff options
Diffstat (limited to 'src/nvim/path.c')
-rw-r--r-- | src/nvim/path.c | 29 |
1 files changed, 26 insertions, 3 deletions
diff --git a/src/nvim/path.c b/src/nvim/path.c index 152154e5f4..9d9cd933b4 100644 --- a/src/nvim/path.c +++ b/src/nvim/path.c @@ -481,6 +481,28 @@ static size_t path_expand(garray_T *gap, const char_u *path, int flags) return do_path_expand(gap, path, 0, flags, false); } +static const char *scandir_next_with_dots(Directory *dir) +{ + static int count = 0; + const char *entry = NULL; + if (dir == NULL) { + 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 entry; +} + /// Implementation of path_expand(). /// /// Chars before `path + wildoff` do not get expanded. @@ -597,11 +619,12 @@ static size_t do_path_expand(garray_T *gap, const char_u *path, *s = NUL; Directory dir; - // open the directory for scanning - if (os_scandir(&dir, *buf == NUL ? "." : (char *)buf)) { + if (os_scandir(&dir, *buf == NUL ? "." : (char *)buf) + || os_isdir(*buf == NUL ? (char_u *)"." : (char_u *)buf)) { // Find all matching entries. char_u *name; - while((name = (char_u *) os_scandir_next(&dir))) { + scandir_next_with_dots(NULL); + 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)) || ((flags & EW_NOTWILD) |