1
0
forked from aniani/vim

patch 7.4.1478

Problem:    ":loadplugin" doesn't take care of ftdetect files.
Solution:   Also load ftdetect scripts when appropriate.
This commit is contained in:
Bram Moolenaar
2016-03-03 14:23:10 +01:00
parent b5760a1ce5
commit 1bdd42627d
2 changed files with 30 additions and 3 deletions

View File

@@ -3052,6 +3052,25 @@ do_in_runtimepath(
return do_in_path(p_rtp, name, all, callback, cookie); 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 static void
source_pack_plugin(char_u *fname, void *cookie UNUSED) 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", do_in_path(p_pp, (char_u *)"pack/*/ever/*/plugin/*.vim",
TRUE, source_pack_plugin, NULL); TRUE, source_pack_plugin, NULL);
may_do_filetypes((char_u *)"pack/*/ever/*/ftdetect/*.vim");
} }
/* /*
@@ -3130,16 +3150,21 @@ source_packages()
void void
ex_loadplugin(exarg_T *eap) 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; int len;
char *pat; char *pat;
len = (int)STRLEN(pattern) + (int)STRLEN(eap->arg); len = (int)STRLEN(ftpat) + (int)STRLEN(eap->arg);
pat = (char *)alloc(len); pat = (char *)alloc(len);
if (pat == NULL) if (pat == NULL)
return; 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); 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); vim_free(pat);
} }

View File

@@ -743,6 +743,8 @@ static char *(features[]) =
static int included_patches[] = static int included_patches[] =
{ /* Add new patch number below this line */ { /* Add new patch number below this line */
/**/
1478,
/**/ /**/
1477, 1477,
/**/ /**/