mirror of
https://github.com/labwc/labwc.git
synced 2026-03-18 05:33:53 -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
|
|
@ -564,7 +564,15 @@ bool view_titlebar_visible(struct view *view);
|
|||
void view_set_ssd_mode(struct view *view, enum lab_ssd_mode mode);
|
||||
void view_set_decorations(struct view *view, enum lab_ssd_mode mode, bool force_ssd);
|
||||
void view_toggle_fullscreen(struct view *view);
|
||||
|
||||
/*
|
||||
* Saves the window position in view->last_placement. This should be called
|
||||
* when a view is first mapped or manually moved by the user.
|
||||
*/
|
||||
void view_save_last_placement(struct view *view);
|
||||
/* Restores and adjusts the view's position from the view->last_placement */
|
||||
void view_adjust_for_layout_change(struct view *view);
|
||||
|
||||
void view_move_to_edge(struct view *view, enum lab_edge direction, bool snap_to_windows);
|
||||
void view_grow_to_edge(struct view *view, enum lab_edge direction);
|
||||
void view_shrink_to_edge(struct view *view, enum lab_edge direction);
|
||||
|
|
|
|||
Loading…
Add table
Add a link
Reference in a new issue