]> granicus.if.org Git - vim/commitdiff
patch 8.1.1300: in a terminal 'ballooneval' does not work right away v8.1.1300
authorBram Moolenaar <Bram@vim.org>
Wed, 8 May 2019 19:59:25 +0000 (21:59 +0200)
committerBram Moolenaar <Bram@vim.org>
Wed, 8 May 2019 19:59:25 +0000 (21:59 +0200)
Problem:    In a terminal 'ballooneval' does not work right away.
Solution:   Flush output after drawing the balloon.  Add the <Ignore> key
            code.  Add a test.

src/ex_cmds2.c
src/misc2.c
src/testdir/Make_all.mak
src/testdir/dumps/Test_balloon_eval_term_01.dump [new file with mode: 0644]
src/testdir/test_balloon.vim [new file with mode: 0644]
src/version.c

index 07e664867ab754e0eff8918adad4d1c24b272b8c..1e9d18e833509fc65947bf712d7747d966f8df8c 100644 (file)
@@ -229,6 +229,9 @@ profile_zero(proftime_T *tm)
 static timer_T *first_timer = NULL;
 static long    last_timer_id = 0;
 
+/*
+ * Return time left until "due".  Negative if past "due".
+ */
     long
 proftime_time_left(proftime_T *due, proftime_T *now)
 {
@@ -445,7 +448,11 @@ check_due_timer(void)
                balloonEvalForTerm = TRUE;
            }
            if (balloonEval != NULL)
+           {
                general_beval_cb(balloonEval, 0);
+               setcursor();
+               out_flush();
+           }
        }
        else if (next_due == -1 || next_due > this_due)
            next_due = this_due;
index e615f96b505b17546469d817e37bb9d17e2de84f..3ef7c94222049ce23b879f07e5388e92ce934a46 100644 (file)
@@ -2496,6 +2496,7 @@ static struct key_name_entry
 #endif
     {K_PLUG,           (char_u *)"Plug"},
     {K_CURSORHOLD,     (char_u *)"CursorHold"},
+    {K_IGNORE,         (char_u *)"Ignore"},
     {0,                        NULL}
     /* NOTE: When adding a long name update MAX_KEY_NAME_LEN. */
 };
index 2bda7427682cd7cb1203020140f11c2aa91dc853..6b966e6fe8d5568188dc443813a899bd20f54f10 100644 (file)
@@ -68,6 +68,7 @@ NEW_TESTS = \
        test_autoload \
        test_backspace_opt \
        test_backup \
+       test_balloon \
        test_behave \
        test_blob \
        test_blockedit \
@@ -294,6 +295,7 @@ NEW_TESTS_RES = \
        test_autocmd.res \
        test_autoload.res \
        test_backspace_opt.res \
+       test_balloon.res \
        test_blob.res \
        test_blockedit.res \
        test_breakindent.res \
diff --git a/src/testdir/dumps/Test_balloon_eval_term_01.dump b/src/testdir/dumps/Test_balloon_eval_term_01.dump
new file mode 100644 (file)
index 0000000..20a7197
--- /dev/null
@@ -0,0 +1,10 @@
+>o+0&#ffffff0|n|e| |o|n|e| |o|n|e| @38
+@2|o| |t|X|o| |t|w|o| @38
+|t|h|r|e| +0#0000001#ffd7ff255@16| +0#0000000#ffffff0@28
+|~+0#4040ff13&| @2| +0#0000001#ffd7ff255|l|i|n|e| |2| |c|o|l|u|m|n| |6| | +0#4040ff13#ffffff0@28
+|~| @2| +0#0000001#ffd7ff255@16| +0#4040ff13#ffffff0@28
+|~| @48
+|~| @48
+|~| @48
+|~| @48
+| +0#0000000&@31|1|,|1| @10|A|l@1| 
diff --git a/src/testdir/test_balloon.vim b/src/testdir/test_balloon.vim
new file mode 100644 (file)
index 0000000..e518755
--- /dev/null
@@ -0,0 +1,32 @@
+" Tests for 'balloonevalterm'.
+
+if !has('balloon_eval_term') || has('gui_running')
+  finish
+endif
+
+source screendump.vim
+if !CanRunVimInTerminal()
+  finish
+endif
+
+func Test_balloon_eval_term()
+  call writefile([
+       \ 'call setline(1, ["one one one", "two tXo two", "three three three"])',
+       \ 'set balloonevalterm balloonexpr=MyBalloonExpr() balloondelay=100',
+       \ 'func MyBalloonExpr()',
+       \ ' return "line " . v:beval_lnum . " column " . v:beval_col',
+       \ 'endfun',
+       \ 'redraw',
+       \ 'call test_setmouse(2, 6)',
+       \ 'call feedkeys("\<MouseMove>\<Ignore>", "xt")',
+       \ ], 'XTest_beval')
+
+  " Check that the balloon shows up
+  let buf = RunVimInTerminal('-S XTest_beval', {'rows': 10, 'cols': 50})
+  call term_wait(buf, 100)
+  call VerifyScreenDump(buf, 'Test_balloon_eval_term_01', {})
+
+  " clean up
+  call StopVimInTerminal(buf)
+  call delete('XTest_beval')
+endfunc
index 1ea47db720c0779b65e5c7e4720758a1b51ec4fe..7905cdac1953732feb1d8fdb3a88c9e1a631ee0f 100644 (file)
@@ -767,6 +767,8 @@ static char *(features[]) =
 
 static int included_patches[] =
 {   /* Add new patch number below this line */
+/**/
+    1300,
 /**/
     1299,
 /**/