mirror of
				https://github.com/vim/vim.git
				synced 2025-10-25 09:04:09 -04:00 
			
		
		
		
	patch 8.2.0054: :diffget and :diffput don't have good completion
Problem: :diffget and :diffput don't have good completion. Solution: Add proper completion. (Dominique Pelle, closes #5409)
This commit is contained in:
		| @@ -5058,6 +5058,7 @@ getcompletion({pat}, {type} [, {filtered}])		*getcompletion()* | ||||
| 		command		Ex command (and arguments) | ||||
| 		compiler	compilers | ||||
| 		cscope		|:cscope| suboptions | ||||
| 		diff_buffer     |:diffget| and |:diffput| completion | ||||
| 		dir		directory names | ||||
| 		environment	environment variable names | ||||
| 		event		autocommand events | ||||
|   | ||||
| @@ -2702,6 +2702,15 @@ ExpandBufnames( | ||||
| 	    { | ||||
| 		if (!buf->b_p_bl)	// skip unlisted buffers | ||||
| 		    continue; | ||||
| #ifdef FEAT_DIFF | ||||
| 		if (options & BUF_DIFF_FILTER) | ||||
| 		    // Skip buffers not suitable for | ||||
| 		    // :diffget or :diffput completion. | ||||
| 		    if (buf == curbuf | ||||
| 			    || !diff_mode_buf(curbuf) || !diff_mode_buf(buf)) | ||||
| 			continue; | ||||
| #endif | ||||
|  | ||||
| 		p = buflist_match(®match, buf, p_wic); | ||||
| 		if (p != NULL) | ||||
| 		{ | ||||
|   | ||||
| @@ -1582,7 +1582,15 @@ set_one_cmd_context( | ||||
| 	    xp->xp_context = EXPAND_BUFFERS; | ||||
| 	    xp->xp_pattern = arg; | ||||
| 	    break; | ||||
|  | ||||
| #ifdef FEAT_DIFF | ||||
| 	case CMD_diffget: | ||||
| 	case CMD_diffput: | ||||
| 	    // If current buffer is in diff mode, complete buffer names | ||||
| 	    // which are in diff mode, and different than current buffer. | ||||
| 	    xp->xp_context = EXPAND_DIFF_BUFFERS; | ||||
| 	    xp->xp_pattern = arg; | ||||
| 	    break; | ||||
| #endif | ||||
| 	case CMD_USER: | ||||
| 	case CMD_USER_BUF: | ||||
| 	    if (compl != EXPAND_NOTHING) | ||||
| @@ -2069,6 +2077,10 @@ ExpandFromContext( | ||||
| 	return ExpandOldSetting(num_file, file); | ||||
|     if (xp->xp_context == EXPAND_BUFFERS) | ||||
| 	return ExpandBufnames(pat, num_file, file, options); | ||||
| #ifdef FEAT_DIFF | ||||
|     if (xp->xp_context == EXPAND_DIFF_BUFFERS) | ||||
| 	return ExpandBufnames(pat, num_file, file, options | BUF_DIFF_FILTER); | ||||
| #endif | ||||
|     if (xp->xp_context == EXPAND_TAGS | ||||
| 	    || xp->xp_context == EXPAND_TAGS_LISTFILES) | ||||
| 	return expand_tags(xp->xp_context == EXPAND_TAGS, pat, num_file, file); | ||||
|   | ||||
| @@ -242,6 +242,46 @@ func Test_diffput_two() | ||||
|   bwipe! b | ||||
| endfunc | ||||
|  | ||||
| func Test_diffget_diffput_completion() | ||||
|   new Xdiff1 | diffthis | ||||
|   new Xdiff2 | diffthis | ||||
|   new Xdiff3 | diffthis | ||||
|   new Xdiff4 | ||||
|  | ||||
|   " :diffput and :diffget completes names of buffers which | ||||
|   " are in diff mode and which are different then current buffer. | ||||
|   b Xdiff1 | ||||
|   call feedkeys(":diffput \<C-A>\<C-B>\"\<CR>", 'tx') | ||||
|   call assert_equal('"diffput Xdiff2 Xdiff3', @:) | ||||
|   call feedkeys(":diffget \<C-A>\<C-B>\"\<CR>", 'tx') | ||||
|   call assert_equal('"diffget Xdiff2 Xdiff3', @:) | ||||
|   call assert_equal(['Xdiff2', 'Xdiff3'], getcompletion('', 'diff_buffer')) | ||||
|  | ||||
|   b Xdiff2 | ||||
|   call feedkeys(":diffput \<C-A>\<C-B>\"\<CR>", 'tx') | ||||
|   call assert_equal('"diffput Xdiff1 Xdiff3', @:) | ||||
|   call feedkeys(":diffget \<C-A>\<C-B>\"\<CR>", 'tx') | ||||
|   call assert_equal('"diffget Xdiff1 Xdiff3', @:) | ||||
|   call assert_equal(['Xdiff1', 'Xdiff3'], getcompletion('', 'diff_buffer')) | ||||
|  | ||||
|   b Xdiff3 | ||||
|   call feedkeys(":diffput \<C-A>\<C-B>\"\<CR>", 'tx') | ||||
|   call assert_equal('"diffput Xdiff1 Xdiff2', @:) | ||||
|   call feedkeys(":diffget \<C-A>\<C-B>\"\<CR>", 'tx') | ||||
|   call assert_equal('"diffget Xdiff1 Xdiff2', @:) | ||||
|   call assert_equal(['Xdiff1', 'Xdiff2'], getcompletion('', 'diff_buffer')) | ||||
|  | ||||
|   " No completion when in Xdiff4, it's not in diff mode. | ||||
|   b Xdiff4 | ||||
|   call feedkeys(":diffput \<C-A>\<C-B>\"\<CR>", 'tx') | ||||
|   call assert_equal('"diffput ', @:) | ||||
|   call feedkeys(":diffget \<C-A>\<C-B>\"\<CR>", 'tx') | ||||
|   call assert_equal('"diffget ', @:) | ||||
|   call assert_equal([], getcompletion('', 'diff_buffer')) | ||||
|  | ||||
|   %bwipe | ||||
| endfunc | ||||
|  | ||||
| func Test_dp_do_buffer() | ||||
|   e! one | ||||
|   let bn1=bufnr('%') | ||||
|   | ||||
| @@ -57,6 +57,7 @@ static struct | ||||
|     {EXPAND_USER_DEFINED, "custom"}, | ||||
|     {EXPAND_USER_LIST, "customlist"}, | ||||
| #endif | ||||
|     {EXPAND_DIFF_BUFFERS, "diff_buffer"}, | ||||
|     {EXPAND_DIRECTORIES, "dir"}, | ||||
|     {EXPAND_ENV_VARS, "environment"}, | ||||
|     {EXPAND_EVENTS, "event"}, | ||||
|   | ||||
| @@ -742,6 +742,8 @@ static char *(features[]) = | ||||
|  | ||||
| static int included_patches[] = | ||||
| {   /* Add new patch number below this line */ | ||||
| /**/ | ||||
|     54, | ||||
| /**/ | ||||
|     53, | ||||
| /**/ | ||||
|   | ||||
| @@ -801,6 +801,7 @@ extern int (*dyn_libintl_wputenv)(const wchar_t *envstring); | ||||
| #define EXPAND_MESSAGES		46 | ||||
| #define EXPAND_MAPCLEAR		47 | ||||
| #define EXPAND_ARGLIST		48 | ||||
| #define EXPAND_DIFF_BUFFERS	49 | ||||
|  | ||||
| // Values for exmode_active (0 is no exmode) | ||||
| #define EXMODE_NORMAL		1 | ||||
| @@ -829,6 +830,7 @@ extern int (*dyn_libintl_wputenv)(const wchar_t *envstring); | ||||
| #define WILD_IGNORE_COMPLETESLASH   0x400 | ||||
| #define WILD_NOERROR		    0x800  // sets EW_NOERROR | ||||
| #define WILD_BUFLASTUSED	    0x1000 | ||||
| #define BUF_DIFF_FILTER		    0x2000 | ||||
|  | ||||
| // Flags for expand_wildcards() | ||||
| #define EW_DIR		0x01	// include directory names | ||||
|   | ||||
		Reference in New Issue
	
	Block a user