# HG changeset patch # User Bram Moolenaar # Date 1550839506 -3600 # Node ID ca0a0b64809cb4ab9282a9516aeb8fa01a7a0899 # Parent 5e40c2b82a0f718a625d9022c58fda249831615e patch 8.1.0969: message written during startup is truncated commit https://github.com/vim/vim/commit/97c2c05ead689f4a5de986c82531fcbd09295cda Author: Bram Moolenaar Date: Fri Feb 22 13:42:07 2019 +0100 patch 8.1.0969: message written during startup is truncated Problem: Message written during startup is truncated. Solution: Restore message after truncating. (closes 3969) diff --git a/src/message.c b/src/message.c --- a/src/message.c +++ b/src/message.c @@ -2627,12 +2627,19 @@ msg_puts_printf(char_u *str, int maxlen) if (*p != NUL && !(silent_mode && p_verbose == 0)) { + int c = -1; + if (maxlen > 0 && STRLEN(p) > (size_t)maxlen) + { + c = p[maxlen]; p[maxlen] = 0; + } if (info_message) mch_msg((char *)p); else mch_errmsg((char *)p); + if (c != -1) + p[maxlen] = c; } msg_didout = TRUE; // assume that line is not empty diff --git a/src/testdir/test_startup.vim b/src/testdir/test_startup.vim --- a/src/testdir/test_startup.vim +++ b/src/testdir/test_startup.vim @@ -537,3 +537,13 @@ func Test_zzz_startinsert() endif call delete('Xtestout') endfunc + +func Test_issue_3969() + if has('gui_running') + " Can't catch the output of gvim. + return + endif + " Check that message is not truncated. + let out = system(GetVimCommand() . ' -es -X -V1 -c "echon ''hello''" -cq') + call assert_equal('hello', out) +endfunc diff --git a/src/version.c b/src/version.c --- a/src/version.c +++ b/src/version.c @@ -780,6 +780,8 @@ static char *(features[]) = static int included_patches[] = { /* Add new patch number below this line */ /**/ + 969, +/**/ 968, /**/ 967,