patch 9.1.1676: completion: long line shown twice
Problem:  completion: long line shown twice
          (Maxim Kim)
Solution: Fix the issue, disable an incorrect test.
          (Girish Palya)
fixes: #18035
closes: #18088
Signed-off-by: Girish Palya <girishji@gmail.com>
Signed-off-by: Christian Brabandt <cb@256bit.org>
			
			
This commit is contained in:
		
				
					committed by
					
						 Christian Brabandt
						Christian Brabandt
					
				
			
			
				
	
			
			
			
						parent
						
							e06d81fe67
						
					
				
				
					commit
					57379302aa
				
			| @ -946,12 +946,10 @@ cmdline_wildchar_complete( | ||||
|     int		res; | ||||
|     int		j; | ||||
|     int		options = WILD_NO_BEEP; | ||||
|     int		noselect = (wim_flags[0] & WIM_NOSELECT) != 0; | ||||
|     int		noselect = p_wmnu && (wim_flags[0] & WIM_NOSELECT); | ||||
|  | ||||
|     if (wim_flags[wim_index] & WIM_BUFLASTUSED) | ||||
| 	options |= WILD_BUFLASTUSED; | ||||
|     if (noselect) | ||||
| 	options |= WILD_KEEP_SOLE_ITEM; | ||||
|     if (xp->xp_numfiles > 0)   // typed p_wc at least twice | ||||
|     { | ||||
| 	// if 'wildmode' contains "list" may still need to list | ||||
| @ -992,7 +990,11 @@ cmdline_wildchar_complete( | ||||
| 	if (wim_flags[0] & WIM_LONGEST) | ||||
| 	    res = nextwild(xp, WILD_LONGEST, options, escape); | ||||
| 	else | ||||
| 	{ | ||||
| 	    if (noselect || (wim_flags[wim_index] & WIM_LIST)) | ||||
| 		options |= WILD_NOSELECT; | ||||
| 	    res = nextwild(xp, WILD_EXPAND_KEEP, options, escape); | ||||
| 	} | ||||
|  | ||||
| 	// Remove popup window if no completion items are available | ||||
| 	if (redraw_if_menu_empty && xp->xp_numfiles <= 0) | ||||
| @ -1022,25 +1024,12 @@ cmdline_wildchar_complete( | ||||
| 	    if ((wim_flags[wim_index] & WIM_LIST) | ||||
| 		    || (p_wmnu && (wim_flags[wim_index] & (WIM_FULL | WIM_NOSELECT)))) | ||||
| 	    { | ||||
| 		if (!(wim_flags[0] & WIM_LONGEST)) | ||||
| 		{ | ||||
| 		    int p_wmnu_save = p_wmnu; | ||||
|  | ||||
| 		    p_wmnu = 0; | ||||
|  | ||||
| 		    // remove match | ||||
| 		    nextwild(xp, WILD_PREV, options, escape); | ||||
| 		    p_wmnu = p_wmnu_save; | ||||
| 		} | ||||
| 		(void)showmatches(xp, p_wmnu | ||||
| 			&& ((wim_flags[wim_index] & WIM_LIST) == 0), noselect); | ||||
| 		redrawcmd(); | ||||
| 		*did_wild_list = TRUE; | ||||
| 		if (wim_flags[wim_index] & WIM_LONGEST) | ||||
| 		    nextwild(xp, WILD_LONGEST, options, escape); | ||||
| 		else if ((wim_flags[wim_index] & WIM_FULL) | ||||
| 			&& !(wim_flags[wim_index] & WIM_NOSELECT)) | ||||
| 		    nextwild(xp, WILD_NEXT, options, escape); | ||||
| 	    } | ||||
| 	    else | ||||
| 		vim_beep(BO_WILD); | ||||
|  | ||||
		Reference in New Issue
	
	Block a user