Merge pull request #2678 from RyanDwyer/reconfigure-on-reposition

Reconfigure xwayland views when repositioned
This commit is contained in:
emersion 2018-09-22 10:09:55 +02:00 committed by GitHub
commit fe7e66407c
No known key found for this signature in database
GPG key ID: 4AEE18F83AFDEB23

View file

@ -6,6 +6,7 @@
#include <string.h> #include <string.h>
#include <time.h> #include <time.h>
#include <wlr/types/wlr_buffer.h> #include <wlr/types/wlr_buffer.h>
#include "sway/config.h"
#include "sway/debug.h" #include "sway/debug.h"
#include "sway/desktop.h" #include "sway/desktop.h"
#include "sway/desktop/idle_inhibit_v1.h" #include "sway/desktop/idle_inhibit_v1.h"
@ -390,6 +391,16 @@ static bool should_configure(struct sway_node *node,
} }
struct sway_container_state *cstate = &node->sway_container->current; struct sway_container_state *cstate = &node->sway_container->current;
struct sway_container_state *istate = instruction->container_state; struct sway_container_state *istate = instruction->container_state;
#ifdef HAVE_XWAYLAND
// Xwayland views are position-aware and need to be reconfigured
// when their position changes.
if (node->sway_container->view->type == SWAY_VIEW_XWAYLAND) {
if (cstate->view_x != istate->view_x ||
cstate->view_y != istate->view_y) {
return true;
}
}
#endif
if (cstate->view_width == istate->view_width && if (cstate->view_width == istate->view_width &&
cstate->view_height == istate->view_height) { cstate->view_height == istate->view_height) {
return false; return false;