]> git.ipfire.org Git - thirdparty/vim.git/commitdiff
patch 9.0.1837: Vim9: class_member_type() can be optimized v9.0.1837
authorErnie Rael <errael@raelity.com>
Fri, 1 Sep 2023 16:54:54 +0000 (18:54 +0200)
committerChristian Brabandt <cb@256bit.org>
Fri, 1 Sep 2023 16:57:09 +0000 (18:57 +0200)
Problem:  Vim9: class_member_type() can be optimized
Solution: class_member_type() provides more information;
          safe an additional alloc()/free()

closes: #12989

Signed-off-by: Christian Brabandt <cb@256bit.org>
Co-authored-by: Ernie Rael <errael@raelity.com>
src/proto/vim9class.pro
src/version.c
src/vim9class.c
src/vim9compile.c

index df0ed35f32b84927e10762e87eceb76cc7f5215d..47bfa9d1f522fbd18337d249032d9cb96d549d3f 100644 (file)
@@ -1,7 +1,7 @@
 /* vim9class.c */
 int object_index_from_itf_index(class_T *itf, int is_method, int idx, class_T *cl);
 void ex_class(exarg_T *eap);
-type_T *class_member_type(class_T *cl, char_u *name, char_u *name_end, int *member_idx, omacc_T *access);
+type_T *class_member_type(class_T *cl, char_u *name, char_u *name_end, int *member_idx, ocmember_T **m);
 void ex_enum(exarg_T *eap);
 void ex_type(exarg_T *eap);
 int class_object_index(char_u **arg, typval_T *rettv, evalarg_T *evalarg, int verbose);
index b31207dce24cb5ae32573180928c5dbb4b475d0c..d6c8ed14f3ecb91b6975e17ed6aaae266d9b97fc 100644 (file)
@@ -699,6 +699,8 @@ static char *(features[]) =
 
 static int included_patches[] =
 {   /* Add new patch number below this line */
+/**/
+    1837,
 /**/
     1836,
 /**/
index 79780c0c8d5c9a7b00338fb25b0f8cd2b2ecde36..0e780fafaba3746ca867f062c9c62fdeb7cafe72 100644 (file)
@@ -1554,6 +1554,7 @@ cleanup:
  * Find member "name" in class "cl", set "member_idx" to the member index and
  * return its type.
  * When not found "member_idx" is set to -1 and t_any is returned.
+ * Set *p_m ocmmember_T if not NULL
  */
     type_T *
 class_member_type(
@@ -1561,7 +1562,7 @@ class_member_type(
     char_u     *name,
     char_u     *name_end,
     int                *member_idx,
-    omacc_T    *access)
+    ocmember_T **p_m)
 {
     *member_idx = -1;  // not found (yet)
     size_t len = name_end - name;
@@ -1572,7 +1573,8 @@ class_member_type(
        if (STRNCMP(m->ocm_name, name, len) == 0 && m->ocm_name[len] == NUL)
        {
            *member_idx = i;
-           *access = m->ocm_access;
+           if (p_m != NULL)
+               *p_m = m;
            return m->ocm_type;
        }
     }
index 0d2de9953bfe7f05314b3ed015bd482666cbd4a6..cc5a302a5343120469619485ff0aa172f846866f 100644 (file)
@@ -1866,27 +1866,21 @@ compile_lhs(
        {
            // for an object or class member get the type of the member
            class_T     *cl = lhs->lhs_type->tt_class;
-           omacc_T     access;
+           ocmember_T  *m;
 
            lhs->lhs_member_type = class_member_type(cl, after + 1,
-                                       lhs->lhs_end, &lhs->lhs_member_idx,
-                                       &access);
+                                   lhs->lhs_end, &lhs->lhs_member_idx, &m);
            if (lhs->lhs_member_idx < 0)
                return FAIL;
 
            // If it is private member variable, then accessing it outside the
            // class is not allowed.
-           if ((access != VIM_ACCESS_ALL) && !inside_class(cctx, cl))
+           if ((m->ocm_access != VIM_ACCESS_ALL) && !inside_class(cctx, cl))
            {
-               char_u  *m_name;
-               char    *msg;
-
-               m_name = vim_strnsave(after + 1, lhs->lhs_end - after - 1);
-               msg = (access == VIM_ACCESS_PRIVATE)
+               char *msg = (m->ocm_access == VIM_ACCESS_PRIVATE)
                                ? e_cannot_access_private_member_str
                                : e_cannot_change_readonly_variable_str;
-               semsg(_(msg), m_name);
-               vim_free(m_name);
+               semsg(_(msg), m->ocm_name);
                return FAIL;
            }
        }
@@ -2097,10 +2091,9 @@ compile_load_lhs_with_index(lhs_T *lhs, char_u *var_start, cctx_T *cctx)
           return FAIL;
 
        class_T *cl = lhs->lhs_type->tt_class;
-       omacc_T access;
        type_T  *type = class_member_type(cl, dot + 1,
                                           lhs->lhs_end, &lhs->lhs_member_idx,
-                                          &access);
+                                          NULL);
        if (lhs->lhs_member_idx < 0)
            return FAIL;