mirror of
				https://github.com/encounter/SDL.git
				synced 2025-10-26 11:40:23 +00:00 
			
		
		
		
	wayland: The rest of the wayland-client 1.18 requirement... Git, please
This commit is contained in:
		
							parent
							
								
									f3ff0c568e
								
							
						
					
					
						commit
						13337e17a5
					
				| @ -632,7 +632,7 @@ endmacro() | |||||||
| # - HAVE_SDL_LOADSO opt | # - HAVE_SDL_LOADSO opt | ||||||
| macro(CheckWayland) | macro(CheckWayland) | ||||||
|   if(SDL_WAYLAND) |   if(SDL_WAYLAND) | ||||||
|     pkg_check_modules(WAYLAND wayland-client wayland-egl wayland-cursor egl "xkbcommon>=0.5.0") |     pkg_check_modules(WAYLAND "wayland-client>=1.18" wayland-egl wayland-cursor egl "xkbcommon>=0.5.0") | ||||||
| 
 | 
 | ||||||
|     if(WAYLAND_FOUND) |     if(WAYLAND_FOUND) | ||||||
|       find_program(WAYLAND_SCANNER NAMES wayland-scanner REQUIRED) |       find_program(WAYLAND_SCANNER NAMES wayland-scanner REQUIRED) | ||||||
|  | |||||||
| @ -1555,7 +1555,7 @@ CheckWayland() | |||||||
|         video_wayland=no |         video_wayland=no | ||||||
|         if  test x$video_opengl_egl = xyes && \ |         if  test x$video_opengl_egl = xyes && \ | ||||||
|             test x$video_opengles_v2 = xyes; then |             test x$video_opengles_v2 = xyes; then | ||||||
|             if $PKG_CONFIG --exists wayland-client wayland-scanner wayland-egl wayland-cursor egl 'xkbcommon >= 0.5.0'; then |             if $PKG_CONFIG --exists 'wayland-client >= 1.18' wayland-scanner wayland-egl wayland-cursor egl 'xkbcommon >= 0.5.0'; then | ||||||
|                 WAYLAND_CFLAGS=`$PKG_CONFIG --cflags wayland-client wayland-egl wayland-cursor xkbcommon` |                 WAYLAND_CFLAGS=`$PKG_CONFIG --cflags wayland-client wayland-egl wayland-cursor xkbcommon` | ||||||
|                 WAYLAND_LIBS=`$PKG_CONFIG --libs wayland-client wayland-egl wayland-cursor xkbcommon` |                 WAYLAND_LIBS=`$PKG_CONFIG --libs wayland-client wayland-egl wayland-cursor xkbcommon` | ||||||
|                 WAYLAND_SCANNER=`$PKG_CONFIG --variable=wayland_scanner wayland-scanner` |                 WAYLAND_SCANNER=`$PKG_CONFIG --variable=wayland_scanner wayland-scanner` | ||||||
|  | |||||||
| @ -72,18 +72,15 @@ SDL_WAYLAND_SYM(void, wl_list_remove, (struct wl_list *)) | |||||||
| SDL_WAYLAND_SYM(int, wl_list_length, (const struct wl_list *)) | SDL_WAYLAND_SYM(int, wl_list_length, (const struct wl_list *)) | ||||||
| SDL_WAYLAND_SYM(int, wl_list_empty, (const struct wl_list *)) | SDL_WAYLAND_SYM(int, wl_list_empty, (const struct wl_list *)) | ||||||
| SDL_WAYLAND_SYM(void, wl_list_insert_list, (struct wl_list *, struct wl_list *)) | SDL_WAYLAND_SYM(void, wl_list_insert_list, (struct wl_list *, struct wl_list *)) | ||||||
| 
 |  | ||||||
| /* These functions are available in Wayland >= 1.4 */ |  | ||||||
| SDL_WAYLAND_MODULE(WAYLAND_CLIENT_1_4) |  | ||||||
| SDL_WAYLAND_SYM(struct wl_proxy *, wl_proxy_marshal_constructor, (struct wl_proxy *, uint32_t opcode, const struct wl_interface *interface, ...)) | SDL_WAYLAND_SYM(struct wl_proxy *, wl_proxy_marshal_constructor, (struct wl_proxy *, uint32_t opcode, const struct wl_interface *interface, ...)) | ||||||
| 
 |  | ||||||
| SDL_WAYLAND_MODULE(WAYLAND_CLIENT_1_10) |  | ||||||
| SDL_WAYLAND_SYM(struct wl_proxy *, wl_proxy_marshal_constructor_versioned, (struct wl_proxy *proxy, uint32_t opcode, const struct wl_interface *interface, uint32_t version, ...)) | SDL_WAYLAND_SYM(struct wl_proxy *, wl_proxy_marshal_constructor_versioned, (struct wl_proxy *proxy, uint32_t opcode, const struct wl_interface *interface, uint32_t version, ...)) | ||||||
| 
 |  | ||||||
| SDL_WAYLAND_MODULE(WAYLAND_CLIENT_1_18) |  | ||||||
| SDL_WAYLAND_SYM(void, wl_proxy_set_tag, (struct wl_proxy *, const char * const *)) | SDL_WAYLAND_SYM(void, wl_proxy_set_tag, (struct wl_proxy *, const char * const *)) | ||||||
| SDL_WAYLAND_SYM(const char * const *, wl_proxy_get_tag, (struct wl_proxy *)) | SDL_WAYLAND_SYM(const char * const *, wl_proxy_get_tag, (struct wl_proxy *)) | ||||||
| 
 | 
 | ||||||
|  | /* These were introduced in 1.20 and introduce a handful of build issues.
 | ||||||
|  |  * See GitHub #5376 and #4636 | ||||||
|  |  * -flibit | ||||||
|  |  */ | ||||||
| SDL_WAYLAND_MODULE(WAYLAND_CLIENT_1_20) | SDL_WAYLAND_MODULE(WAYLAND_CLIENT_1_20) | ||||||
| SDL_WAYLAND_SYM(struct wl_proxy*, wl_proxy_marshal_flags, (struct wl_proxy *proxy, uint32_t opcode, const struct wl_interface *interfac, uint32_t version, uint32_t flags, ...)) | SDL_WAYLAND_SYM(struct wl_proxy*, wl_proxy_marshal_flags, (struct wl_proxy *proxy, uint32_t opcode, const struct wl_interface *interfac, uint32_t version, uint32_t flags, ...)) | ||||||
| SDL_WAYLAND_SYM(struct wl_proxy*, wl_proxy_marshal_array_flags, (struct wl_proxy *proxy, uint32_t opcode, const struct wl_interface *interface, uint32_t version,  uint32_t flags, union wl_argument *args)) | SDL_WAYLAND_SYM(struct wl_proxy*, wl_proxy_marshal_array_flags, (struct wl_proxy *proxy, uint32_t opcode, const struct wl_interface *interface, uint32_t version,  uint32_t flags, union wl_argument *args)) | ||||||
|  | |||||||
| @ -133,32 +133,22 @@ static const char *SDL_WAYLAND_output_tag = "sdl-output"; | |||||||
| 
 | 
 | ||||||
| void SDL_WAYLAND_register_surface(struct wl_surface *surface) | void SDL_WAYLAND_register_surface(struct wl_surface *surface) | ||||||
| { | { | ||||||
|     if (SDL_WAYLAND_HAVE_WAYLAND_CLIENT_1_18) { |     wl_proxy_set_tag((struct wl_proxy *)surface, &SDL_WAYLAND_surface_tag); | ||||||
|         wl_proxy_set_tag((struct wl_proxy *)surface, &SDL_WAYLAND_surface_tag); |  | ||||||
|     } |  | ||||||
| } | } | ||||||
| 
 | 
 | ||||||
| void SDL_WAYLAND_register_output(struct wl_output *output) | void SDL_WAYLAND_register_output(struct wl_output *output) | ||||||
| { | { | ||||||
|     if (SDL_WAYLAND_HAVE_WAYLAND_CLIENT_1_18) { |     wl_proxy_set_tag((struct wl_proxy *)output, &SDL_WAYLAND_output_tag); | ||||||
|         wl_proxy_set_tag((struct wl_proxy *)output, &SDL_WAYLAND_output_tag); |  | ||||||
|     } |  | ||||||
| } | } | ||||||
| 
 | 
 | ||||||
| SDL_bool SDL_WAYLAND_own_surface(struct wl_surface *surface) | SDL_bool SDL_WAYLAND_own_surface(struct wl_surface *surface) | ||||||
| { | { | ||||||
|     if (SDL_WAYLAND_HAVE_WAYLAND_CLIENT_1_18) { |     return wl_proxy_get_tag((struct wl_proxy *) surface) == &SDL_WAYLAND_surface_tag; | ||||||
|         return wl_proxy_get_tag((struct wl_proxy *) surface) == &SDL_WAYLAND_surface_tag; |  | ||||||
|     } |  | ||||||
|     return SDL_TRUE; /* For older clients we have to assume this is us... */ |  | ||||||
| } | } | ||||||
| 
 | 
 | ||||||
| SDL_bool SDL_WAYLAND_own_output(struct wl_output *output) | SDL_bool SDL_WAYLAND_own_output(struct wl_output *output) | ||||||
| { | { | ||||||
|     if (SDL_WAYLAND_HAVE_WAYLAND_CLIENT_1_18) { |     return wl_proxy_get_tag((struct wl_proxy *) output) == &SDL_WAYLAND_output_tag; | ||||||
|         return wl_proxy_get_tag((struct wl_proxy *) output) == &SDL_WAYLAND_output_tag; |  | ||||||
|     } |  | ||||||
|     return SDL_TRUE; /* For older clients we have to assume this is us... */ |  | ||||||
| } | } | ||||||
| 
 | 
 | ||||||
| static void | static void | ||||||
|  | |||||||
		Loading…
	
	
			
			x
			
			
		
	
		Reference in New Issue
	
	Block a user