diff options
Diffstat (limited to 'src')
| -rw-r--r-- | src/nvim/ex_cmds2.c | 28 | ||||
| -rw-r--r-- | src/nvim/version.c | 2 | 
2 files changed, 18 insertions, 12 deletions
diff --git a/src/nvim/ex_cmds2.c b/src/nvim/ex_cmds2.c index 33fe30cd5a..f8c470f213 100644 --- a/src/nvim/ex_cmds2.c +++ b/src/nvim/ex_cmds2.c @@ -2498,6 +2498,7 @@ static int APP_BOTH;  static void add_pack_plugin(char_u *fname, void *cookie)  {    char_u *p4, *p3, *p2, *p1, *p; +  char_u *buf = NULL;    char *const ffname = fix_fname((char *)fname); @@ -2525,26 +2526,30 @@ static void add_pack_plugin(char_u *fname, void *cookie)      // Find "ffname" in "p_rtp", ignoring '/' vs '\' differences      size_t fname_len = strlen(ffname);      const char *insp = (const char *)p_rtp; -    for (;;) { -      if (path_fnamencmp(insp, ffname, fname_len) == 0) { -        break; +    buf = try_malloc(MAXPATHL); +    if (buf == NULL) { +      goto theend; +    } +    while (*insp != NUL) { +      copy_option_part((char_u **)&insp, buf, MAXPATHL, ","); +      add_pathsep((char *)buf); +      char *const rtp_ffname = fix_fname((char *)buf); +      if (rtp_ffname == NULL) { +        goto theend;        } -      insp = strchr(insp, ','); -      if (insp == NULL) { +      bool match = path_fnamencmp(rtp_ffname, ffname, fname_len) == 0; +      xfree(rtp_ffname); +      if (match) {          break;        } -      insp++;      } -    if (insp == NULL) { +    if (*insp == NUL) {        // not found, append at the end        insp = (const char *)p_rtp + STRLEN(p_rtp);      } else {        // append after the matching directory. -      insp += strlen(ffname); -      while (*insp != NUL && *insp != ',') { -        insp++; -      } +      insp--;      }      *p4 = c; @@ -2614,6 +2619,7 @@ static void add_pack_plugin(char_u *fname, void *cookie)    }  theend: +  xfree(buf);    xfree(ffname);  } diff --git a/src/nvim/version.c b/src/nvim/version.c index 2a3fdbd70d..a190293d8e 100644 --- a/src/nvim/version.c +++ b/src/nvim/version.c @@ -644,7 +644,7 @@ static const int included_patches[] = {    311,    // 310,    // 309, -  // 308, +  308,    307,    // 306,    // 305,  | 
