patch 9.1.1704: Cannot determine non-X11/Wayland clipmethods
Problem: Cannot determine non-X11/Wayland clipmethods Solution: Add the "gui" value to the 'clipmethod' option (Foxe Chen) related: #18006 closes: #18067 Signed-off-by: Foxe Chen <chen.foxe@gmail.com> Signed-off-by: Christian Brabandt <cb@256bit.org>
This commit is contained in:
		
				
					committed by
					
						 Christian Brabandt
						Christian Brabandt
					
				
			
			
				
	
			
			
			
						parent
						
							1f51bbc3b9
						
					
				
				
					commit
					528196c8a9
				
			| @ -2245,10 +2245,13 @@ v:clipmethod	The current method of accessing the clipboard that is being | |||||||
| 		used.  Can either have the value of: | 		used.  Can either have the value of: | ||||||
| 			wayland		The Wayland protocol is being used. | 			wayland		The Wayland protocol is being used. | ||||||
| 			x11		X11 selections are being used. | 			x11		X11 selections are being used. | ||||||
| 			none		The above methods are unavailable or | 			gui		GUI specific method is being used | ||||||
| 					cannot be used. | 			other		Some other method is being used | ||||||
|  | 			none		Clipboard functionality is disabled or | ||||||
|  | 					unavailable. | ||||||
| 		See 'clipmethod' for more details. | 		See 'clipmethod' for more details. | ||||||
|  |  | ||||||
|  |  | ||||||
| 					*v:cmdarg* *cmdarg-variable* | 					*v:cmdarg* *cmdarg-variable* | ||||||
| v:cmdarg	This variable is used for two purposes: | v:cmdarg	This variable is used for two purposes: | ||||||
| 		1. The extra arguments given to a file read/write command. | 		1. The extra arguments given to a file read/write command. | ||||||
|  | |||||||
| @ -1906,30 +1906,30 @@ A jump table for the options with a short description can be found at |Q_op|. | |||||||
| 			{pattern}, this must be the last entry. | 			{pattern}, this must be the last entry. | ||||||
|  |  | ||||||
| 						*'clipmethod'* *'cpm'* | 						*'clipmethod'* *'cpm'* | ||||||
| 'clipmethod' 'cpm'	string	(default for Unix: "wayland,x11", | 'clipmethod' 'cpm'	string	(default for Unix: "wayland,x11,gui,other", | ||||||
| 				 for VMS: "x11", | 				 for VMS: "x11,gui,other", | ||||||
| 				 otherwise: "") | 				 otherwise: "gui,other") | ||||||
| 			global | 			global | ||||||
| 			{only when the |+xterm_clipboard| or | 			{only when the |+clipboard| feature is included} | ||||||
| 			|+wayland_clipboard| features are included} |  | ||||||
| 	Specifies which method of accessing the system clipboard is used, | 	Specifies which method of accessing the system clipboard is used, | ||||||
| 	depending on which method works first or is available.  Supported | 	depending on which method works first or is available.  Supported | ||||||
| 	methods are: | 	methods are: | ||||||
| 		wayland		Wayland selections | 		wayland		Wayland selections | ||||||
| 		x11		X11 selections | 		x11		X11 selections | ||||||
|  | 		gui		GUI specific method | ||||||
|  | 		other		Some other method | ||||||
|  |  | ||||||
| 	Note: This option is ignored when either the GUI is running or if Vim | 	Note: "other" is used on systems without X11/Wayland, such as | ||||||
| 	is run on a system without Wayland or X11 support, such as Windows or | 	MS-Windows or MacOS, when running Vim without the GUI. | ||||||
| 	macOS.  The GUI or system way of accessing the clipboard is always |  | ||||||
| 	used instead. |  | ||||||
|  |  | ||||||
| 	The option value is a list of comma separated items.  The list is | 	The option value is a list of comma separated items.  The list is | ||||||
| 	parsed left to right in order, and the first method that Vim | 	parsed left to right in order, and the first method that Vim | ||||||
| 	determines is available or is working is used as the actual method for | 	determines is available or is working is used as the actual method for | ||||||
| 	accessing the clipboard. | 	accessing the clipboard.  Setting this option to an empty value | ||||||
|  | 	disables the clipboard functionality on all systems. | ||||||
|  |  | ||||||
| 	The current method that is being used can be found in the |v:clipmethod| | 	The current method that is being used can be found in the | ||||||
| 	variable. | 	|v:clipmethod| variable. | ||||||
|  |  | ||||||
| 						*'cmdheight'* *'ch'* | 						*'cmdheight'* *'ch'* | ||||||
| 'cmdheight' 'ch'	number	(default 1) | 'cmdheight' 'ch'	number	(default 1) | ||||||
|  | |||||||
| @ -1,4 +1,4 @@ | |||||||
| *wayland.txt*   For Vim version 9.1.  Last change: 2025 Aug 20 | *wayland.txt*   For Vim version 9.1.  Last change: 2025 Aug 27 | ||||||
|  |  | ||||||
|  |  | ||||||
| 		  VIM REFERENCE MANUAL    by Bram Moolenaar | 		  VIM REFERENCE MANUAL    by Bram Moolenaar | ||||||
| @ -22,7 +22,7 @@ multiple Wayland seats in the same Wayland session. | |||||||
| See |gui-wayland|.  Please note that when using the GUI, Vim uses the toolkit | See |gui-wayland|.  Please note that when using the GUI, Vim uses the toolkit | ||||||
| such as GTK for accessing the clipboard, and does not access the clipboard | such as GTK for accessing the clipboard, and does not access the clipboard | ||||||
| though Wayland.  You can check this though the |v:clipmethod| variable, which | though Wayland.  You can check this though the |v:clipmethod| variable, which | ||||||
| should equal to "none" when running the GUI. | should equal to "gui" when running the GUI. | ||||||
|  |  | ||||||
| Wayland commands: | Wayland commands: | ||||||
| 							*:wlrestore* *:wl* | 							*:wlrestore* *:wl* | ||||||
| @ -72,7 +72,7 @@ selections, see |wayland-primary-selection| for more details. | |||||||
| 							*wayland-persist* | 							*wayland-persist* | ||||||
| If you use X11 cut buffers, no such things exist on Wayland.  Instead to | If you use X11 cut buffers, no such things exist on Wayland.  Instead to | ||||||
| emulate such functionality, a separate clipboard manager must be used in order | emulate such functionality, a separate clipboard manager must be used in order | ||||||
| to persist selection data when a Wayland client exists. | to persist selection data when a Wayland client exits. | ||||||
|  |  | ||||||
| 							*wayland-and-x11* | 							*wayland-and-x11* | ||||||
| If your version of Vim comes compiled with both X11 and Wayland support, then | If your version of Vim comes compiled with both X11 and Wayland support, then | ||||||
|  | |||||||
							
								
								
									
										182
									
								
								src/clipboard.c
									
									
									
									
									
								
							
							
						
						
									
										182
									
								
								src/clipboard.c
									
									
									
									
									
								
							| @ -142,16 +142,16 @@ clip_update_selection(Clipboard_T *clip) | |||||||
| } | } | ||||||
|  |  | ||||||
|     static int |     static int | ||||||
| clip_gen_own_selection(Clipboard_T *cbd) | clip_gen_own_selection(Clipboard_T *cbd UNUSED) | ||||||
| { | { | ||||||
| #if defined(FEAT_XCLIPBOARD) || defined(FEAT_WAYLAND_CLIPBOARD) |     if (clipmethod == CLIPMETHOD_GUI) | ||||||
| # ifdef FEAT_GUI |     { | ||||||
|  | #ifdef FEAT_GUI | ||||||
| 	if (gui.in_use) | 	if (gui.in_use) | ||||||
| 	    return clip_mch_own_selection(cbd); | 	    return clip_mch_own_selection(cbd); | ||||||
|     else | #endif | ||||||
| # endif |     } | ||||||
|     { |     else if (clipmethod == CLIPMETHOD_WAYLAND) | ||||||
| 	if (clipmethod == CLIPMETHOD_WAYLAND) |  | ||||||
|     { |     { | ||||||
| #ifdef FEAT_WAYLAND_CLIPBOARD | #ifdef FEAT_WAYLAND_CLIPBOARD | ||||||
| 	return clip_wl_own_selection(cbd); | 	return clip_wl_own_selection(cbd); | ||||||
| @ -163,11 +163,13 @@ clip_gen_own_selection(Clipboard_T *cbd) | |||||||
| 	return clip_xterm_own_selection(cbd); | 	return clip_xterm_own_selection(cbd); | ||||||
| #endif | #endif | ||||||
|     } |     } | ||||||
|     } |     else if (clipmethod == CLIPMETHOD_OTHER) | ||||||
|     return FAIL; |     { | ||||||
| #else | #if !defined(FEAT_XCLIPBOARD) && !defined(FEAT_WAYLAND_CLIPBOARD) | ||||||
| 	return clip_mch_own_selection(cbd); | 	return clip_mch_own_selection(cbd); | ||||||
| #endif | #endif | ||||||
|  |     } | ||||||
|  |     return FAIL; | ||||||
| } | } | ||||||
|  |  | ||||||
|     void |     void | ||||||
| @ -207,16 +209,16 @@ clip_own_selection(Clipboard_T *cbd) | |||||||
| } | } | ||||||
|  |  | ||||||
|     static void |     static void | ||||||
| clip_gen_lose_selection(Clipboard_T *cbd) | clip_gen_lose_selection(Clipboard_T *cbd UNUSED) | ||||||
| { | { | ||||||
| #if defined(FEAT_XCLIPBOARD) || defined(FEAT_WAYLAND_CLIPBOARD) |     if (clipmethod == CLIPMETHOD_GUI) | ||||||
| # ifdef FEAT_GUI |     { | ||||||
|  | #ifdef FEAT_GUI | ||||||
| 	if (gui.in_use) | 	if (gui.in_use) | ||||||
| 	    clip_mch_lose_selection(cbd); | 	    clip_mch_lose_selection(cbd); | ||||||
|     else | #endif | ||||||
| # endif |     } | ||||||
|     { |     else if (clipmethod == CLIPMETHOD_WAYLAND) | ||||||
| 	if (clipmethod == CLIPMETHOD_WAYLAND) |  | ||||||
|     { |     { | ||||||
| #ifdef FEAT_WAYLAND_CLIPBOARD | #ifdef FEAT_WAYLAND_CLIPBOARD | ||||||
| 	clip_wl_lose_selection(cbd); | 	clip_wl_lose_selection(cbd); | ||||||
| @ -228,10 +230,12 @@ clip_gen_lose_selection(Clipboard_T *cbd) | |||||||
| 	clip_xterm_lose_selection(cbd); | 	clip_xterm_lose_selection(cbd); | ||||||
| #endif | #endif | ||||||
|     } |     } | ||||||
|     } |     else if (clipmethod == CLIPMETHOD_OTHER) | ||||||
| #else |     { | ||||||
|     clip_mch_lose_selection(cbd); | #if !defined(FEAT_XCLIPBOARD) && !defined(FEAT_WAYLAND_CLIPBOARD) | ||||||
|  | 	return clip_mch_lose_selection(cbd); | ||||||
| #endif | #endif | ||||||
|  |     } | ||||||
| } | } | ||||||
|  |  | ||||||
|     void |     void | ||||||
| @ -1257,14 +1261,14 @@ clip_gen_set_selection(Clipboard_T *cbd) | |||||||
| 	    return; | 	    return; | ||||||
| 	} | 	} | ||||||
|     } |     } | ||||||
| #if defined(FEAT_XCLIPBOARD) || defined(FEAT_WAYLAND_CLIPBOARD) |     if (clipmethod == CLIPMETHOD_GUI) | ||||||
| # ifdef FEAT_GUI |     { | ||||||
|  | #ifdef FEAT_GUI | ||||||
| 	if (gui.in_use) | 	if (gui.in_use) | ||||||
| 	clip_mch_set_selection(cbd); | 	clip_mch_set_selection(cbd); | ||||||
|     else | #endif | ||||||
| # endif |     } | ||||||
|     { |     else if (clipmethod == CLIPMETHOD_WAYLAND) | ||||||
| 	if (clipmethod == CLIPMETHOD_WAYLAND) |  | ||||||
|     { |     { | ||||||
| #ifdef FEAT_WAYLAND_CLIPBOARD | #ifdef FEAT_WAYLAND_CLIPBOARD | ||||||
| 	clip_wl_set_selection(cbd); | 	clip_wl_set_selection(cbd); | ||||||
| @ -1276,23 +1280,25 @@ clip_gen_set_selection(Clipboard_T *cbd) | |||||||
| 	clip_xterm_set_selection(cbd); | 	clip_xterm_set_selection(cbd); | ||||||
| #endif | #endif | ||||||
|     } |     } | ||||||
|     } |     else if (clipmethod == CLIPMETHOD_OTHER) | ||||||
| #else |     { | ||||||
|     clip_mch_set_selection(cbd); | #if !defined(FEAT_XCLIPBOARD) && !defined(FEAT_WAYLAND_CLIPBOARD) | ||||||
|  | 	return clip_mch_set_selection(cbd); | ||||||
| #endif | #endif | ||||||
|  |     } | ||||||
| } | } | ||||||
|  |  | ||||||
|     static void |     static void | ||||||
| clip_gen_request_selection(Clipboard_T *cbd) | clip_gen_request_selection(Clipboard_T *cbd UNUSED) | ||||||
| { | { | ||||||
| #if defined(FEAT_XCLIPBOARD) || defined(FEAT_WAYLAND_CLIPBOARD) |     if (clipmethod == CLIPMETHOD_GUI) | ||||||
|  |     { | ||||||
| # ifdef FEAT_GUI | # ifdef FEAT_GUI | ||||||
| 	if (gui.in_use) | 	if (gui.in_use) | ||||||
| 	    clip_mch_request_selection(cbd); | 	    clip_mch_request_selection(cbd); | ||||||
|     else |  | ||||||
| # endif | # endif | ||||||
|     { |     } | ||||||
| 	if (clipmethod == CLIPMETHOD_WAYLAND) |     else if (clipmethod == CLIPMETHOD_WAYLAND) | ||||||
|     { |     { | ||||||
| #ifdef FEAT_WAYLAND_CLIPBOARD | #ifdef FEAT_WAYLAND_CLIPBOARD | ||||||
| 	clip_wl_request_selection(cbd); | 	clip_wl_request_selection(cbd); | ||||||
| @ -1304,10 +1310,12 @@ clip_gen_request_selection(Clipboard_T *cbd) | |||||||
| 	clip_xterm_request_selection(cbd); | 	clip_xterm_request_selection(cbd); | ||||||
| #endif | #endif | ||||||
|     } |     } | ||||||
|     } |     else if (clipmethod == CLIPMETHOD_OTHER) | ||||||
| #else |     { | ||||||
|     clip_mch_request_selection(cbd); | #if !defined(FEAT_XCLIPBOARD) && !defined(FEAT_WAYLAND_CLIPBOARD) | ||||||
|  | 	return clip_mch_request_selection(cbd); | ||||||
| #endif | #endif | ||||||
|  |     } | ||||||
| } | } | ||||||
|  |  | ||||||
| #if (defined(FEAT_X11) && defined(FEAT_XCLIPBOARD) && defined(USE_SYSTEM)) \ | #if (defined(FEAT_X11) && defined(FEAT_XCLIPBOARD) && defined(USE_SYSTEM)) \ | ||||||
| @ -1324,31 +1332,28 @@ clip_x11_owner_exists(Clipboard_T *cbd) | |||||||
|     int |     int | ||||||
| clip_gen_owner_exists(Clipboard_T *cbd UNUSED) | clip_gen_owner_exists(Clipboard_T *cbd UNUSED) | ||||||
| { | { | ||||||
| #ifdef FEAT_XCLIPBOARD |     if (clipmethod == CLIPMETHOD_OTHER) | ||||||
|  |     { | ||||||
| # ifdef FEAT_GUI_GTK | # ifdef FEAT_GUI_GTK | ||||||
| 	if (gui.in_use) | 	if (gui.in_use) | ||||||
| 	    return clip_gtk_owner_exists(cbd); | 	    return clip_gtk_owner_exists(cbd); | ||||||
|     else |  | ||||||
| # endif | # endif | ||||||
|  |     } | ||||||
|  |     else if (clipmethod == CLIPMETHOD_WAYLAND) | ||||||
|     { |     { | ||||||
| 	if (clipmethod == CLIPMETHOD_WAYLAND) | # ifdef FEAT_WAYLAND_CLIPBOARD | ||||||
| 	{ |  | ||||||
| #ifdef FEAT_WAYLAND_CLIPBOARD |  | ||||||
| 	return clip_wl_owner_exists(cbd); | 	return clip_wl_owner_exists(cbd); | ||||||
| #endif | # endif | ||||||
|     } |     } | ||||||
|     else if (clipmethod == CLIPMETHOD_X11) |     else if (clipmethod == CLIPMETHOD_X11) | ||||||
|     { |     { | ||||||
| #ifdef FEAT_XCLIPBOARD | # ifdef FEAT_XCLIPBOARD | ||||||
| 	return clip_x11_owner_exists(cbd); | 	return clip_x11_owner_exists(cbd); | ||||||
| #endif | # endif | ||||||
|     } |     } | ||||||
|     else |     else | ||||||
| 	return FALSE; | 	return FALSE; | ||||||
|     } |     return FALSE; | ||||||
| #else |  | ||||||
|     return TRUE; |  | ||||||
| #endif |  | ||||||
| } | } | ||||||
| #endif | #endif | ||||||
|  |  | ||||||
| @ -2405,7 +2410,7 @@ poll_data: | |||||||
| 	{ | 	{ | ||||||
| 	    if (ga_grow(&buf, 8192) == FAIL) | 	    if (ga_grow(&buf, 8192) == FAIL) | ||||||
| 		break; | 		break; | ||||||
| 	    start = (char_u *)buf.ga_data + buf.ga_len; | 	    start = buf.ga_data + buf.ga_len; | ||||||
| 	} | 	} | ||||||
|     } |     } | ||||||
|  |  | ||||||
| @ -2735,25 +2740,48 @@ get_clipmethod(char_u *str) | |||||||
|  |  | ||||||
| 	if (STRCMP(buf, "wayland") == 0) | 	if (STRCMP(buf, "wayland") == 0) | ||||||
| 	{ | 	{ | ||||||
|  | #ifdef FEAT_GUI | ||||||
|  | 	    if (!gui.in_use) | ||||||
|  | #endif | ||||||
|  | 	    { | ||||||
| #ifdef FEAT_WAYLAND_CLIPBOARD | #ifdef FEAT_WAYLAND_CLIPBOARD | ||||||
| 		if (wayland_cb_is_ready()) | 		if (wayland_cb_is_ready()) | ||||||
| 		    method = CLIPMETHOD_WAYLAND; | 		    method = CLIPMETHOD_WAYLAND; | ||||||
| #endif | #endif | ||||||
| 	    } | 	    } | ||||||
|  | 	} | ||||||
| 	else if (STRCMP(buf, "x11") == 0) | 	else if (STRCMP(buf, "x11") == 0) | ||||||
| 	{ | 	{ | ||||||
|  | #ifdef FEAT_GUI | ||||||
|  | 	    if (!gui.in_use) | ||||||
|  | #endif | ||||||
|  | 	    { | ||||||
| #ifdef FEAT_XCLIPBOARD | #ifdef FEAT_XCLIPBOARD | ||||||
| 	    // x_IOerror_handler() in os_unix.c should set xterm_dpy to NULL if | 		// x_IOerror_handler() in os_unix.c should set xterm_dpy to NULL | ||||||
| 	    // we lost connection to the X server. | 		// if we lost connection to the X server. | ||||||
| 		if (xterm_dpy != NULL) | 		if (xterm_dpy != NULL) | ||||||
| 		{ | 		{ | ||||||
| 		// If the X connection is lost then that handler will longjmp | 		    // If the X connection is lost then that handler will | ||||||
| 		// somewhere else, in that case we will call choose_clipmethod() | 		    // longjmp somewhere else, in that case we will call | ||||||
| 		// again from there, and this if block won't be executed since | 		    // choose_clipmethod() again from there, and this if block | ||||||
| 		// xterm_dpy will be set to NULL. | 		    // won't be executed since xterm_dpy will be set to NULL. | ||||||
| 		    xterm_update(); | 		    xterm_update(); | ||||||
| 		    method = CLIPMETHOD_X11; | 		    method = CLIPMETHOD_X11; | ||||||
| 		} | 		} | ||||||
|  | #endif | ||||||
|  | 	    } | ||||||
|  | 	} | ||||||
|  | 	else if (STRCMP(buf, "gui") == 0) | ||||||
|  | 	{ | ||||||
|  | #ifdef FEAT_GUI | ||||||
|  | 	    if (gui.in_use) | ||||||
|  | 		method = CLIPMETHOD_GUI; | ||||||
|  | #endif | ||||||
|  | 	} | ||||||
|  | 	else if (STRCMP(buf, "other") == 0) | ||||||
|  | 	{ | ||||||
|  | #if !defined(FEAT_XCLIPBOARD) && !defined(FEAT_WAYLAND_CLIPBOARD) | ||||||
|  | 		method = CLIPMETHOD_OTHER; | ||||||
| #endif | #endif | ||||||
| 	} | 	} | ||||||
| 	else | 	else | ||||||
| @ -2779,17 +2807,21 @@ exit: | |||||||
| /* | /* | ||||||
|  * Returns name of clipmethod in a statically allocated string. |  * Returns name of clipmethod in a statically allocated string. | ||||||
|  */ |  */ | ||||||
|     static char * |     static char_u * | ||||||
| clipmethod_to_str(clipmethod_T method) | clipmethod_to_str(clipmethod_T method) | ||||||
| { | { | ||||||
|     switch(method) |     switch(method) | ||||||
|     { |     { | ||||||
| 	case CLIPMETHOD_WAYLAND: | 	case CLIPMETHOD_WAYLAND: | ||||||
| 	    return "wayland"; | 	    return (char_u *)"wayland"; | ||||||
| 	case CLIPMETHOD_X11: | 	case CLIPMETHOD_X11: | ||||||
| 	    return "x11"; | 	    return (char_u *)"x11"; | ||||||
|  | 	case CLIPMETHOD_GUI: | ||||||
|  | 	    return (char_u *)"gui"; | ||||||
|  | 	case CLIPMETHOD_OTHER: | ||||||
|  | 	    return (char_u *)"other"; | ||||||
| 	default: | 	default: | ||||||
| 	    return "none"; | 	    return (char_u *)"none"; | ||||||
|     } |     } | ||||||
| } | } | ||||||
|  |  | ||||||
| @ -2807,29 +2839,13 @@ choose_clipmethod(void) | |||||||
|     if (method == CLIPMETHOD_FAIL) |     if (method == CLIPMETHOD_FAIL) | ||||||
| 	return e_invalid_argument; | 	return e_invalid_argument; | ||||||
|  |  | ||||||
| // If GUI is running or we are not on a system with Wayland or X11, then always | #if defined(FEAT_GUI) && defined(FEAT_WAYLAND) | ||||||
| // return CLIPMETHOD_NONE. System or GUI clipboard handling always overrides. |     if (method == CLIPMETHOD_GUI) | ||||||
| #if defined(FEAT_XCLIPBOARD) || defined(FEAT_WAYLAND_CLIPBOARD) |  | ||||||
| #if defined(FEAT_GUI) |  | ||||||
|     if (gui.in_use) |  | ||||||
|     { |  | ||||||
| #ifdef FEAT_WAYLAND |  | ||||||
| 	// We only interact with Wayland for the clipboard, we can just deinit | 	// We only interact with Wayland for the clipboard, we can just deinit | ||||||
| 	// everything. | 	// everything. | ||||||
| 	wayland_uninit_client(); | 	wayland_uninit_client(); | ||||||
| #endif | #endif | ||||||
|  |  | ||||||
| 	method = CLIPMETHOD_NONE; |  | ||||||
| 	goto lose_sel_exit; |  | ||||||
|     } |  | ||||||
| #endif |  | ||||||
| #else |  | ||||||
|     // If on a system like windows or macos, then clipmethod is irrelevant, we |  | ||||||
|     // use their way of accessing the clipboard. |  | ||||||
|     method = CLIPMETHOD_NONE; |  | ||||||
|     goto exit; |  | ||||||
| #endif |  | ||||||
|  |  | ||||||
|     // Deinitialize clipboard if there is no way to access clipboard |     // Deinitialize clipboard if there is no way to access clipboard | ||||||
|     if (method == CLIPMETHOD_NONE) |     if (method == CLIPMETHOD_NONE) | ||||||
| 	clip_init(FALSE); | 	clip_init(FALSE); | ||||||
| @ -2844,24 +2860,16 @@ choose_clipmethod(void) | |||||||
|     // Disown clipboard if we are switching to a new method |     // Disown clipboard if we are switching to a new method | ||||||
|     if (clipmethod != CLIPMETHOD_NONE && method != clipmethod) |     if (clipmethod != CLIPMETHOD_NONE && method != clipmethod) | ||||||
|     { |     { | ||||||
| #if (defined(FEAT_XCLIPBOARD) || defined(FEAT_WAYLAND_CLIPBOARD)) \ |  | ||||||
| 	&& defined(FEAT_GUI) |  | ||||||
| lose_sel_exit: |  | ||||||
| #endif |  | ||||||
| 	if (clip_star.owned) | 	if (clip_star.owned) | ||||||
| 	    clip_lose_selection(&clip_star); | 	    clip_lose_selection(&clip_star); | ||||||
| 	if (clip_plus.owned) | 	if (clip_plus.owned) | ||||||
| 	    clip_lose_selection(&clip_plus); | 	    clip_lose_selection(&clip_plus); | ||||||
|     } |     } | ||||||
|  |  | ||||||
| #if !defined(FEAT_XCLIPBOARD) && !defined(FEAT_WAYLAND_CLIPBOARD) |  | ||||||
| exit: |  | ||||||
| #endif |  | ||||||
|  |  | ||||||
|     clipmethod = method; |     clipmethod = method; | ||||||
|  |  | ||||||
| #ifdef FEAT_EVAL | #ifdef FEAT_EVAL | ||||||
|     set_vim_var_string(VV_CLIPMETHOD, (char_u*)clipmethod_to_str(method), -1); |     set_vim_var_string(VV_CLIPMETHOD, clipmethod_to_str(method), -1); | ||||||
| #endif | #endif | ||||||
|  |  | ||||||
|     return NULL; |     return NULL; | ||||||
|  | |||||||
| @ -147,7 +147,7 @@ gui_start(char_u *arg UNUSED) | |||||||
| #endif | #endif | ||||||
|     } |     } | ||||||
|     else |     else | ||||||
| 	// Reset clipmethod to CLIPMETHOD_NONE | 	// Reset clipmethod to CLIPMETHOD_GUI | ||||||
| 	choose_clipmethod(); | 	choose_clipmethod(); | ||||||
|  |  | ||||||
| #ifdef FEAT_SOCKETSERVER | #ifdef FEAT_SOCKETSERVER | ||||||
|  | |||||||
| @ -637,11 +637,11 @@ static struct vimoption options[] = | |||||||
| #ifdef FEAT_CLIPBOARD | #ifdef FEAT_CLIPBOARD | ||||||
| 			    (char_u *)&p_cpm, PV_NONE, did_set_clipmethod, expand_set_clipmethod, | 			    (char_u *)&p_cpm, PV_NONE, did_set_clipmethod, expand_set_clipmethod, | ||||||
| # ifdef UNIX | # ifdef UNIX | ||||||
| 			    {(char_u *)"wayland,x11", (char_u *)0L} | 			    {(char_u *)"wayland,x11,gui,other", (char_u *)0L} | ||||||
| # elif defined(VMS) | # elif defined(VMS) | ||||||
| 			    {(char_u *)"x11", (char_u *)0L} | 			    {(char_u *)"x11,gui,other", (char_u *)0L} | ||||||
| # else | # else | ||||||
| 			    {(char_u *)"", (char_u *)0L} | 			    {(char_u *)"gui,other", (char_u *)0L} | ||||||
| # endif | # endif | ||||||
| #else | #else | ||||||
| 			    (char_u *)NULL, PV_NONE, NULL, NULL, | 			    (char_u *)NULL, PV_NONE, NULL, NULL, | ||||||
|  | |||||||
| @ -45,7 +45,7 @@ static char *(p_ff_values[]) = {FF_UNIX, FF_DOS, FF_MAC, NULL}; | |||||||
| // Note: Keep this in sync with did_set_clipboard() | // Note: Keep this in sync with did_set_clipboard() | ||||||
| static char *(p_cb_values[]) = {"unnamed", "unnamedplus", "autoselect", "autoselectplus", "autoselectml", "html", "exclude:", NULL}; | static char *(p_cb_values[]) = {"unnamed", "unnamedplus", "autoselect", "autoselectplus", "autoselectml", "html", "exclude:", NULL}; | ||||||
| // Note: Keep this in sync with get_clipmethod() | // Note: Keep this in sync with get_clipmethod() | ||||||
| static char *(p_cpm_values[]) = {"wayland", "x11", NULL}; | static char *(p_cpm_values[]) = {"wayland", "x11", "gui", "other", NULL}; | ||||||
| #endif | #endif | ||||||
| #ifdef FEAT_CRYPT | #ifdef FEAT_CRYPT | ||||||
| static char *(p_cm_values[]) = {"zip", "blowfish", "blowfish2", | static char *(p_cm_values[]) = {"zip", "blowfish", "blowfish2", | ||||||
|  | |||||||
| @ -1,14 +1,12 @@ | |||||||
| " Tests for clipmethod | " Tests for clipmethod | ||||||
|  |  | ||||||
| source util/window_manager.vim | if has('unix') | ||||||
|  |   source util/window_manager.vim | ||||||
| CheckFeature clipboard_working | endif | ||||||
| CheckFeature xterm_clipboard |  | ||||||
| CheckFeature wayland_clipboard |  | ||||||
| CheckUnix |  | ||||||
|  |  | ||||||
| " Test if no available clipmethod sets v:clipmethod to none and deinits clipboard | " Test if no available clipmethod sets v:clipmethod to none and deinits clipboard | ||||||
| func Test_no_clipmethod_sets_v_clipmethod_none() | func Test_no_clipmethod_sets_v_clipmethod_none() | ||||||
|  |   CheckFeature clipboard_working | ||||||
|   CheckNotGui |   CheckNotGui | ||||||
|  |  | ||||||
|   set clipmethod= |   set clipmethod= | ||||||
| @ -19,6 +17,9 @@ endfunc | |||||||
| " Test if method chosen is in line with clipmethod order | " Test if method chosen is in line with clipmethod order | ||||||
| func Test_clipmethod_order() | func Test_clipmethod_order() | ||||||
|   CheckNotGui |   CheckNotGui | ||||||
|  |   CheckFeature clipboard_working | ||||||
|  |   CheckFeature xterm_clipboard | ||||||
|  |   CheckFeature wayland_clipboard | ||||||
|  |  | ||||||
|   set cpm=wayland,x11 |   set cpm=wayland,x11 | ||||||
|  |  | ||||||
| @ -62,12 +63,12 @@ func Test_clipmethod_order() | |||||||
|   call EndWaylandCompositor(l:wayland_display) |   call EndWaylandCompositor(l:wayland_display) | ||||||
| endfunc | endfunc | ||||||
|  |  | ||||||
| " Test if clipmethod is set to 'none' when gui is started | " Test if clipmethod is set to 'gui' when gui is started | ||||||
| func Test_clipmethod_is_none_when_gui() | func Test_clipmethod_is_gui_when_gui_started() | ||||||
|   CheckCanRunGui |   CheckCanRunGui | ||||||
|  |   CheckFeature clipboard_working | ||||||
|  |  | ||||||
|   let lines =<< trim END |   let lines =<< trim END | ||||||
|     set cpm=wayland,x11 |  | ||||||
|     call writefile([v:clipmethod != ""], 'Cbdscript') |     call writefile([v:clipmethod != ""], 'Cbdscript') | ||||||
|     gui -f |     gui -f | ||||||
|     call writefile([v:clipmethod], 'Cbdscript', 'a') |     call writefile([v:clipmethod], 'Cbdscript', 'a') | ||||||
| @ -78,12 +79,15 @@ func Test_clipmethod_is_none_when_gui() | |||||||
|  |  | ||||||
|   call writefile(lines, 'Cbdscript', 'D') |   call writefile(lines, 'Cbdscript', 'D') | ||||||
|   call system($'{GetVimCommand()} -S Cbdscript') |   call system($'{GetVimCommand()} -S Cbdscript') | ||||||
|   call assert_equal(['1', 'none', 'none'], readfile('Cbdscript')) |   call assert_equal(['1', 'gui', 'gui'], readfile('Cbdscript')) | ||||||
| endfunc | endfunc | ||||||
|  |  | ||||||
| " Test if :clipreset switches methods when current one doesn't work | " Test if :clipreset switches methods when current one doesn't work | ||||||
| func Test_clipreset_switches() | func Test_clipreset_switches() | ||||||
|   CheckNotGui |   CheckNotGui | ||||||
|  |   CheckFeature clipboard_working | ||||||
|  |   CheckFeature xterm_clipboard | ||||||
|  |   CheckFeature wayland_clipboard | ||||||
|   CheckFeature clientserver |   CheckFeature clientserver | ||||||
|   CheckXServer |   CheckXServer | ||||||
|   CheckWaylandCompositor |   CheckWaylandCompositor | ||||||
| @ -173,4 +177,15 @@ func Test_clipreset_switches() | |||||||
|   endif |   endif | ||||||
| endfunc | endfunc | ||||||
|  |  | ||||||
|  | " Test if v:clipmethod is "other" on non-gui versions of MacOS and Windows | ||||||
|  | " builds | ||||||
|  | func Test_clipmethod_is_other_on_non_x11_wayland() | ||||||
|  |   CheckFeature clipboard_working | ||||||
|  |   CheckNotGui | ||||||
|  |   CheckNotFeature wayland | ||||||
|  |   CheckNotFeature x11 | ||||||
|  |  | ||||||
|  |   call assert_equal("other", v:clipmethod) | ||||||
|  | endfunc | ||||||
|  |  | ||||||
| " vim: shiftwidth=2 sts=2 expandtab | " vim: shiftwidth=2 sts=2 expandtab | ||||||
|  | |||||||
| @ -529,7 +529,7 @@ func Test_set_completion_string_values() | |||||||
|     if has('unix') || has('vms') |     if has('unix') || has('vms') | ||||||
|       call assert_match('wayland', getcompletion('set clipmethod=', 'cmdline')[1]) |       call assert_match('wayland', getcompletion('set clipmethod=', 'cmdline')[1]) | ||||||
|     else |     else | ||||||
|       call assert_match('wayland', getcompletion('set clipmethod=', 'cmdline')[0]) |       call assert_match('gui', getcompletion('set clipmethod=', 'cmdline')[0]) | ||||||
|     endif |     endif | ||||||
|   endif |   endif | ||||||
|   call assert_equal('.', getcompletion('set complete=', 'cmdline')[1]) |   call assert_equal('.', getcompletion('set complete=', 'cmdline')[1]) | ||||||
|  | |||||||
| @ -724,6 +724,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 */ | ||||||
|  | /**/ | ||||||
|  |     1704, | ||||||
| /**/ | /**/ | ||||||
|     1703, |     1703, | ||||||
| /**/ | /**/ | ||||||
|  | |||||||
		Reference in New Issue
	
	Block a user