| Age | Commit message (Collapse) | Author | 
|---|
|  | Implement resizing tiled containers via cursor | 
|  | Instead of relying on bindings being configured, primarily source
new workspace names from workspace-output assignments.
Fixes #2435 | 
|  |  | 
|  | This fixes an issue where views might commit to a transaction ahead of
the first one, and applying the first transaction causes us to save a
buffer of the wrong size. | 
|  | Rather than resizing the split within the container. | 
|  |  | 
|  |  | 
|  |  | 
|  | There was a separate function dispatch_cursor_button_floating which
dealt with the resize and move operations, but as resize is not really
limited to floating views, it doesn't make as much sense to have this
separate. So both functions are now combined into one.
Additionally, dispatch_cursor_button now uses a pattern of returning
early instead of using else-ifs. | 
|  | * The OP_RESIZE seat operation has been renamed to OP_RESIZE_FLOATING,
and OP_RESIZE_TILING has been introduced.
* Similar to the above, seat_begin_resize and handle_resize_motion have
been renamed and tiling variants introduced.
* resize.c's resize_tiled has to be used, so container_resize_tiled has
been introduced in resize.c to allow external code to call it. | 
|  |  | 
|  | Fixes #2450 | 
|  | Remove container_for_each_descendant_bfs | 
|  | The function was not used.
Also renames container_for_each_descendant_dfs to just
container_for_each_descendant. | 
|  | In all cases you can use container_has_ancestor with the arguments
swapped, which is faster than container_has_child. | 
|  |  | 
|  |  | 
|  | Unlike i3, this implementation allows px measurements.
Also fixes a sane size check. | 
|  |  | 
|  |  | 
|  |  | 
|  | This allows for a color to be set when the wallpaper does not fill the
entire output. If specified, the fallback color is also used when the
image path is inaccessible. | 
|  |  | 
|  |  | 
|  |  | 
|  |  | 
|  | It's not right for container_at_view to only return the swayc if a
surface was clicked. | 
|  | Rationale: Sticky containers are always assigned to the visible
workspace.
The basic idea here is to check the destination's output (move.c:190).
But if the command was `move container to workspace x` then a workspace
might have been created for it. We could destroy the workspace in this
case, but that results in unnecessary IPC events.
To avoid this, the logic for `move container to workspace x` has been
adjusted. It now delays creating the workspace until the end, and uses
`workspace_get_initial_output` to determine and check the output before
creating it. | 
|  | * Removes container_floating_move_to_container, instead opting to put
that logic in container_move_to
* In the seat code, focusing a floating view now updates the pending
state only and lets the next transaction carry it over to the current
state. This is required, otherwise it would crash.
* When unfullscreening a floating container, an output check is now done
to see if it should center it. | 
|  | Also adjusts container_floating_translate to not change the current
properties directly. | 
|  | Fix crash when running `move container to workspace back_and_forth` | 
|  | In a multi-output setup, if a sticky container is on one output and
focus is on the other output, and you run (eg) `workspace 1` to focus
the workspace containing the sticky container, an infinite loop would
occur. It would loop infinitely because it would remove the sticky
container from the workspace, add it back to the same workspace, and
then decrement the iterator variable.
The fix just wraps the loop in a workspace comparison. | 
|  | The back_and_forth condition is intended to be handled in the else-if
block, but this was never reached because it remained in the first
block's conditions. | 
|  |  | 
|  | Enable borders on floating SSD xdg-shell views | 
|  |  | 
|  |  | 
|  |  | 
|  | container_move_to handled moving containers to new parents, as well as
moving workspaces to new outputs.
This commit removes the workspace-moving code from this function and
introduces workspace_move_to_output. Moving workspaces using
container_move_to only happened from the move command, so it's been
implemented as a static function in that file.
Simplifying container_move_to makes it easier for me to fix some issues
in #2420. | 
|  |  | 
|  |  | 
|  |  | 
|  |  | 
|  | Allow optional --no-auto-back-and-forth flag, as well as refactoring some logic | 
|  |  | 
|  |  | 
|  |  | 
|  |  | 
|  |  | 
|  | criteria |