aboutsummaryrefslogtreecommitdiff
path: root/src
diff options
context:
space:
mode:
authorJan Edmund Lazo <janedmundlazo@hotmail.com>2018-07-18 21:14:15 -0400
committerJan Edmund Lazo <janedmundlazo@hotmail.com>2018-07-18 21:20:11 -0400
commit2ea619c10b28f908279832f87fb30121aaca7f5a (patch)
tree5e39d007597d933ab1b9cf4c9402aef516b38b3e /src
parent489d32f2b88f8d0796b10e59a4d8b64e4a49b15b (diff)
downloadrneovim-2ea619c10b28f908279832f87fb30121aaca7f5a.tar.gz
rneovim-2ea619c10b28f908279832f87fb30121aaca7f5a.tar.bz2
rneovim-2ea619c10b28f908279832f87fb30121aaca7f5a.zip
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. https://github.com/vim/vim/commit/cdd09aa51a8d34bb384460af4f91026dbff5bf48
Diffstat (limited to 'src')
-rw-r--r--src/nvim/hardcopy.c21
1 files changed, 9 insertions, 12 deletions
diff --git a/src/nvim/hardcopy.c b/src/nvim/hardcopy.c
index b3a9eabdb8..70332fec86 100644
--- a/src/nvim/hardcopy.c
+++ b/src/nvim/hardcopy.c
@@ -2891,6 +2891,7 @@ int mch_print_text_out(char_u *p, size_t len)
double next_pos;
int in_ascii;
int half_width;
+ char_u *tofree = NULL;
char_width = prt_char_width;
@@ -2993,23 +2994,20 @@ int mch_print_text_out(char_u *p, size_t len)
}
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 *)xstrdup("");
+ // Convert from multi-byte to 8-bit encoding
+ 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 {
+ // Multi-byte character strings are represented more efficiently as hex
+ // strings when outputting clean 8 bit PS.
+ while (len-- > 0) {
ch = prt_hexchar[(unsigned)(*p) >> 4];
ga_append(&prt_ps_buffer, (char)ch);
ch = prt_hexchar[(*p) & 0xf];
ga_append(&prt_ps_buffer, (char)ch);
p++;
- } while (--len);
+ }
} else {
/* Add next character to buffer of characters to output.
* 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);
}
- /* Need to free any translated characters */
- if (prt_do_conv)
- xfree(p);
+ // Need to free any translated characters
+ xfree(tofree);
prt_text_run += char_width;
prt_pos_x += char_width;