]> git.ipfire.org Git - thirdparty/vim.git/commitdiff
patch 9.1.0688: Vim9: dereferences NULL pointer in check_type_is_value() v9.1.0688
authorChristian Brabandt <cb@256bit.org>
Thu, 22 Aug 2024 19:25:18 +0000 (21:25 +0200)
committerChristian Brabandt <cb@256bit.org>
Thu, 22 Aug 2024 19:25:18 +0000 (21:25 +0200)
Problem:  Vim9: dereferences NULL pointer in check_type_is_value()
          (Suyue Guo)
Solution: Verify that the pointer is not Null

fixes: #15540
closes: #15545

Signed-off-by: Christian Brabandt <cb@256bit.org>
src/testdir/test_vim9_cmd.vim
src/version.c
src/vim9type.c

index a9e10e797c3186d004192982ab222fc7c7a8189d..51ae7e685f11bc0ef55ce7d4bdf15a368a2d1f30 100644 (file)
@@ -2036,6 +2036,14 @@ def Test_no_space_after_command()
   v9.CheckDefExecAndScriptFailure(lines, 'E486:', 1)
 enddef
 
+def Test_lambda_crash()
+  # This used to crash Vim
+  var lines =<< trim END
+    vim9 () => super      => {
+  END
+  v9.CheckScriptFailureList(lines, ["E1356:", "E1405:"])
+enddef
+
 " Test for the 'previewpopup' option
 def Test_previewpopup()
   set previewpopup=height:10,width:60
@@ -2044,6 +2052,7 @@ def Test_previewpopup()
   assert_notequal(id, 0)
   assert_match('Xppfile', popup_getoptions(id).title)
   popup_clear()
+  bw Xppfile
   set previewpopup&
 enddef
 
index 72cce6580a5a1f219a72bc1ad87541e745aaa379..e77ef0f4c9635c5bc4ae3f813a52a1c8e9b12387 100644 (file)
@@ -704,6 +704,8 @@ static char *(features[]) =
 
 static int included_patches[] =
 {   /* Add new patch number below this line */
+/**/
+    688,
 /**/
     687,
 /**/
index a1571218f68672b6dc44ac7557c8edd423498be8..1f044d3d43853c7e67b1b98cd55a789f9a98048c 100644 (file)
@@ -2138,12 +2138,13 @@ check_type_is_value(type_T *type)
     switch (type->tt_type)
     {
        case VAR_CLASS:
-           if (IS_ENUM(type->tt_class))
+           if (type->tt_class != NULL && IS_ENUM(type->tt_class))
                semsg(_(e_using_enum_as_value_str),
                        type->tt_class->class_name);
            else
                semsg(_(e_using_class_as_value_str),
-                       type->tt_class->class_name);
+                       type->tt_class == NULL ? (char_u *)""
+                       : type->tt_class->class_name);
            return FAIL;
 
        case VAR_TYPEALIAS: