patch 9.1.0201: gM not working correctly with virt text
Problem:  `gM` would include outer virtual text and its padding when
          getting the line length used to calculate the middle of the
          line, putting the cursor much closer to virtual text lines.
Solution: Exclude outer virtual text in getting the line length for
          `gM`, so that virtual text doesn't influence where the cursor
          is moved to (Dylan Thacker-Smith).
closes: #14262
Signed-off-by: Dylan Thacker-Smith <dylan.ah.smith@gmail.com>
Signed-off-by: Christian Brabandt <cb@256bit.org>
			
			
This commit is contained in:
		
				
					committed by
					
						 Christian Brabandt
						Christian Brabandt
					
				
			
			
				
	
			
			
			
						parent
						
							b2d124c625
						
					
				
				
					commit
					366c81a200
				
			| @ -6066,7 +6066,7 @@ nv_g_cmd(cmdarg_T *cap) | |||||||
| 	{ | 	{ | ||||||
| 	    oap->motion_type = MCHAR; | 	    oap->motion_type = MCHAR; | ||||||
| 	    oap->inclusive = FALSE; | 	    oap->inclusive = FALSE; | ||||||
| 	    i = linetabsize(curwin, curwin->w_cursor.lnum); | 	    i = linetabsize_no_outer(curwin, curwin->w_cursor.lnum); | ||||||
| 	    if (cap->count0 > 0 && cap->count0 <= 100) | 	    if (cap->count0 > 0 && cap->count0 <= 100) | ||||||
| 		coladvance((colnr_T)(i * cap->count0 / 100)); | 		coladvance((colnr_T)(i * cap->count0 / 100)); | ||||||
| 	    else | 	    else | ||||||
|  | |||||||
| @ -0,0 +1,16 @@ | |||||||
|  | | +0#af5f00255#ffffff0@3|A+0#0000001#ffff4012|b|o|v|e| +0#0000000#ffffff0@30 | ||||||
|  | | +0#af5f00255&@1|1| |F+0#0000000&|i|r|s|t| |l|i|n|e| |f|i|t|s> |o|n| |s|c|r|e@1|n| |l|i|n|e|.|A+0#0000001#ffff4012|f|t|e|r | ||||||
|  | | +0#af5f00255#ffffff0@3| +0#0000001#ffff4012|t|e|x|t| |w|r|a|p|s| |t|o| |n|e|x|t| |l|i|n|e|.| +0#0000000#ffffff0@10 | ||||||
|  | | +0#af5f00255&@3| +0#0000000&@5|R+0#0000001#ffff4012|i|g|h|t| |t|e|x|t| |w|r|a|p|s| |t|o| |n|e|x|t| |l|i|n|e|. | ||||||
|  | | +0#af5f00255#ffffff0@3|B+0#0000001#ffff4012|e|l|o|w| +0#0000000#ffffff0@30 | ||||||
|  | | +0#af5f00255&@3|A+0#0000001#ffff4012|b|o|v|e| +0#0000000#ffffff0@30 | ||||||
|  | | +0#af5f00255&@1|2| |A+0#0000001#ffff4012|f|t|e|r| |t|e|x|t| |w|r|a|p|s| |t|o| |n|e|x|t| |l|i|n|e|.| +0#0000000#ffffff0@5 | ||||||
|  | | +0#af5f00255&@3| +0#0000000&@5|R+0#0000001#ffff4012|i|g|h|t| |t|e|x|t| |w|r|a|p|s| |t|o| |n|e|x|t| |l|i|n|e|. | ||||||
|  | | +0#af5f00255#ffffff0@3| +0#0000000&@35 | ||||||
|  | | +0#af5f00255&@3|B+0#0000001#ffff4012|e|l|o|w| +0#0000000#ffffff0@30 | ||||||
|  | | +0#af5f00255&@3|A+0#0000001#ffff4012|b|o|v|e| +0#0000000#ffffff0@30 | ||||||
|  | | +0#af5f00255&@1|3| |T+0#0000000&|h|i|r|d| |l|i|n|e| |f|i|t|s| |o|n| |s|c|r|e@1|n| |l|i|n|e|.|A+0#0000001#ffff4012|f|t|e|r | ||||||
|  | | +0#af5f00255#ffffff0@3| +0#0000001#ffff4012|t|e|x|t| |w|r|a|p|s| |t|o| |n|e|x|t| |l|i|n|e|.| +0#0000000#ffffff0@10 | ||||||
|  | | +0#af5f00255&@3| +0#0000000&@5|R+0#0000001#ffff4012|i|g|h|t| |t|e|x|t| |w|r|a|p|s| |t|o| |n|e|x|t| |l|i|n|e|. | ||||||
|  | | +0#af5f00255#ffffff0@3|B+0#0000001#ffff4012|e|l|o|w| +0#0000000#ffffff0@30 | ||||||
|  | @22|1|,|1|6|-|5|2| @6|A|l@1|  | ||||||
| @ -2690,7 +2690,7 @@ func Test_prop_inserts_text_normal_gj_gk() | |||||||
|   call Run_test_prop_inserts_text_normal_gj_gk('set virtualedit=all') |   call Run_test_prop_inserts_text_normal_gj_gk('set virtualedit=all') | ||||||
| endfunc | endfunc | ||||||
|  |  | ||||||
| func Test_prop_normal_gj_gk_over_outer_virtual_text() | func Test_prop_normal_gj_gk_gM_with_outer_virtual_text() | ||||||
|   CheckRunVimInTerminal |   CheckRunVimInTerminal | ||||||
|  |  | ||||||
|   let lines =<< trim END |   let lines =<< trim END | ||||||
| @ -2708,23 +2708,26 @@ func Test_prop_normal_gj_gk_over_outer_virtual_text() | |||||||
|       endfor |       endfor | ||||||
|       normal 3l |       normal 3l | ||||||
|   END |   END | ||||||
|   call writefile(lines, 'XscriptPropsNormal_gj_gk_over_outer', 'D') |   call writefile(lines, 'XscriptPropsNormal_gj_gk_gM_with_outer_text', 'D') | ||||||
|   let buf = RunVimInTerminal('-S XscriptPropsNormal_gj_gk_over_outer', #{rows: 16, cols: 40}) |   let buf = RunVimInTerminal('-S XscriptPropsNormal_gj_gk_gM_with_outer_text', #{rows: 16, cols: 40}) | ||||||
|   call VerifyScreenDump(buf, 'Test_prop_normal_gj_gk_over_outer_virtual_text_1', {}) |   call VerifyScreenDump(buf, 'Test_prop_normal_gj_gk_gM_with_outer_virtual_text_1', {}) | ||||||
|  |  | ||||||
|   call term_sendkeys(buf, "gj") |   call term_sendkeys(buf, "gj") | ||||||
|   call VerifyScreenDump(buf, 'Test_prop_normal_gj_gk_over_outer_virtual_text_2', {}) |   call VerifyScreenDump(buf, 'Test_prop_normal_gj_gk_gM_with_outer_virtual_text_2', {}) | ||||||
|   call term_sendkeys(buf, "gj") |   call term_sendkeys(buf, "gj") | ||||||
|   call VerifyScreenDump(buf, 'Test_prop_normal_gj_gk_over_outer_virtual_text_3', {}) |   call VerifyScreenDump(buf, 'Test_prop_normal_gj_gk_gM_with_outer_virtual_text_3', {}) | ||||||
|   call term_sendkeys(buf, "gk") |   call term_sendkeys(buf, "gk") | ||||||
|   call VerifyScreenDump(buf, 'Test_prop_normal_gj_gk_over_outer_virtual_text_2', {}) |   call VerifyScreenDump(buf, 'Test_prop_normal_gj_gk_gM_with_outer_virtual_text_2', {}) | ||||||
|   call term_sendkeys(buf, "gk") |   call term_sendkeys(buf, "gk") | ||||||
|   call VerifyScreenDump(buf, 'Test_prop_normal_gj_gk_over_outer_virtual_text_1', {}) |   call VerifyScreenDump(buf, 'Test_prop_normal_gj_gk_gM_with_outer_virtual_text_1', {}) | ||||||
|  |  | ||||||
|   call term_sendkeys(buf, "2gj") |   call term_sendkeys(buf, "2gj") | ||||||
|   call VerifyScreenDump(buf, 'Test_prop_normal_gj_gk_over_outer_virtual_text_3', {}) |   call VerifyScreenDump(buf, 'Test_prop_normal_gj_gk_gM_with_outer_virtual_text_3', {}) | ||||||
|   call term_sendkeys(buf, "2gk") |   call term_sendkeys(buf, "2gk") | ||||||
|   call VerifyScreenDump(buf, 'Test_prop_normal_gj_gk_over_outer_virtual_text_1', {}) |   call VerifyScreenDump(buf, 'Test_prop_normal_gj_gk_gM_with_outer_virtual_text_1', {}) | ||||||
|  |  | ||||||
|  |   call term_sendkeys(buf, "gM") | ||||||
|  |   call VerifyScreenDump(buf, 'Test_prop_normal_gj_gk_gM_with_outer_virtual_text_4', {}) | ||||||
|  |  | ||||||
|   call StopVimInTerminal(buf) |   call StopVimInTerminal(buf) | ||||||
| endfunc | endfunc | ||||||
|  | |||||||
| @ -704,6 +704,8 @@ static char *(features[]) = | |||||||
|  |  | ||||||
| static int included_patches[] = | static int included_patches[] = | ||||||
| {   /* Add new patch number below this line */ | {   /* Add new patch number below this line */ | ||||||
|  | /**/ | ||||||
|  |     201, | ||||||
| /**/ | /**/ | ||||||
|     200, |     200, | ||||||
| /**/ | /**/ | ||||||
|  | |||||||
		Reference in New Issue
	
	Block a user