summaryrefslogtreecommitdiffstats
path: root/src/clientserver.c
diff options
context:
space:
mode:
authorChristian Brabandt <cb@256bit.org>2024-01-23 21:13:58 +0100
committerChristian Brabandt <cb@256bit.org>2024-01-23 21:16:54 +0100
commitcc979b49dcb2392a2c6767d3a7e05a6e07ed7201 (patch)
treeaa6ec70f6f2b1292aeed45e62474ac3d2e7b6b6f /src/clientserver.c
parente13b665a6e2a32910ff5c3fec330bef4a10f8f23 (diff)
patch 9.1.0045: --remote-* does not ignore `wilidignore`v9.1.0045
Problem: --remote-silent applies the wildignore option to each argument, which may result in "E479: No match" (hebaronson) Solution: temporarily reset 'wildignore' setting when building the :drop command closes: #13835 Signed-off-by: Christian Brabandt <cb@256bit.org>
Diffstat (limited to 'src/clientserver.c')
-rw-r--r--src/clientserver.c8
1 files changed, 8 insertions, 0 deletions
diff --git a/src/clientserver.c b/src/clientserver.c
index cfc0ab6613..340add3151 100644
--- a/src/clientserver.c
+++ b/src/clientserver.c
@@ -566,6 +566,10 @@ build_drop_cmd(
char_u *p;
char_u *cdp;
char_u *cwd;
+ // reset wildignore temporarily
+ const char *wig[] =
+ { "<CR><C-\\><C-N>:let g:_wig=&wig|set wig=",
+ "<C-\\><C-N>:let &wig=g:_wig|unlet g:_wig<CR>"};
if (filec > 0 && filev[0][0] == '+')
{
@@ -599,6 +603,8 @@ build_drop_cmd(
ga_init2(&ga, 1, 100);
ga_concat(&ga, (char_u *)"<C-\\><C-N>:cd ");
ga_concat(&ga, cdp);
+ // reset wildignorecase temporarily
+ ga_concat(&ga, (char_u *)wig[0]);
// Call inputsave() so that a prompt for an encryption key works.
ga_concat(&ga, (char_u *)
@@ -650,6 +656,8 @@ build_drop_cmd(
ga_concat(&ga, cdp);
ga_concat(&ga, (char_u *)"'|cd -|endif|endif<CR>");
vim_free(cdp);
+ // reset wildignorecase
+ ga_concat(&ga, (char_u *)wig[1]);
if (sendReply)
ga_concat(&ga, (char_u *)":call SetupRemoteReplies()<CR>");