mirror of
https://gitlab.freedesktop.org/wlroots/wlroots.git
synced 2024-11-22 15:12:26 +00:00
bug: dont slide over too far
This commit is contained in:
parent
bf5ae85683
commit
8b967fc573
@ -1761,7 +1761,7 @@ static bool wlr_xdg_popup_v6_unconstrain_flip(struct wlr_xdg_popup_v6 *popup,
|
||||
|
||||
static bool wlr_xdg_popup_v6_unconstrain_slide(struct wlr_xdg_popup_v6 *popup,
|
||||
struct wlr_box *toplevel_box) {
|
||||
int offset_x, offset_y;
|
||||
int offset_x = 0, offset_y = 0;
|
||||
wlr_xdg_popup_v6_box_constraints(popup, toplevel_box, &offset_x, &offset_y);
|
||||
|
||||
if (!offset_x && !offset_y) {
|
||||
@ -1784,6 +1784,17 @@ static bool wlr_xdg_popup_v6_unconstrain_slide(struct wlr_xdg_popup_v6 *popup,
|
||||
popup->geometry.y += offset_y;
|
||||
}
|
||||
|
||||
int toplevel_x = 0, toplevel_y = 0;
|
||||
wlr_xdg_popup_v6_get_toplevel_coords(popup, popup->geometry.x,
|
||||
popup->geometry.y, &toplevel_x, &toplevel_y);
|
||||
|
||||
if (slide_x && toplevel_x < toplevel_box->x) {
|
||||
popup->geometry.x += toplevel_box->x - toplevel_x;
|
||||
}
|
||||
if (slide_y && toplevel_y < toplevel_box->y) {
|
||||
popup->geometry.y += toplevel_box->y - toplevel_y;
|
||||
}
|
||||
|
||||
wlr_xdg_popup_v6_box_constraints(popup, toplevel_box, &offset_x, &offset_y);
|
||||
|
||||
return !offset_x && !offset_y;
|
||||
|
Loading…
Reference in New Issue
Block a user