mirror of
				https://gitlab.freedesktop.org/wlroots/wlroots.git
				synced 2025-11-03 09:01:40 -05:00 
			
		
		
		
	Add xwayland activate and fix EGL bug
This commit is contained in:
		
							parent
							
								
									906a816abf
								
							
						
					
					
						commit
						220a6e9bf6
					
				
					 8 changed files with 36 additions and 4 deletions
				
			
		| 
						 | 
					@ -50,5 +50,7 @@ struct wlr_x11_window {
 | 
				
			||||||
void wlr_xwayland_destroy(struct wlr_xwayland *wlr_xwayland);
 | 
					void wlr_xwayland_destroy(struct wlr_xwayland *wlr_xwayland);
 | 
				
			||||||
struct wlr_xwayland *wlr_xwayland_create(struct wl_display *wl_display,
 | 
					struct wlr_xwayland *wlr_xwayland_create(struct wl_display *wl_display,
 | 
				
			||||||
		struct wlr_compositor *compositor);
 | 
							struct wlr_compositor *compositor);
 | 
				
			||||||
 | 
					void wlr_x11_window_activate(struct wlr_xwayland *wlr_xwayland,
 | 
				
			||||||
 | 
							struct wlr_x11_window *window);
 | 
				
			||||||
 | 
					
 | 
				
			||||||
#endif
 | 
					#endif
 | 
				
			||||||
| 
						 | 
					
 | 
				
			||||||
| 
						 | 
					@ -227,13 +227,13 @@ static void gles2_texture_get_buffer_size(struct wlr_texture *texture, struct
 | 
				
			||||||
			return;
 | 
								return;
 | 
				
			||||||
		}
 | 
							}
 | 
				
			||||||
		if (!wlr_egl_query_buffer(tex->egl, resource, EGL_WIDTH,
 | 
							if (!wlr_egl_query_buffer(tex->egl, resource, EGL_WIDTH,
 | 
				
			||||||
				(EGLint*)&width)) {
 | 
									(EGLint*)width)) {
 | 
				
			||||||
			wlr_log(L_ERROR, "could not get size of the buffer "
 | 
								wlr_log(L_ERROR, "could not get size of the buffer "
 | 
				
			||||||
				"(no buffer found)");
 | 
									"(no buffer found)");
 | 
				
			||||||
			return;
 | 
								return;
 | 
				
			||||||
		};
 | 
							};
 | 
				
			||||||
		wlr_egl_query_buffer(tex->egl, resource, EGL_HEIGHT,
 | 
							wlr_egl_query_buffer(tex->egl, resource, EGL_HEIGHT,
 | 
				
			||||||
			(EGLint*)&height);
 | 
								(EGLint*)height);
 | 
				
			||||||
 | 
					
 | 
				
			||||||
		return;
 | 
							return;
 | 
				
			||||||
	}
 | 
						}
 | 
				
			||||||
| 
						 | 
					
 | 
				
			||||||
| 
						 | 
					@ -100,7 +100,9 @@ static void do_cursor_button_press(struct roots_input *input,
 | 
				
			||||||
		input->input_events_idx = (i + 1)
 | 
							input->input_events_idx = (i + 1)
 | 
				
			||||||
			% (sizeof(input->input_events) / sizeof(input->input_events[0]));
 | 
								% (sizeof(input->input_events) / sizeof(input->input_events[0]));
 | 
				
			||||||
		set_view_focus(input, desktop, view);
 | 
							set_view_focus(input, desktop, view);
 | 
				
			||||||
		wlr_seat_keyboard_enter(input->wl_seat, view->wlr_surface);
 | 
							if (view) {
 | 
				
			||||||
 | 
								wlr_seat_keyboard_enter(input->wl_seat, view->wlr_surface);
 | 
				
			||||||
 | 
							}
 | 
				
			||||||
		break;
 | 
							break;
 | 
				
			||||||
	}
 | 
						}
 | 
				
			||||||
}
 | 
					}
 | 
				
			||||||
| 
						 | 
					
 | 
				
			||||||
| 
						 | 
					@ -23,6 +23,8 @@ void view_get_input_bounds(struct roots_view *view, struct wlr_box *box) {
 | 
				
			||||||
		return;
 | 
							return;
 | 
				
			||||||
	}
 | 
						}
 | 
				
			||||||
	box->x = box->y = 0;
 | 
						box->x = box->y = 0;
 | 
				
			||||||
 | 
						box->width = view->wlr_surface->current.width;
 | 
				
			||||||
 | 
						box->height = view->wlr_surface->current.height;
 | 
				
			||||||
}
 | 
					}
 | 
				
			||||||
 | 
					
 | 
				
			||||||
void view_activate(struct roots_view *view, bool activate) {
 | 
					void view_activate(struct roots_view *view, bool activate) {
 | 
				
			||||||
| 
						 | 
					
 | 
				
			||||||
| 
						 | 
					@ -17,6 +17,10 @@ static void handle_destroy(struct wl_listener *listener, void *data) {
 | 
				
			||||||
	free(roots_surface);
 | 
						free(roots_surface);
 | 
				
			||||||
}
 | 
					}
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					static void x11_activate(struct roots_view *view, bool active) {
 | 
				
			||||||
 | 
						wlr_x11_window_activate(view->desktop->xwayland, view->x11_window);
 | 
				
			||||||
 | 
					}
 | 
				
			||||||
 | 
					
 | 
				
			||||||
void handle_xwayland_surface(struct wl_listener *listener, void *data) {
 | 
					void handle_xwayland_surface(struct wl_listener *listener, void *data) {
 | 
				
			||||||
	struct roots_desktop *desktop =
 | 
						struct roots_desktop *desktop =
 | 
				
			||||||
		wl_container_of(listener, desktop, xwayland_surface);
 | 
							wl_container_of(listener, desktop, xwayland_surface);
 | 
				
			||||||
| 
						 | 
					@ -38,6 +42,7 @@ void handle_xwayland_surface(struct wl_listener *listener, void *data) {
 | 
				
			||||||
	view->roots_x11_surface = roots_surface;
 | 
						view->roots_x11_surface = roots_surface;
 | 
				
			||||||
	view->wlr_surface = surface->surface;
 | 
						view->wlr_surface = surface->surface;
 | 
				
			||||||
	view->desktop = desktop;
 | 
						view->desktop = desktop;
 | 
				
			||||||
 | 
						view->activate = x11_activate;
 | 
				
			||||||
	roots_surface->view = view;
 | 
						roots_surface->view = view;
 | 
				
			||||||
	wl_list_insert(&desktop->views, &view->link);
 | 
						wl_list_insert(&desktop->views, &view->link);
 | 
				
			||||||
}
 | 
					}
 | 
				
			||||||
| 
						 | 
					
 | 
				
			||||||
| 
						 | 
					@ -117,6 +117,7 @@ static void wlr_surface_update_size(struct wlr_surface *surface) {
 | 
				
			||||||
 | 
					
 | 
				
			||||||
	surface->current.width = _width;
 | 
						surface->current.width = _width;
 | 
				
			||||||
	surface->current.height = _height;
 | 
						surface->current.height = _height;
 | 
				
			||||||
 | 
						wlr_log(L_DEBUG, "%dx%d", _width, _height);
 | 
				
			||||||
}
 | 
					}
 | 
				
			||||||
 | 
					
 | 
				
			||||||
static void wlr_surface_to_buffer_region(struct wlr_surface *surface,
 | 
					static void wlr_surface_to_buffer_region(struct wlr_surface *surface,
 | 
				
			||||||
| 
						 | 
					
 | 
				
			||||||
| 
						 | 
					@ -308,6 +308,25 @@ static void xcb_init_wm(struct wlr_xwm *xwm) {
 | 
				
			||||||
	xcb_flush(xwm->xcb_conn);
 | 
						xcb_flush(xwm->xcb_conn);
 | 
				
			||||||
}
 | 
					}
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					void wlr_x11_window_activate(struct wlr_xwayland *wlr_xwayland,
 | 
				
			||||||
 | 
							struct wlr_x11_window *window) {
 | 
				
			||||||
 | 
						struct wlr_xwm *xwm = wlr_xwayland->xwm;
 | 
				
			||||||
 | 
						xcb_client_message_event_t m = {0};
 | 
				
			||||||
 | 
						m.response_type = XCB_CLIENT_MESSAGE;
 | 
				
			||||||
 | 
						m.format = 32;
 | 
				
			||||||
 | 
						m.window = window->window_id;
 | 
				
			||||||
 | 
						m.type = xwm->atoms[WM_PROTOCOLS];
 | 
				
			||||||
 | 
						m.data.data32[0] = xwm->atoms[WM_TAKE_FOCUS];
 | 
				
			||||||
 | 
						m.data.data32[1] = XCB_TIME_CURRENT_TIME;
 | 
				
			||||||
 | 
						xcb_send_event_checked(xwm->xcb_conn, 0, window->window_id,
 | 
				
			||||||
 | 
								XCB_EVENT_MASK_SUBSTRUCTURE_REDIRECT, (char*)&m);
 | 
				
			||||||
 | 
						xcb_set_input_focus_checked(xwm->xcb_conn, XCB_INPUT_FOCUS_POINTER_ROOT,
 | 
				
			||||||
 | 
								window->window_id, XCB_CURRENT_TIME);
 | 
				
			||||||
 | 
						xcb_configure_window_checked(xwm->xcb_conn, window->window_id,
 | 
				
			||||||
 | 
								XCB_CONFIG_WINDOW_STACK_MODE, (uint32_t[]){XCB_STACK_MODE_ABOVE});
 | 
				
			||||||
 | 
						xcb_flush(xwm->xcb_conn);
 | 
				
			||||||
 | 
					}
 | 
				
			||||||
 | 
					
 | 
				
			||||||
void xwm_destroy(struct wlr_xwm *xwm) {
 | 
					void xwm_destroy(struct wlr_xwm *xwm) {
 | 
				
			||||||
	if (!xwm) {
 | 
						if (!xwm) {
 | 
				
			||||||
		return;
 | 
							return;
 | 
				
			||||||
| 
						 | 
					
 | 
				
			||||||
| 
						 | 
					@ -52,7 +52,8 @@ enum atom_name {
 | 
				
			||||||
	NET_SUPPORTED,
 | 
						NET_SUPPORTED,
 | 
				
			||||||
	NET_WM_S0,
 | 
						NET_WM_S0,
 | 
				
			||||||
	NET_WM_STATE,
 | 
						NET_WM_STATE,
 | 
				
			||||||
	ATOM_LAST
 | 
						ATOM_LAST,
 | 
				
			||||||
 | 
						WM_TAKE_FOCUS,
 | 
				
			||||||
};
 | 
					};
 | 
				
			||||||
 | 
					
 | 
				
			||||||
static const char * const atom_map[ATOM_LAST] = {
 | 
					static const char * const atom_map[ATOM_LAST] = {
 | 
				
			||||||
| 
						 | 
					
 | 
				
			||||||
		Loading…
	
	Add table
		Add a link
		
	
		Reference in a new issue