]> granicus.if.org Git - vim/commitdiff
patch 7.4.1478 v7.4.1478
authorBram Moolenaar <Bram@vim.org>
Thu, 3 Mar 2016 13:23:10 +0000 (14:23 +0100)
committerBram Moolenaar <Bram@vim.org>
Thu, 3 Mar 2016 13:23:10 +0000 (14:23 +0100)
Problem:    ":loadplugin" doesn't take care of ftdetect files.
Solution:   Also load ftdetect scripts when appropriate.

src/ex_cmds2.c
src/version.c

index e1a0dfd11e9fe27d79fe4164b8a034a568aeeb08..3768569397affcc272f46db106f79e65cdad2d70 100644 (file)
@@ -3052,6 +3052,25 @@ do_in_runtimepath(
     return do_in_path(p_rtp, name, all, callback, cookie);
 }
 
+/*
+ * Source filetype detection scripts, if filetype.vim was already done.
+ */
+    static void
+may_do_filetypes(char_u *pat)
+{
+    char_u *cmd = vim_strsave((char_u *)"did_load_filetypes");
+
+    /* If runtime/filetype.vim wasn't loaded yet, the scripts will be found
+     * when it loads. */
+    if (cmd != NULL && eval_to_number(cmd) > 0)
+    {
+       do_cmdline_cmd((char_u *)"augroup filetypedetect");
+       source_runtime(pat, TRUE);
+       do_cmdline_cmd((char_u *)"augroup END");
+    }
+    vim_free(cmd);
+}
+
     static void
 source_pack_plugin(char_u *fname, void *cookie UNUSED)
 {
@@ -3122,6 +3141,7 @@ source_packages()
 {
     do_in_path(p_pp, (char_u *)"pack/*/ever/*/plugin/*.vim",
                                              TRUE, source_pack_plugin, NULL);
+    may_do_filetypes((char_u *)"pack/*/ever/*/ftdetect/*.vim");
 }
 
 /*
@@ -3130,16 +3150,21 @@ source_packages()
     void
 ex_loadplugin(exarg_T *eap)
 {
-    static char *pattern = "pack/*/opt/%s/plugin/*.vim";
+    static char *plugpat = "pack/*/opt/%s/plugin/*.vim";
+    static char *ftpat = "pack/*/opt/%s/ftdetect/*.vim";
     int                len;
     char       *pat;
 
-    len = (int)STRLEN(pattern) + (int)STRLEN(eap->arg);
+    len = (int)STRLEN(ftpat) + (int)STRLEN(eap->arg);
     pat = (char *)alloc(len);
     if (pat == NULL)
        return;
-    vim_snprintf(pat, len, pattern, eap->arg);
+    vim_snprintf(pat, len, plugpat, eap->arg);
     do_in_path(p_pp, (char_u *)pat, TRUE, source_pack_plugin, NULL);
+
+    vim_snprintf(pat, len, ftpat, eap->arg);
+    may_do_filetypes((char_u *)pat);
+
     vim_free(pat);
 }
 
index a8e3f39cb2e61e6ac12108b07e668ab847ac6ffd..0731d61bd53121674f10151cc16fc67ffeb40137 100644 (file)
@@ -743,6 +743,8 @@ static char *(features[]) =
 
 static int included_patches[] =
 {   /* Add new patch number below this line */
+/**/
+    1478,
 /**/
     1477,
 /**/