mirror of
https://github.com/labwc/labwc.git
synced 2026-04-07 08:21:20 -04:00
view: save view->last_placement on initial positioning
Fix a regression introduced in3f223fe5where output layout changes may move xdg views outside of the output layout with the error: `view has no last placement info`. This happens also for X11 views if they don't specify its own geometry on map. Recent changes introduced `view->last_placement` which is used to restore view positions after layout changes. This is supposed to be updated when a view is mapped or manually moved by the user. However,3f223fe5replaced `view_place_by_policy()` with `view_compute_position_by_policy()` in the xdg view map handler. Unlike `view_place_by_policy()`, this function does not update `view->last_placement`, leaving it unset at the time of output layout changes. Therefore, this patch adds explicit calls to `view_save_last_placement()` in the map handler to ensure `view->last_placement` is always set for mapped views.
This commit is contained in:
parent
1f776466a8
commit
3bb4ccd22d
4 changed files with 16 additions and 5 deletions
|
|
@ -786,6 +786,9 @@ set_initial_position(struct view *view,
|
|||
}
|
||||
}
|
||||
|
||||
/* view->last_placement is still unset if has_position=true */
|
||||
view_save_last_placement(view);
|
||||
|
||||
/*
|
||||
* Always make sure the view is onscreen and adjusted for any
|
||||
* layout changes that could have occurred between map_request
|
||||
|
|
|
|||
Loading…
Add table
Add a link
Reference in a new issue