diff options
| author | Justin M. Keyes <justinkz@gmail.com> | 2015-08-01 23:16:17 -0400 | 
|---|---|---|
| committer | Justin M. Keyes <justinkz@gmail.com> | 2015-08-01 23:16:53 -0400 | 
| commit | dd7c7efcfb37342ccd9168977b2431d16de7b3cb (patch) | |
| tree | 22fb3ae8dd192f9dc50053b02d33e76af73a6af1 /src | |
| parent | d4396acedb213209aee4693e196f1952bbc88ff5 (diff) | |
| parent | ea551044ea8a0de8e2f6937c9d083cecd2f67b99 (diff) | |
| download | rneovim-dd7c7efcfb37342ccd9168977b2431d16de7b3cb.tar.gz rneovim-dd7c7efcfb37342ccd9168977b2431d16de7b3cb.tar.bz2 rneovim-dd7c7efcfb37342ccd9168977b2431d16de7b3cb.zip | |
Merge #3099 glob() should return '.' and '..'
Diffstat (limited to 'src')
| -rw-r--r-- | src/nvim/fileio.c | 5 | ||||
| -rw-r--r-- | src/nvim/path.c | 29 | 
2 files changed, 27 insertions, 7 deletions
| diff --git a/src/nvim/fileio.c b/src/nvim/fileio.c index dee9680230..58e4873e00 100644 --- a/src/nvim/fileio.c +++ b/src/nvim/fileio.c @@ -415,14 +415,11 @@ readfile (      msg_scroll = TRUE;          /* don't overwrite previous file message */    /* -   * If the name ends in a path separator, we can't open it.  Check here, -   * because reading the file may actually work, but then creating the swap -   * file may destroy it!  Reported on MS-DOS and Win 95.     * If the name is too long we might crash further on, quit here.     */    if (fname != NULL && *fname != NUL) {      p = fname + STRLEN(fname); -    if (after_pathsep((char *)fname, (char *)p) || STRLEN(fname) >= MAXPATHL) { +    if (STRLEN(fname) >= MAXPATHL) {        filemess(curbuf, fname, (char_u *)_("Illegal file name"), 0);        msg_end();        msg_scroll = msg_save; 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) | 
