]> git.ipfire.org Git - thirdparty/vim.git/commitdiff
patch 9.1.0226: Not able to assign enum values to an enum static variable v9.1.0226
authorYegappan Lakshmanan <yegappan@yahoo.com>
Fri, 29 Mar 2024 09:08:23 +0000 (10:08 +0100)
committerChristian Brabandt <cb@256bit.org>
Fri, 29 Mar 2024 09:08:23 +0000 (10:08 +0100)
Problem:  Not able to assign enum values to an enum static variable
          (zzzyxwvut)
Solution: Make it work
          (Yegappan Lakshmanan)

related: #14224
closes: #14329

Signed-off-by: Yegappan Lakshmanan <yegappan@yahoo.com>
Signed-off-by: Christian Brabandt <cb@256bit.org>
src/testdir/test_vim9_enum.vim
src/version.c
src/vim9class.c

index 6e10e0c705a6dba3e55ffacbb57dd30929e56c9e..ceea32fe4f315c5b8cd981691304425b70c72427 100644 (file)
@@ -964,7 +964,7 @@ def Test_enum_refcount()
 
     enum Star
       Gemini,
-      Orion,
+      Orion
     endenum
     assert_equal(3, test_refcount(Star))
     assert_equal(2, test_refcount(Star.Gemini))
@@ -1473,4 +1473,17 @@ def Test_enum_eval()
   v9.CheckSourceSuccess(lines)
 enddef
 
+" Test for using "values" in an enum class variable
+def Test_use_enum_values_in_class_variable()
+  var lines =<< trim END
+    vim9script
+    enum Dir
+      North, South
+      static const dirs: list<Dir> = Dir.values
+    endenum
+    assert_equal([Dir.North, Dir.South], Dir.dirs)
+  END
+  v9.CheckSourceSuccess(lines)
+enddef
+
 " vim: ts=8 sw=2 sts=2 expandtab tw=80 fdm=marker
index e96f17c25a1616407d57fbf7afe0c30e88af70ba..b56b6d38dca47dbaaefcb5612433f66db0b71dbe 100644 (file)
@@ -704,6 +704,8 @@ static char *(features[]) =
 
 static int included_patches[] =
 {   /* Add new patch number below this line */
+/**/
+    226,
 /**/
     225,
 /**/
index 696349190c94738356b277055bca28e11b3f1756..2d60ba95a6584d6577d31e154e1663e7b3464a17 100644 (file)
@@ -2056,6 +2056,11 @@ early_ret:
            if (enum_parse_values(eap, cl, line, &classmembers,
                                        &num_enum_values, &enum_end) == FAIL)
                break;
+
+           if (enum_end)
+               // Add the enum "values" class variable.
+               enum_add_values_member(cl, &classmembers, num_enum_values,
+                                                       &type_list);
            continue;
        }
 
@@ -2368,9 +2373,9 @@ early_ret:
 
     vim_free(theline);
 
-    if (success && is_enum)
-       // Add the enum "values" class variable.
-       enum_add_values_member(cl, &classmembers, num_enum_values, &type_list);
+    if (success && is_enum && num_enum_values == 0)
+       // Empty enum statement. Add an empty "values" class variable
+       enum_add_values_member(cl, &classmembers, 0, &type_list);
 
     /*
      * Check a few things