mirror of
				https://github.com/neovim/neovim.git
				synced 2025-10-26 12:27:24 +00:00 
			
		
		
		
	Merge pull request #31073 from bfredl/cmdchar
fix(cmdline): simplify and correct grapheme cluster adjustment
This commit is contained in:
		| @@ -3596,38 +3596,14 @@ void put_on_cmdline(const char *str, int len, bool redraw) | |||||||
|   memmove(ccline.cmdbuff + ccline.cmdpos, str, (size_t)len); |   memmove(ccline.cmdbuff + ccline.cmdpos, str, (size_t)len); | ||||||
|   ccline.cmdbuff[ccline.cmdlen] = NUL; |   ccline.cmdbuff[ccline.cmdlen] = NUL; | ||||||
|  |  | ||||||
|   { |  | ||||||
|   // When the inserted text starts with a composing character, |   // When the inserted text starts with a composing character, | ||||||
|     // backup to the character before it.  There could be two of them. |   // backup to the character before it. | ||||||
|     int i = 0; |   if (ccline.cmdpos > 0 && (uint8_t)ccline.cmdbuff[ccline.cmdpos] >= 0x80) { | ||||||
|     int c = utf_ptr2char(ccline.cmdbuff + ccline.cmdpos); |     int i = utf_head_off(ccline.cmdbuff, ccline.cmdbuff + ccline.cmdpos); | ||||||
|     // TODO(bfredl): this can be corrected/simplified as utf_head_off implements the |  | ||||||
|     // correct grapheme cluster breaks |  | ||||||
|     while (ccline.cmdpos > 0 && utf_iscomposing_legacy(c)) { |  | ||||||
|       i = utf_head_off(ccline.cmdbuff, ccline.cmdbuff + ccline.cmdpos - 1) + 1; |  | ||||||
|       ccline.cmdpos -= i; |  | ||||||
|       len += i; |  | ||||||
|       c = utf_ptr2char(ccline.cmdbuff + ccline.cmdpos); |  | ||||||
|     } |  | ||||||
|     if (i == 0 && ccline.cmdpos > 0 && arabic_maycombine(c)) { |  | ||||||
|       // Check the previous character for Arabic combining pair. |  | ||||||
|       i = utf_head_off(ccline.cmdbuff, ccline.cmdbuff + ccline.cmdpos - 1) + 1; |  | ||||||
|       if (arabic_combine(utf_ptr2char(ccline.cmdbuff + ccline.cmdpos - i), c)) { |  | ||||||
|         ccline.cmdpos -= i; |  | ||||||
|         len += i; |  | ||||||
|       } else { |  | ||||||
|         i = 0; |  | ||||||
|       } |  | ||||||
|     } |  | ||||||
|     if (i != 0) { |     if (i != 0) { | ||||||
|       // Also backup the cursor position. |       ccline.cmdpos -= i; | ||||||
|       i = ptr2cells(ccline.cmdbuff + ccline.cmdpos); |       len += i; | ||||||
|       ccline.cmdspos -= i; |       ccline.cmdspos = cmd_screencol(ccline.cmdpos); | ||||||
|       msg_col -= i; |  | ||||||
|       if (msg_col < 0) { |  | ||||||
|         msg_col += Columns; |  | ||||||
|         msg_row--; |  | ||||||
|       } |  | ||||||
|     } |     } | ||||||
|   } |   } | ||||||
|  |  | ||||||
|   | |||||||
| @@ -38,6 +38,27 @@ describe('cmdline', function() | |||||||
|       feed([[:<C-R>="foo\nbar\rbaz"<CR>]]) |       feed([[:<C-R>="foo\nbar\rbaz"<CR>]]) | ||||||
|       eq('foo\nbar\rbaz', fn.getcmdline()) |       eq('foo\nbar\rbaz', fn.getcmdline()) | ||||||
|     end) |     end) | ||||||
|  |  | ||||||
|  |     it('pasting handles composing chars properly', function() | ||||||
|  |       local screen = Screen.new(60, 4) | ||||||
|  |       -- 'arabicshape' cheats and always redraws everything which trivially works, | ||||||
|  |       -- this test is for partial redraws in 'noarabicshape' mode. | ||||||
|  |       command('set noarabicshape') | ||||||
|  |       screen:attach() | ||||||
|  |       fn.setreg('a', '💻') | ||||||
|  |       feed(':test 🧑') | ||||||
|  |       screen:expect([[ | ||||||
|  |                                                                     | | ||||||
|  |         {1:~                                                           }|*2 | ||||||
|  |         :test 🧑^                                                    | | ||||||
|  |       ]]) | ||||||
|  |       feed('<c-r><c-r>a') | ||||||
|  |       screen:expect([[ | ||||||
|  |                                                                     | | ||||||
|  |         {1:~                                                           }|*2 | ||||||
|  |         :test 🧑💻^                                                    | | ||||||
|  |       ]]) | ||||||
|  |     end) | ||||||
|   end) |   end) | ||||||
|  |  | ||||||
|   it('Ctrl-Shift-V supports entering unsimplified key notations', function() |   it('Ctrl-Shift-V supports entering unsimplified key notations', function() | ||||||
|   | |||||||
		Reference in New Issue
	
	Block a user
	 bfredl
					bfredl