]> git.ipfire.org Git - thirdparty/vim.git/commitdiff
patch 8.1.1302: v:beval_text is not tested in Visual mode v8.1.1302
authorBram Moolenaar <Bram@vim.org>
Wed, 8 May 2019 20:55:16 +0000 (22:55 +0200)
committerBram Moolenaar <Bram@vim.org>
Wed, 8 May 2019 20:55:16 +0000 (22:55 +0200)
Problem:    v:beval_text is not tested in Visual mode.
Solution:   Add a screenshot of the balloon in Visual mode.

src/normal.c
src/testdir/dumps/Test_balloon_eval_term_01.dump
src/testdir/dumps/Test_balloon_eval_term_02.dump [new file with mode: 0644]
src/testdir/test_balloon.vim
src/version.c

index 06595e98c5e5a78308a9508a7c00a59e65485b4d..8d4cf09379ffcb73394400b094333f7872eac0c2 100644 (file)
@@ -2326,10 +2326,10 @@ do_mouse(
 
     if (c == K_MOUSEMOVE)
     {
-       /* Mouse moved without a button pressed. */
+       // Mouse moved without a button pressed.
 #ifdef FEAT_BEVAL_TERM
        ui_may_remove_balloon();
-       if (p_bevalterm && !VIsual_active)
+       if (p_bevalterm)
        {
            profile_setlimit(p_bdlay, &bevalexpr_due);
            bevalexpr_due_set = TRUE;
index 20a7197a7baf4c547c077fc38354c41268d1cfa1..4ffeb8f1188c0dc98f4959c0daaf7f877fa80c1e 100644 (file)
@@ -1,8 +1,8 @@
 >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
+|t|h|r|e| +0#0000001#ffd7ff255@21| +0#0000000#ffffff0@23
+|~+0#4040ff13&| @2| +0#0000001#ffd7ff255|l|i|n|e| |2| |c|o|l|u|m|n| |6|:| |t|X|o| | +0#4040ff13#ffffff0@23
+|~| @2| +0#0000001#ffd7ff255@21| +0#4040ff13#ffffff0@23
 |~| @48
 |~| @48
 |~| @48
diff --git a/src/testdir/dumps/Test_balloon_eval_term_02.dump b/src/testdir/dumps/Test_balloon_eval_term_02.dump
new file mode 100644 (file)
index 0000000..4f4b788
--- /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|e+0&#e0e0e08| |t|h>r+0&#ffffff0|e@1| |t|h|r|e@1| @32
+|~+0#4040ff13&| @2| +0#0000001#ffd7ff255@23| +0#4040ff13#ffffff0@21
+|~| @2| +0#0000001#ffd7ff255|l|i|n|e| |3| |c|o|l|u|m|n| |5|:| |e| |t|h|r| | +0#4040ff13#ffffff0@21
+|~| @2| +0#0000001#ffd7ff255@23| +0#4040ff13#ffffff0@21
+|~| @48
+|~| @48
+|~| @48
+|-+2#0000000&@1| |V|I|S|U|A|L| |-@1| +0&&@9|5| @8|3|,|9| @10|A|l@1| 
index e5187557a2cea77d217e181c05e4c718efb0bb78..966587c31245117ef27d2bb11f2819a66f999b25 100644 (file)
@@ -9,19 +9,24 @@ if !CanRunVimInTerminal()
   finish
 endif
 
-func Test_balloon_eval_term()
-  call writefile([
+let s:common_script = [
        \ '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',
+       \ ' return "line " .. v:beval_lnum .. " column " .. v:beval_col .. ": " .. v:beval_text',
        \ 'endfun',
        \ 'redraw',
+       \ ]
+
+func Test_balloon_eval_term()
+  " Use <Ignore> after <MouseMove> to return from vgetc() without removing
+  " the balloon.
+  call writefile(s:common_script + [
        \ 'call test_setmouse(2, 6)',
        \ 'call feedkeys("\<MouseMove>\<Ignore>", "xt")',
        \ ], 'XTest_beval')
 
-  " Check that the balloon shows up
+  " Check that the balloon shows up after a mouse move
   let buf = RunVimInTerminal('-S XTest_beval', {'rows': 10, 'cols': 50})
   call term_wait(buf, 100)
   call VerifyScreenDump(buf, 'Test_balloon_eval_term_01', {})
@@ -30,3 +35,21 @@ func Test_balloon_eval_term()
   call StopVimInTerminal(buf)
   call delete('XTest_beval')
 endfunc
+
+func Test_balloon_eval_term_visual()
+  " Use <Ignore> after <MouseMove> to return from vgetc() without removing
+  " the balloon.
+  call writefile(s:common_script + [
+       \ 'call test_setmouse(3, 6)',
+       \ 'call feedkeys("3Gevfr\<MouseMove>\<Ignore>", "xt")',
+       \ ], 'XTest_beval_visual')
+
+  " Check that the balloon shows up after a mouse move
+  let buf = RunVimInTerminal('-S XTest_beval_visual', {'rows': 10, 'cols': 50})
+  call term_wait(buf, 100)
+  call VerifyScreenDump(buf, 'Test_balloon_eval_term_02', {})
+
+  " clean up
+  call StopVimInTerminal(buf)
+  call delete('XTest_beval_visual')
+endfunc
index 6f6456b2144d2b5b0df0ce429b94c7d9d14c6f3f..96c72faa275a189aa2bd2beef4351339689a1851 100644 (file)
@@ -767,6 +767,8 @@ static char *(features[]) =
 
 static int included_patches[] =
 {   /* Add new patch number below this line */
+/**/
+    1302,
 /**/
     1301,
 /**/