diff options
author | Yegappan Lakshmanan <yegappan@yahoo.com> | 2023-10-28 15:53:55 +0200 |
---|---|---|
committer | Christian Brabandt <cb@256bit.org> | 2023-10-28 15:53:55 +0200 |
commit | feaccd239573a6265d39d3a917862ee40742eab4 (patch) | |
tree | 3ccb80ce860395236ba3d4a44b4257af99e4b21a /src/vim9type.c | |
parent | 87ca5e86fa0ef305f3d39cc4261b622f21417f7f (diff) |
patch 9.0.2078: several problems with type aliasesv9.0.2078
Problem: several problems with type aliases
Solution: Check for more error conditions, add tests,
fix issues
Check for more error conditions and add additional tests
fixes #13434
fixes #13437
fixes #13438
closes #13441
Signed-off-by: Yegappan Lakshmanan <yegappan@yahoo.com>
Signed-off-by: Christian Brabandt <cb@256bit.org>
Diffstat (limited to 'src/vim9type.c')
-rw-r--r-- | src/vim9type.c | 8 |
1 files changed, 7 insertions, 1 deletions
diff --git a/src/vim9type.c b/src/vim9type.c index 2a20bcb2bf..e5b61052be 100644 --- a/src/vim9type.c +++ b/src/vim9type.c @@ -1811,7 +1811,13 @@ f_typename(typval_T *argvars, typval_T *rettv) rettv->v_type = VAR_STRING; ga_init2(&type_list, sizeof(type_T *), 10); if (argvars[0].v_type == VAR_TYPEALIAS) - type = argvars[0].vval.v_typealias->ta_type; + { + type = copy_type(argvars[0].vval.v_typealias->ta_type, &type_list); + // A type alias for a class has the type set to VAR_OBJECT. Change it + // to VAR_CLASS, so that the name is "typealias<class<xxx>>" + if (type->tt_type == VAR_OBJECT) + type->tt_type = VAR_CLASS; + } else type = typval2type(argvars, get_copyID(), &type_list, TVTT_DO_MEMBER); name = type_name(type, &tofree); |