From b897871ce9a4a6bd033bfe127a83eb6348361739 Mon Sep 17 00:00:00 2001 From: Bram Moolenaar Date: Sat, 16 Mar 2013 21:42:16 +0100 Subject: updated for version 7.3.865 Problem: Mouse position may be wrong. Solution: Let vungetc() restore the mouse position. --- src/getchar.c | 12 ++++++++++++ 1 file changed, 12 insertions(+) (limited to 'src/getchar.c') diff --git a/src/getchar.c b/src/getchar.c index c6d9492ebd..d3d50e9254 100644 --- a/src/getchar.c +++ b/src/getchar.c @@ -1337,6 +1337,10 @@ save_typebuf() static int old_char = -1; /* character put back by vungetc() */ static int old_mod_mask; /* mod_mask for ungotten character */ +#ifdef FEAT_MOUSE +static int old_mouse_row; /* mouse_row related to old_char */ +static int old_mouse_col; /* mouse_col related to old_char */ +#endif #if defined(FEAT_EVAL) || defined(FEAT_EX_EXTRA) || defined(PROTO) @@ -1567,6 +1571,10 @@ vgetc() c = old_char; old_char = -1; mod_mask = old_mod_mask; +#ifdef FEAT_MOUSE + mouse_row = old_mouse_row; + mouse_col = old_mouse_col; +#endif } else { @@ -1877,6 +1885,10 @@ vungetc(c) /* unget one character (can only be done once!) */ { old_char = c; old_mod_mask = mod_mask; +#ifdef FEAT_MOUSE + old_mouse_row = mouse_row; + old_mouse_col = mouse_col; +#endif } /* -- cgit v1.2.3