# HG changeset patch # User Christian Brabandt # Date 1500220804 -7200 # Node ID b9928ef8632f0ad97ab88fbd1fed7b3944177665 # Parent 26af18ef94c769165386bad2f8e1647d2d4de1ba patch 8.0.0724: the message for yanking doesn't indicate the register commit https://github.com/vim/vim/commit/e45deb79978677cb41f1477ba4140bccff658fd1 Author: Bram Moolenaar Date: Sun Jul 16 17:56:16 2017 +0200 patch 8.0.0724: the message for yanking doesn't indicate the register Problem: The message for yanking doesn't indicate the register. Solution: Show the register name in the "N lines yanked" message. (Lemonboy, closes #1803, closes #1809) diff --git a/src/Makefile b/src/Makefile --- a/src/Makefile +++ b/src/Makefile @@ -2227,6 +2227,7 @@ test_arglist \ test_regex_char_classes \ test_regexp_latin \ test_regexp_utf8 \ + test_registers \ test_reltime \ test_retab \ test_ruby \ diff --git a/src/ops.c b/src/ops.c --- a/src/ops.c +++ b/src/ops.c @@ -3167,19 +3167,29 @@ op_yank(oparg_T *oap, int deleting, int /* Some versions of Vi use ">=" here, some don't... */ if (yanklines > p_report) { + char namebuf[100]; + + if (oap->regname == NUL) + *namebuf = NUL; + else + vim_snprintf(namebuf, sizeof(namebuf), + " into \"%c", oap->regname); + /* redisplay now, so message is not deleted */ update_topline_redraw(); if (yanklines == 1) { if (oap->block_mode) - MSG(_("block of 1 line yanked")); + smsg((char_u *)_("block of 1 line yanked%s"), namebuf); else - MSG(_("1 line yanked")); + smsg((char_u *)_("1 line yanked%s"), namebuf); } else if (oap->block_mode) - smsg((char_u *)_("block of %ld lines yanked"), yanklines); + smsg((char_u *)_("block of %ld lines yanked%s"), + yanklines, namebuf); else - smsg((char_u *)_("%ld lines yanked"), yanklines); + smsg((char_u *)_("%ld lines yanked%s"), yanklines, + namebuf); } } diff --git a/src/testdir/Make_all.mak b/src/testdir/Make_all.mak --- a/src/testdir/Make_all.mak +++ b/src/testdir/Make_all.mak @@ -184,6 +184,7 @@ NEW_TESTS = test_arabic.res \ test_quickfix.res \ test_quotestar.res \ test_retab.res \ + test_registers.res \ test_ruby.res \ test_search.res \ test_signs.res \ diff --git a/src/testdir/test_registers.vim b/src/testdir/test_registers.vim new file mode 100644 --- /dev/null +++ b/src/testdir/test_registers.vim @@ -0,0 +1,27 @@ + +func Test_yank_shows_register() + enew + set report=0 + call setline(1, ['foo', 'bar']) + " Line-wise + exe 'norm! yy' + call assert_equal('1 line yanked', v:statusmsg) + exe 'norm! "zyy' + call assert_equal('1 line yanked into "z', v:statusmsg) + exe 'norm! yj' + call assert_equal('2 lines yanked', v:statusmsg) + exe 'norm! "zyj' + call assert_equal('2 lines yanked into "z', v:statusmsg) + + " Block-wise + exe "norm! \y" + call assert_equal('block of 1 line yanked', v:statusmsg) + exe "norm! \\"zy" + call assert_equal('block of 1 line yanked into "z', v:statusmsg) + exe "norm! \jy" + call assert_equal('block of 2 lines yanked', v:statusmsg) + exe "norm! \j\"zy" + call assert_equal('block of 2 lines yanked into "z', v:statusmsg) + + bwipe! +endfunc diff --git a/src/version.c b/src/version.c --- a/src/version.c +++ b/src/version.c @@ -770,6 +770,8 @@ static char *(features[]) = static int included_patches[] = { /* Add new patch number below this line */ /**/ + 724, +/**/ 723, /**/ 722,