]> granicus.if.org Git - vim/commitdiff
patch 8.0.1503: access memory beyond end of string v8.0.1503
authorBram Moolenaar <Bram@vim.org>
Sun, 11 Feb 2018 14:38:40 +0000 (15:38 +0100)
committerBram Moolenaar <Bram@vim.org>
Sun, 11 Feb 2018 14:38:40 +0000 (15:38 +0100)
Problem:    Access memory beyond end of string. (Coverity)
Solution:   Keep allocated memory in separate pointer.  Avoid outputting the
            NUL character.

src/hardcopy.c
src/version.c

index 96fab2048a73ba1dc3d142bd89ac172cc3649e12..91f62c39f3ded104c7158a329cd9f6bf74cecb10 100644 (file)
@@ -3382,6 +3382,7 @@ mch_print_text_out(char_u *p, int len UNUSED)
 #ifdef FEAT_MBYTE
     int                in_ascii;
     int                half_width;
+    char_u     *tofree = NULL;
 #endif
 
     char_width = prt_char_width;
@@ -3507,19 +3508,15 @@ mch_print_text_out(char_u *p, int len UNUSED)
 
 #ifdef FEAT_MBYTE
     if (prt_do_conv)
-    {
        /* Convert from multi-byte to 8-bit encoding */
-       p = string_convert(&prt_conv, p, &len);
-       if (p == NULL)
-           p = (char_u *)"";
-    }
+       tofree = p = string_convert(&prt_conv, p, &len);
 
     if (prt_out_mbyte)
     {
        /* Multi-byte character strings are represented more efficiently as hex
         * strings when outputting clean 8 bit PS.
         */
-       do
+       while (len-- > 0)
        {
            ch = prt_hexchar[(unsigned)(*p) >> 4];
            ga_append(&prt_ps_buffer, ch);
@@ -3527,7 +3524,6 @@ mch_print_text_out(char_u *p, int len UNUSED)
            ga_append(&prt_ps_buffer, ch);
            p++;
        }
-       while (--len);
     }
     else
 #endif
@@ -3574,8 +3570,7 @@ mch_print_text_out(char_u *p, int len UNUSED)
 
 #ifdef FEAT_MBYTE
     /* Need to free any translated characters */
-    if (prt_do_conv && (*p != NUL))
-       vim_free(p);
+    vim_free(tofree);
 #endif
 
     prt_text_run += char_width;
index 62fd9edce90d69ef97ce9398ebe6c29f4dde9b00..5c72d8d73d213cf51d8e47e387806b04f5172f1b 100644 (file)
@@ -771,6 +771,8 @@ static char *(features[]) =
 
 static int included_patches[] =
 {   /* Add new patch number below this line */
+/**/
+    1503,
 /**/
     1502,
 /**/