summaryrefslogtreecommitdiffstats
path: root/src/evalvars.c
diff options
context:
space:
mode:
authorBram Moolenaar <Bram@vim.org>2022-01-24 21:28:01 +0000
committerBram Moolenaar <Bram@vim.org>2022-01-24 21:28:01 +0000
commit3e93a2b075e99a2b3ced85227a6373be233712ff (patch)
treee34bf26f7503259ea27c2ec7c4a612e41c2b3307 /src/evalvars.c
parentdff97e65eb1bb24c44c2b7430a480888d8afb3f4 (diff)
patch 8.2.4209: partial in 'opfunc' cannot use an imported functionv8.2.4209
Problem: partial in 'opfunc' cannot use an imported function. Solution: Also expand the function name in a partial. (closes #9614)
Diffstat (limited to 'src/evalvars.c')
-rw-r--r--src/evalvars.c31
1 files changed, 24 insertions, 7 deletions
diff --git a/src/evalvars.c b/src/evalvars.c
index bd8cc73a12..496666e1ea 100644
--- a/src/evalvars.c
+++ b/src/evalvars.c
@@ -4680,27 +4680,44 @@ copy_callback(callback_T *dest, callback_T *src)
void
expand_autload_callback(callback_T *cb)
{
+ char_u *name;
char_u *p;
imported_T *import;
- if (!in_vim9script() || cb->cb_name == NULL || !cb->cb_free_name)
+ if (!in_vim9script() || cb->cb_name == NULL
+ || (!cb->cb_free_name
+ && (cb->cb_partial == NULL || cb->cb_partial->pt_name == NULL)))
return;
- p = vim_strchr(cb->cb_name, '.');
+ if (cb->cb_partial != NULL)
+ name = cb->cb_partial->pt_name;
+ else
+ name = cb->cb_name;
+ p = vim_strchr(name, '.');
if (p == NULL)
return;
- import = find_imported(cb->cb_name, p - cb->cb_name, FALSE, NULL);
+ import = find_imported(name, p - name, FALSE, NULL);
if (import != NULL && SCRIPT_ID_VALID(import->imp_sid))
{
scriptitem_T *si = SCRIPT_ITEM(import->imp_sid);
if (si->sn_autoload_prefix != NULL)
{
- char_u *name = concat_str(si->sn_autoload_prefix, p + 1);
+ char_u *newname = concat_str(si->sn_autoload_prefix, p + 1);
- if (name != NULL)
+ if (newname != NULL)
{
- vim_free(cb->cb_name);
- cb->cb_name = name;
+ if (cb->cb_partial != NULL)
+ {
+ if (cb->cb_name == cb->cb_partial->pt_name)
+ cb->cb_name = newname;
+ vim_free(cb->cb_partial->pt_name);
+ cb->cb_partial->pt_name = newname;
+ }
+ else
+ {
+ vim_free(cb->cb_name);
+ cb->cb_name = newname;
+ }
}
}
}