aboutsummaryrefslogtreecommitdiff
path: root/src/nvim/screen.c
diff options
context:
space:
mode:
authorwatiko <service@mail.watiko.net>2016-02-15 22:40:55 +0900
committerwatiko <service@mail.watiko.net>2016-02-17 21:04:20 +0900
commit46128219462b44d4a5ae964b41812f6953753fed (patch)
tree4f621a3d8c28ebcc5c513c6e8ef9b6c061658f03 /src/nvim/screen.c
parent498eb020498010c157e453daa8a1f3a518a82ff3 (diff)
downloadrneovim-46128219462b44d4a5ae964b41812f6953753fed.tar.gz
rneovim-46128219462b44d4a5ae964b41812f6953753fed.tar.bz2
rneovim-46128219462b44d4a5ae964b41812f6953753fed.zip
vim-patch:7.4.925
Problem: User may yank or put using the register being recorded in. Solution: Add the recording register in the message. (Christian Brabandt, closes vim/vim#470) https://github.com/vim/vim/commit/a0ed84a26897c994512873a895b9fc54e90c6845
Diffstat (limited to 'src/nvim/screen.c')
-rw-r--r--src/nvim/screen.c39
1 files changed, 23 insertions, 16 deletions
diff --git a/src/nvim/screen.c b/src/nvim/screen.c
index 3b5836f0b5..382fcbac25 100644
--- a/src/nvim/screen.c
+++ b/src/nvim/screen.c
@@ -6760,8 +6760,8 @@ int showmode(void)
if (Recording
&& edit_submode == NULL /* otherwise it gets too long */
) {
- MSG_PUTS_ATTR(_("recording"), attr);
- need_clear = TRUE;
+ recording_mode(attr);
+ need_clear = true;
}
mode_displayed = TRUE;
@@ -6800,26 +6800,33 @@ static void msg_pos_mode(void)
msg_row = Rows - 1;
}
-/*
- * Delete mode message. Used when ESC is typed which is expected to end
- * Insert mode (but Insert mode didn't end yet!).
- * Caller should check "mode_displayed".
- */
-void unshowmode(int force)
+/// Delete mode message. Used when ESC is typed which is expected to end
+/// Insert mode (but Insert mode didn't end yet!).
+/// Caller should check "mode_displayed".
+void unshowmode(bool force)
{
- /*
- * Don't delete it right now, when not redrawing or inside a mapping.
- */
- if (!redrawing() || (!force && char_avail() && !KeyTyped))
- redraw_cmdline = TRUE; /* delete mode later */
- else {
+ // Don't delete it right now, when not redrawing or inside a mapping.
+ if (!redrawing() || (!force && char_avail() && !KeyTyped)) {
+ redraw_cmdline = true; // delete mode later
+ } else {
msg_pos_mode();
- if (Recording)
- MSG_PUTS_ATTR(_("recording"), hl_attr(HLF_CM));
+ if (Recording) {
+ recording_mode(hl_attr(HLF_CM));
+ }
msg_clr_eos();
}
}
+static void recording_mode(int attr)
+{
+ MSG_PUTS_ATTR(_("recording"), attr);
+ if (!shortmess(SHM_RECORDING)) {
+ char_u s[4];
+ vim_snprintf((char *)s, ARRAY_SIZE(s), " @%c", Recording);
+ MSG_PUTS_ATTR(s, attr);
+ }
+}
+
/*
* Draw the tab pages line at the top of the Vim window.
*/