]> granicus.if.org Git - vim/commitdiff
patch 8.0.0416: setting v:progpath is not quite right v8.0.0416
authorBram Moolenaar <Bram@vim.org>
Sun, 5 Mar 2017 13:29:12 +0000 (14:29 +0100)
committerBram Moolenaar <Bram@vim.org>
Sun, 5 Mar 2017 13:29:12 +0000 (14:29 +0100)
Problem:    Setting v:progpath is not quite right.
Solution:   On MS-Windows add the extension. On Unix use the full path for a
            relative directory. (partly by James McCoy, closes #1531)

src/main.c
src/os_unix.c
src/os_win32.c
src/version.c

index 2575e8237de866ae10405e4e8ba9a374de505965..8669e33a009d9e98393beeac206ab15cb01f9edc 100644 (file)
@@ -3533,21 +3533,31 @@ time_msg(
 set_progpath(char_u *argv0)
 {
     char_u *val = argv0;
+#ifdef WIN32
+    char_u *path = NULL;
+#else
     char_u buf[MAXPATHL];
+#endif
 
     /* A relative path containing a "/" will become invalid when using ":cd",
      * turn it into a full path.
      * On MS-Windows "vim.exe" is found in the current directory, thus also do
      * it when there is no path and the file exists. */
-    if ( !mch_isFullName(argv0)
+    if (!mch_isFullName(argv0))
+    {
 # ifdef WIN32
-           && mch_can_exe(argv0, NULL, TRUE)
+       if (mch_can_exe(argv0, &path, FALSE) && path != NULL)
+           val = path;
 # else
-           && gettail(argv0) != argv0
+       if (gettail(argv0) != argv0
+                          && vim_FullName(argv0, buf, MAXPATHL, TRUE) != FAIL)
+           val = buf;
 # endif
-           && vim_FullName(argv0, buf, MAXPATHL, TRUE) != FAIL)
-       val = buf;
+    }
     set_vim_var_string(VV_PROGPATH, val, -1);
+#ifdef WIN32
+    vim_free(path);
+#endif
 }
 
 #endif /* NO_VIM_MAIN */
index 6220044b683d03e348a4c79da910c987109198db..6c5955b84ffaabdae667f939f0b7afdb9ca0a27f 100644 (file)
@@ -3103,7 +3103,7 @@ mch_can_exe(char_u *name, char_u **path, int use_path)
        {
            if (path != NULL)
            {
-               if (name[0] == '.')
+               if (name[0] != '/')
                    *path = FullName_save(name, TRUE);
                else
                    *path = vim_strsave(name);
@@ -3142,7 +3142,7 @@ mch_can_exe(char_u *name, char_u **path, int use_path)
        {
            if (path != NULL)
            {
-               if (buf[0] == '.')
+               if (buf[0] != '/')
                    *path = FullName_save(buf, TRUE);
                else
                    *path = vim_strsave(buf);
index a3048427cd28b603f2fe46cace8844193fa4cc43..dd3e6def5cb50d1c6c9500858e84422a1a8d9085 100644 (file)
@@ -1902,17 +1902,31 @@ theend:
 #endif
 
 /*
- * Return TRUE if "name" is in $PATH.
+ * If "use_path" is TRUE: Return TRUE if "name" is in $PATH.
+ * If "use_path" is FALSE: Return TRUE if "name" exists.
+ * When returning TRUE and "path" is not NULL save the path and set "*path" to
+ * the allocated memory.
  * TODO: Should somehow check if it's really executable.
  */
     static int
-executable_exists(char *name, char_u **path)
+executable_exists(char *name, char_u **path, int use_path)
 {
     char       *dum;
     char       fname[_MAX_PATH];
     char       *curpath, *newpath;
     long       n;
 
+    if (!use_path)
+    {
+       if (mch_getperm(name) != -1 && !mch_isdir(name))
+       {
+           if (path != NULL)
+               *path = vim_strsave((char_u *)name);
+           return TRUE;
+       }
+       return FALSE;
+    }
+
 #ifdef FEAT_MBYTE
     if (enc_codepage >= 0 && (int)GetACP() != enc_codepage)
     {
@@ -2038,7 +2052,7 @@ mch_init(void)
            vimrun_path = (char *)vim_strsave(vimrun_location);
            s_dont_use_vimrun = FALSE;
        }
-       else if (executable_exists("vimrun.exe", NULL))
+       else if (executable_exists("vimrun.exe", NULL, TRUE))
            s_dont_use_vimrun = FALSE;
 
        /* Don't give the warning for a missing vimrun.exe right now, but only
@@ -2052,7 +2066,7 @@ mch_init(void)
      * If "finstr.exe" doesn't exist, use "grep -n" for 'grepprg'.
      * Otherwise the default "findstr /n" is used.
      */
-    if (!executable_exists("findstr.exe", NULL))
+    if (!executable_exists("findstr.exe", NULL, TRUE))
        set_option_value((char_u *)"grepprg", 0, (char_u *)"grep -n", 0);
 
 #ifdef FEAT_CLIPBOARD
@@ -3358,9 +3372,10 @@ mch_writable(char_u *name)
 }
 
 /*
- * Return 1 if "name" can be executed, 0 if not.
+ * Return TRUE if "name" can be executed, FALSE if not.
  * If "use_path" is FALSE only check if "name" is executable.
- * Return -1 if unknown.
+ * When returning TRUE and "path" is not NULL save the path and set "*path" to
+ * the allocated memory.
  */
     int
 mch_can_exe(char_u *name, char_u **path, int use_path)
@@ -3371,17 +3386,12 @@ mch_can_exe(char_u *name, char_u **path, int use_path)
 
     if (len >= _MAX_PATH)      /* safety check */
        return FALSE;
-    if (!use_path)
-    {
-       /* TODO: check if file is really executable. */
-       return mch_getperm(name) != -1 && !mch_isdir(name);
-    }
 
     /* If there already is an extension try using the name directly.  Also do
      * this with a Unix-shell like 'shell'. */
     if (vim_strchr(gettail(name), '.') != NULL
                               || strstr((char *)gettail(p_sh), "sh") != NULL)
-       if (executable_exists((char *)name, path))
+       if (executable_exists((char *)name, path, use_path))
            return TRUE;
 
     /*
@@ -3403,7 +3413,7 @@ mch_can_exe(char_u *name, char_u **path, int use_path)
        }
        else
            copy_option_part(&p, buf + len, _MAX_PATH - len, ";");
-       if (executable_exists((char *)buf, path))
+       if (executable_exists((char *)buf, path, use_path))
            return TRUE;
     }
     return FALSE;
index dbb7df286c040241799394e820e3bb188fba4491..98fa4a803f04c29f4886271683632a9cfff7fb99 100644 (file)
@@ -764,6 +764,8 @@ static char *(features[]) =
 
 static int included_patches[] =
 {   /* Add new patch number below this line */
+/**/
+    416,
 /**/
     415,
 /**/