vim-patch:8.0.1503: access memory beyond end of string

Problem:    Access memory beyond end of string. (Coverity)
Solution:   Keep allocated memory in separate pointer.  Avoid outputting the
            NUL character.
cdd09aa51a
This commit is contained in:
Jan Edmund Lazo 2018-07-18 21:14:15 -04:00
parent 489d32f2b8
commit 2ea619c10b

View File

@ -2891,6 +2891,7 @@ int mch_print_text_out(char_u *p, size_t len)
double next_pos; double next_pos;
int in_ascii; int in_ascii;
int half_width; int half_width;
char_u *tofree = NULL;
char_width = prt_char_width; char_width = prt_char_width;
@ -2993,23 +2994,20 @@ int mch_print_text_out(char_u *p, size_t len)
} }
if (prt_do_conv) { if (prt_do_conv) {
/* Convert from multi-byte to 8-bit encoding */ // Convert from multi-byte to 8-bit encoding
p = string_convert(&prt_conv, p, &len); tofree = p = string_convert(&prt_conv, p, &len);
if (p == NULL)
p = (char_u *)xstrdup("");
} }
if (prt_out_mbyte) { if (prt_out_mbyte) {
/* Multi-byte character strings are represented more efficiently as hex // Multi-byte character strings are represented more efficiently as hex
* strings when outputting clean 8 bit PS. // strings when outputting clean 8 bit PS.
*/ while (len-- > 0) {
do {
ch = prt_hexchar[(unsigned)(*p) >> 4]; ch = prt_hexchar[(unsigned)(*p) >> 4];
ga_append(&prt_ps_buffer, (char)ch); ga_append(&prt_ps_buffer, (char)ch);
ch = prt_hexchar[(*p) & 0xf]; ch = prt_hexchar[(*p) & 0xf];
ga_append(&prt_ps_buffer, (char)ch); ga_append(&prt_ps_buffer, (char)ch);
p++; p++;
} while (--len); }
} else { } else {
/* Add next character to buffer of characters to output. /* Add next character to buffer of characters to output.
* Note: One printed character may require several PS characters to * Note: One printed character may require several PS characters to
@ -3043,9 +3041,8 @@ int mch_print_text_out(char_u *p, size_t len)
ga_append(&prt_ps_buffer, (char)ch); ga_append(&prt_ps_buffer, (char)ch);
} }
/* Need to free any translated characters */ // Need to free any translated characters
if (prt_do_conv) xfree(tofree);
xfree(p);
prt_text_run += char_width; prt_text_run += char_width;
prt_pos_x += char_width; prt_pos_x += char_width;