mirror of
https://github.com/brl/mutter.git
synced 2024-12-24 20:12:06 +00:00
Revert "window-wayland: Make sure to save where the position for server-initiated resizes"
This is wrong for client-initiated resizes now.
This reverts commit e6b0525c70
.
This commit is contained in:
parent
e6b0525c70
commit
e94f169d4e
@ -34,9 +34,6 @@
|
|||||||
struct _MetaWindowWayland
|
struct _MetaWindowWayland
|
||||||
{
|
{
|
||||||
MetaWindow parent;
|
MetaWindow parent;
|
||||||
|
|
||||||
int saved_x;
|
|
||||||
int saved_y;
|
|
||||||
};
|
};
|
||||||
|
|
||||||
struct _MetaWindowWaylandClass
|
struct _MetaWindowWaylandClass
|
||||||
@ -122,10 +119,8 @@ meta_window_wayland_move_resize_internal (MetaWindow *window,
|
|||||||
MetaMoveResizeFlags flags,
|
MetaMoveResizeFlags flags,
|
||||||
MetaMoveResizeResultFlags *result)
|
MetaMoveResizeResultFlags *result)
|
||||||
{
|
{
|
||||||
MetaWindowWayland *wl_window = META_WINDOW_WAYLAND (window);
|
|
||||||
gboolean should_move = FALSE;
|
gboolean should_move = FALSE;
|
||||||
gboolean is_wayland_resize = FALSE;
|
gboolean is_wayland_resize = FALSE;
|
||||||
int new_x, new_y;
|
|
||||||
|
|
||||||
g_assert (window->frame == NULL);
|
g_assert (window->frame == NULL);
|
||||||
|
|
||||||
@ -143,8 +138,6 @@ meta_window_wayland_move_resize_internal (MetaWindow *window,
|
|||||||
|
|
||||||
if (is_wayland_resize)
|
if (is_wayland_resize)
|
||||||
{
|
{
|
||||||
int dx, dy;
|
|
||||||
|
|
||||||
/* This is a call to wl_surface_commit(), ignore the constrained_rect and
|
/* This is a call to wl_surface_commit(), ignore the constrained_rect and
|
||||||
* update the real client size to match the buffer size.
|
* update the real client size to match the buffer size.
|
||||||
*/
|
*/
|
||||||
@ -156,21 +149,11 @@ meta_window_wayland_move_resize_internal (MetaWindow *window,
|
|||||||
/* This is a commit of an attach. We should move the window to match the
|
/* This is a commit of an attach. We should move the window to match the
|
||||||
* new position the client wants. */
|
* new position the client wants. */
|
||||||
should_move = TRUE;
|
should_move = TRUE;
|
||||||
|
|
||||||
/* The dx/dy that the client asked for. */
|
|
||||||
dx = requested_rect.x - window->rect.x;
|
|
||||||
dy = requested_rect.y - window->rect.y;
|
|
||||||
|
|
||||||
new_x = wl_window->saved_x + dx;
|
|
||||||
new_y = wl_window->saved_y + dy;
|
|
||||||
}
|
}
|
||||||
|
|
||||||
if (constrained_rect.width != window->rect.width ||
|
if (constrained_rect.width != window->rect.width ||
|
||||||
constrained_rect.height != window->rect.height)
|
constrained_rect.height != window->rect.height)
|
||||||
{
|
{
|
||||||
wl_window->saved_x = constrained_rect.x;
|
|
||||||
wl_window->saved_y = constrained_rect.y;
|
|
||||||
|
|
||||||
meta_wayland_surface_configure_notify (window->surface,
|
meta_wayland_surface_configure_notify (window->surface,
|
||||||
constrained_rect.width,
|
constrained_rect.width,
|
||||||
constrained_rect.height);
|
constrained_rect.height);
|
||||||
@ -180,13 +163,13 @@ meta_window_wayland_move_resize_internal (MetaWindow *window,
|
|||||||
/* We're just moving the window, so we don't need to wait for a configure
|
/* We're just moving the window, so we don't need to wait for a configure
|
||||||
* and then ack to simply move the window. */
|
* and then ack to simply move the window. */
|
||||||
should_move = TRUE;
|
should_move = TRUE;
|
||||||
|
|
||||||
new_x = constrained_rect.x;
|
|
||||||
new_y = constrained_rect.y;
|
|
||||||
}
|
}
|
||||||
|
|
||||||
if (should_move)
|
if (should_move)
|
||||||
{
|
{
|
||||||
|
int new_x = constrained_rect.x;
|
||||||
|
int new_y = constrained_rect.y;
|
||||||
|
|
||||||
if (new_x != window->rect.x || new_y != window->rect.y)
|
if (new_x != window->rect.x || new_y != window->rect.y)
|
||||||
{
|
{
|
||||||
*result |= META_MOVE_RESIZE_RESULT_MOVED;
|
*result |= META_MOVE_RESIZE_RESULT_MOVED;
|
||||||
|
Loading…
Reference in New Issue
Block a user