summaryrefslogtreecommitdiff
diff options
context:
space:
mode:
authorBram Moolenaar <Bram@vim.org>2016-03-03 14:23:10 +0100
committerBram Moolenaar <Bram@vim.org>2016-03-03 14:23:10 +0100
commit1bdd42627d619258d0e847f217cfc1c2795f1ac5 (patch)
tree7d9a074140b29732849f6b84f76351f1adc8bf47
parentb5760a1ce5b700fc32b8bd11948ee189a847c59e (diff)
downloadvim-git-1bdd42627d619258d0e847f217cfc1c2795f1ac5.tar.gz
patch 7.4.1478v7.4.1478
Problem: ":loadplugin" doesn't take care of ftdetect files. Solution: Also load ftdetect scripts when appropriate.
-rw-r--r--src/ex_cmds2.c31
-rw-r--r--src/version.c2
2 files changed, 30 insertions, 3 deletions
diff --git a/src/ex_cmds2.c b/src/ex_cmds2.c
index e1a0dfd11..376856939 100644
--- a/src/ex_cmds2.c
+++ b/src/ex_cmds2.c
@@ -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);
}
diff --git a/src/version.c b/src/version.c
index a8e3f39cb..0731d61bd 100644
--- a/src/version.c
+++ b/src/version.c
@@ -744,6 +744,8 @@ static char *(features[]) =
static int included_patches[] =
{ /* Add new patch number below this line */
/**/
+ 1478,
+/**/
1477,
/**/
1476,