Skip to content

Commit

Permalink
patch 8.2.3382: crash when getting the type of a NULL partial
Browse files Browse the repository at this point in the history
Problem:    Crash when getting the type of a NULL partial.
Solution:   Check for NULL. (closes vim#8260)
  • Loading branch information
brammool authored and chrisbra committed Aug 30, 2021
1 parent 16c00f5 commit 57f3030
Show file tree
Hide file tree
Showing 3 changed files with 14 additions and 2 deletions.
9 changes: 9 additions & 0 deletions src/testdir/test_vim9_builtin.vim
Original file line number Diff line number Diff line change
Expand Up @@ -3679,6 +3679,15 @@ def Test_typename()
if has('float')
assert_equal('func([unknown], [unknown]): float', typename(function('pow')))
endif
assert_equal('func', test_null_partial()->typename())
assert_equal('list<unknown>', test_null_list()->typename())
assert_equal('dict<unknown>', test_null_dict()->typename())
if has('job')
assert_equal('job', test_null_job()->typename())
endif
if has('channel')
assert_equal('channel', test_null_channel()->typename())
endif
enddef

def Test_undofile()
Expand Down
2 changes: 2 additions & 0 deletions src/version.c
Original file line number Diff line number Diff line change
Expand Up @@ -755,6 +755,8 @@ static char *(features[]) =

static int included_patches[] =
{ /* Add new patch number below this line */
/**/
3382,
/**/
3381,
/**/
Expand Down
5 changes: 3 additions & 2 deletions src/vim9type.c
Original file line number Diff line number Diff line change
Expand Up @@ -327,7 +327,7 @@ typval2type_int(typval_T *tv, int copyID, garray_T *type_gap, int do_member)
char_u *name = NULL;
ufunc_T *ufunc = NULL;

if (tv->v_type == VAR_PARTIAL)
if (tv->v_type == VAR_PARTIAL && tv->vval.v_partial != NULL)
{
if (tv->vval.v_partial->pt_func != NULL)
ufunc = tv->vval.v_partial->pt_func;
Expand Down Expand Up @@ -382,7 +382,8 @@ typval2type_int(typval_T *tv, int copyID, garray_T *type_gap, int do_member)
type->tt_type = tv->v_type;
type->tt_argcount = argcount;
type->tt_min_argcount = min_argcount;
if (tv->v_type == VAR_PARTIAL && tv->vval.v_partial->pt_argc > 0)
if (tv->v_type == VAR_PARTIAL && tv->vval.v_partial != NULL
&& tv->vval.v_partial->pt_argc > 0)
{
type->tt_argcount -= tv->vval.v_partial->pt_argc;
type->tt_min_argcount -= tv->vval.v_partial->pt_argc;
Expand Down

0 comments on commit 57f3030

Please sign in to comment.