]> git.ipfire.org Git - thirdparty/vim.git/commitdiff
patch 9.1.0163: Calling STRLEN() to compute ml_line_textlen when not needed v9.1.0163
authorzeertzjq <zeertzjq@outlook.com>
Sun, 10 Mar 2024 07:55:42 +0000 (08:55 +0100)
committerChristian Brabandt <cb@256bit.org>
Sun, 10 Mar 2024 07:55:42 +0000 (08:55 +0100)
Problem:  Calling STRLEN() to compute ml_line_textlen when not needed.
Solution: Use 0 when STRLEN() will be required and call STRLEN() later.
          (zeertzjq)

closes: #14155

Signed-off-by: zeertzjq <zeertzjq@outlook.com>
Signed-off-by: Christian Brabandt <cb@256bit.org>
src/change.c
src/edit.c
src/memline.c
src/structs.h
src/version.c

index 847c1878364def5e7a581820bffb1dc4493d6c2d..3af19b600c03fa68ec98497767d87412b24d6bca 100644 (file)
@@ -1364,7 +1364,7 @@ del_bytes(
            mch_memmove(newp + newlen + 1, oldp + oldlen + 1,
                               (size_t)curbuf->b_ml.ml_line_len - oldlen - 1);
        curbuf->b_ml.ml_line_len -= count;
-       curbuf->b_ml.ml_line_textlen = (int)STRLEN(newp) + 1;
+       curbuf->b_ml.ml_line_textlen = 0;
     }
 #endif
 
index 998647cd8e895ef1239476228b80c0670a24f524..26853dce0194a7d179af9e3edb29122cef82d983 100644 (file)
@@ -5088,7 +5088,7 @@ ins_tab(void)
                        vim_free(curbuf->b_ml.ml_line_ptr);
                    curbuf->b_ml.ml_line_ptr = newp;
                    curbuf->b_ml.ml_line_len -= i;
-                   curbuf->b_ml.ml_line_textlen = (int)STRLEN(newp) + 1;
+                   curbuf->b_ml.ml_line_textlen = 0;
                    curbuf->b_ml.ml_flags =
                           (curbuf->b_ml.ml_flags | ML_LINE_DIRTY) & ~ML_EMPTY;
                }
index 19d037f9eb77d32e6f0fd60b6f21e7b2b074cfd9..99b9e9f2ea9888e94a5b7be01f530c3a7e3ac5c3 100644 (file)
@@ -2700,9 +2700,13 @@ ml_get_cursor_len(void)
     colnr_T
 ml_get_buf_len(buf_T *buf, linenr_T lnum)
 {
-    if (*ml_get_buf(buf, lnum, FALSE) == NUL)
+    char_u     *line;
+
+    if (*(line = ml_get_buf(buf, lnum, FALSE)) == NUL)
         return 0;
 
+    if (buf->b_ml.ml_line_textlen <= 0)
+       buf->b_ml.ml_line_textlen = (int)STRLEN(line) + 1;
     return buf->b_ml.ml_line_textlen - 1;
 }
 
@@ -2799,8 +2803,11 @@ errorret:
        buf->b_ml.ml_line_ptr = (char_u *)dp + start;
        buf->b_ml.ml_line_len = end - start;
 #if defined(FEAT_BYTEOFF) && defined(FEAT_PROP_POPUP)
-       if (buf->b_has_textprop)
-           buf->b_ml.ml_line_textlen = (int)STRLEN(buf->b_ml.ml_line_ptr) + 1;
+       // Text properties come after a NUL byte, so ml_line_len should be
+       // larger than the size of textprop_T if there is any.
+       if (buf->b_has_textprop
+                        && (size_t)buf->b_ml.ml_line_len > sizeof(textprop_T))
+           buf->b_ml.ml_line_textlen = 0;  // call STRLEN() later when needed
        else
 #endif
            buf->b_ml.ml_line_textlen = buf->b_ml.ml_line_len;
index b3b3f6a144bcdc376b975b7b55b704a7f4104411..47a0050ddbd9968c9fc210fa19b45f4e05fe5e94 100644 (file)
@@ -802,8 +802,8 @@ typedef struct memline
 #define ML_ALLOCATED   0x10    // ml_line_ptr is an allocated copy
     int                ml_flags;
 
-    colnr_T    ml_line_len;    // length of the cached line + textproperties, including NUL
-    colnr_T    ml_line_textlen;// length of the cached line, including NUL
+    colnr_T    ml_line_len;    // length of the cached line + NUL + text properties
+    colnr_T    ml_line_textlen;// length of the cached line + NUL, 0 if not known yet
     linenr_T   ml_line_lnum;   // line number of cached line, 0 if not valid
     char_u     *ml_line_ptr;   // pointer to cached line
 
index cc63356153c3be5aa349236f96bc534e16c49f52..d1ca31bf65999d50cf6be6791f11aeb21e714798 100644 (file)
@@ -704,6 +704,8 @@ static char *(features[]) =
 
 static int included_patches[] =
 {   /* Add new patch number below this line */
+/**/
+    163,
 /**/
     162,
 /**/