summaryrefslogtreecommitdiff
diff options
context:
space:
mode:
authorBram Moolenaar <Bram@vim.org>2007-11-06 21:27:31 +0000
committerBram Moolenaar <Bram@vim.org>2007-11-06 21:27:31 +0000
commit9b25ffbb2b2210d8a27316ba38ff100713504285 (patch)
tree225e723d085e0571d69e0fc86a87e6b005d47c2e
parente74455a447758301b9209cb7113a3b727e89c38c (diff)
downloadvim-git-7.1.149.tar.gz
updated for version 7.1-149v7.1.149
-rw-r--r--src/edit.c45
-rw-r--r--src/gui.c14
-rw-r--r--src/version.c2
3 files changed, 50 insertions, 11 deletions
diff --git a/src/edit.c b/src/edit.c
index f764f9bdb..b1a13a9e1 100644
--- a/src/edit.c
+++ b/src/edit.c
@@ -3385,8 +3385,8 @@ ins_compl_prep(c)
if (c != Ctrl_R && vim_is_ctrl_x_key(c))
edit_submode_extra = NULL;
- /* Ignore end of Select mode mapping */
- if (c == K_SELECT)
+ /* Ignore end of Select mode mapping and mouse scroll buttons. */
+ if (c == K_SELECT || c == K_MOUSEDOWN || c == K_MOUSEUP)
return retval;
/* Set "compl_get_longest" when finding the first matches. */
@@ -8652,15 +8652,16 @@ ins_mousescroll(up)
int up;
{
pos_T tpos;
-# if defined(FEAT_GUI) && defined(FEAT_WINDOWS)
- win_T *old_curwin;
+# if defined(FEAT_WINDOWS)
+ win_T *old_curwin = curwin;
+# endif
+# ifdef FEAT_INS_EXPAND
+ int did_scroll = FALSE;
# endif
tpos = curwin->w_cursor;
# if defined(FEAT_GUI) && defined(FEAT_WINDOWS)
- old_curwin = curwin;
-
/* Currently the mouse coordinates are only known in the GUI. */
if (gui.in_use && mouse_row >= 0 && mouse_col >= 0)
{
@@ -8677,10 +8678,23 @@ ins_mousescroll(up)
# endif
undisplay_dollar();
- if (mod_mask & (MOD_MASK_SHIFT | MOD_MASK_CTRL))
- scroll_redraw(up, (long)(curwin->w_botline - curwin->w_topline));
- else
- scroll_redraw(up, 3L);
+# ifdef FEAT_INS_EXPAND
+ /* Don't scroll the window in which completion is being done. */
+ if (!pum_visible()
+# if defined(FEAT_WINDOWS)
+ || curwin != old_curwin
+# endif
+ )
+# endif
+ {
+ if (mod_mask & (MOD_MASK_SHIFT | MOD_MASK_CTRL))
+ scroll_redraw(up, (long)(curwin->w_botline - curwin->w_topline));
+ else
+ scroll_redraw(up, 3L);
+# ifdef FEAT_INS_EXPAND
+ did_scroll = TRUE;
+# endif
+ }
# if defined(FEAT_GUI) && defined(FEAT_WINDOWS)
curwin->w_redr_status = TRUE;
@@ -8689,6 +8703,17 @@ ins_mousescroll(up)
curbuf = curwin->w_buffer;
# endif
+# ifdef FEAT_INS_EXPAND
+ /* The popup menu may overlay the window, need to redraw it.
+ * TODO: Would be more efficient to only redraw the windows that are
+ * overlapped by the popup menu. */
+ if (pum_visible() && did_scroll)
+ {
+ redraw_all_later(NOT_VALID);
+ ins_compl_show_pum();
+ }
+# endif
+
if (!equalpos(curwin->w_cursor, tpos))
{
start_arrow(&tpos);
diff --git a/src/gui.c b/src/gui.c
index b2b8e8499..e5a0c267a 100644
--- a/src/gui.c
+++ b/src/gui.c
@@ -4214,7 +4214,19 @@ gui_do_scroll()
#endif
)
{
- redraw_win_later(wp, VALID);
+ int type = VALID;
+
+#ifdef FEAT_INS_EXPAND
+ if (pum_visible())
+ {
+ type = NOT_VALID;
+ wp->w_lines_valid = 0;
+ }
+#endif
+ /* Don't set must_redraw here, it may cause the popup menu to
+ * disappear when losing focus after a scrollbar drag. */
+ if (wp->w_redr_type < type)
+ wp->w_redr_type = type;
updateWindow(wp); /* update window, status line, and cmdline */
}
diff --git a/src/version.c b/src/version.c
index 5809aca5a..1857c9179 100644
--- a/src/version.c
+++ b/src/version.c
@@ -667,6 +667,8 @@ static char *(features[]) =
static int included_patches[] =
{ /* Add new patch number below this line */
/**/
+ 149,
+/**/
148,
/**/
147,