aboutsummaryrefslogtreecommitdiff
path: root/include
AgeCommit message (Collapse)AuthorLines
2021-02-09transaction: Move centering to view_center_surfaceKenny Levinsen-0/+1
This will allow us to reuse it for centering elsewhere.
2021-02-04Declare all struct cmd_handler arrays constManuel Stoeckl-3/+3
And make the functions handling these arrays use const types.
2021-01-12Rename output_layer_for_each_surface_{toplevel,popup}Simon Ser-2/+2
Swap the "surface" part for consistency with wlroots' naming.
2021-01-12Switch to wlr_xdg_surface_for_each_popup_surfaceSimon Ser-4/+4
Instead of calling wlr_xdg_surface_for_each_popup and then wlr_surface_for_each_surface, use the new for_each_popup_surface helper introduced in [1] that does it in one go. [1]: https://github.com/swaywm/wlroots/pull/2609
2021-01-01input: Clean up input_method_relay in seat_destoy()Andri Yngvason-0/+2
This fixes a crash that happens when input_method_new or text_method_new events are emitted after the seat has been freed.
2020-12-20introduce workspace_squashRonan Pigott-0/+28
workspace_squash is container_flatten in the reverse direction. Instead of eliminating redundant splits that are parents of the target container, it eliminates pairs of redundant H/V splits that are children of the workspace. Splits are redundant if a con and its grandchild have the same layout, and the immediate child has the opposite split. For example, layouts are transformed like: H[V[H[app1 app2]] app3] -> H[app1 app2 app3] i3 uses this operation to simplify the tree after moving heavily nested containers to a higher level in the tree via an orthogonal move.
2020-12-20Change workspace_layout to match i3 behaviorRonan Pigott-2/+2
In i3, the workspace_layout command does not affect the workspace layout. Instead, new workspace level containers are wrapped in the desired layout and the workspace layout always defaults to the output orientation.
2020-12-16Fix swaybar tray for non-systemdArav K-1/+1
Meson's generated config.h header defines false macros as 0, not undefined. This means that the header line, which was checking for the definition existing, not a non-zero value, was incorrect. Now the swaybar tray can be used with systemd, elogind, or basu.
2020-12-09build: add basu as sd-bus providerSimon Ser-0/+2
2020-12-09build: introduce sd-bus-provider optionSimon Ser-2/+2
This allows to select a specific provider for the sd-bus library.
2020-12-07Add layer shell subsurfacesVlad Pănăzan-0/+11
Damage subsurfaces created by layer surfaces on map, unmap and commit. This fixes the flicker of Gtk Popovers. Fixes #5617
2020-12-06input/cursor: unhide cursor on synthetic inputTudor Brindus-1/+3
Fixes #5847.
2020-12-04common: make 'lenient_strcmp' arguments constPaul Riou-1/+1
Prevents build failures when calling the function with 'const char *' arguments. This is also more accurate since the function is not expected to modify the args.
2020-11-11tree/container: introduce `container_is_sticky[_or_child]` functionsTudor Brindus-0/+7
To query whether a container is sticky, checking `con->is_sticky` is insufficient. `container_is_floating_or_child` must also return true; this led to a lot of repetition. This commit introduces `container_is_sticky[_or_child]` functions, and switches all stickiness checks to use them. (Including ones where the container is already known to be floating, for consistency.)
2020-11-01commands/focus: force container warp when fulfilling `focus mode_toggle`Tudor Brindus-1/+1
This commit switches focusing behavior to force a warp when executing `focus mode_toggle`. Fixes #5772.
2020-10-31input: remove motion deltas from seatop callbacksTudor Brindus-9/+4
Straightforward cleanup, they haven't been used for a while.
2020-10-30hide_cursor: Add an option to hide when typingTamir Zahavi-Brunner-0/+13
Add an option for the `hide_cursor` command to hide the cursor when typing, i.e. whenever a key is pressed.
2020-10-27output: evacuate sticky containers only if new output has a workspacemwenzkowski-0/+2
Sticky floating containers on an otherwise empty workspace can only be evacuated if the new output has an active workspace. The noop output may not have one and in that case we have to move the whole workspace to the new output.
2020-10-18transaction: validate X transaction completions by geometry, not sizeTudor Brindus-3/+9
Xwayland views are aware of their coordinates, so validating transaction completions should take into account the reported coordinates of the view. Prior to this commit they didn't, and matching dimensions would suffice to validate the transaction. Also introduced `transaction_notify_view_ready_immediately` to support the fix from d0f7e0f without jumping through hoops to figure out the geometry of an `xdg_shell` view.
2020-10-18xwayland: listen to `set_geometry` eventTudor Brindus-0/+1
Closes #5735, refs #3007. This makes the "Search everywhere" dialog in JetBrains IDEs movable.
2020-10-12input/tablet: add tool_mode option to set tablet tools as relative inputTudor Brindus-0/+16
Closes #4139.
2020-10-11Add support for workspace_min_width bar option.Tarmack-0/+3
2020-10-10xwayland: support views that change override-redirect statusTobias Langendorf-0/+2
2020-09-14swaynag: add details background optionMustafa Abdul-Kader-0/+1
Adds a new config option for details background for swaynag issue/#5673
2020-09-04swaynag: adds option to separately specify the text color for buttonsoliver-giersch-0/+1
2020-08-27Use wlr_output_event_commitSimon Ser-2/+1
Instead of listening to both transform and scale events, we can listen to the commit event and use the new wlr_output_event_commit struct to decide what to do. This de-duplicates some of the work we were doing twice when an output was re-configured. Depends on [1]. [1]: https://github.com/swaywm/wlroots/pull/2315
2020-08-24exec: fix validation during config reloadKonstantin Pospelov-0/+6
Split cmd_exec_always into separate methods for general validation and process creation. This fixes a potential call of join_args with 0 arguments.
2020-08-05view: remove foreign toplevel listeners on destroyRonan Pigott-0/+1
2020-08-05view: implement foreign toplevel fullscreen requestRonan Pigott-0/+1
2020-07-22Fix X11 clients getting stuck minimizedTobias Langendorf-0/+1
Usually it should be enough to simply not grant a client's minimize request, however some applications (Steam, fullscreen games in Wine) don't wait for the compositor and minimize anyway, getting them stuck in an unrecoverable state. Restoring them immediately lead to heavy flickering when unfocused on my test application (Earth Defense Force 5 via Steam), so it's preferable to grant their request without actually minimizing and then restoring them once they are in focus again.
2020-07-21moved and renamed movement-unit parsing to commonNils Schulte-0/+24
2020-07-13input: implement xdg_toplevel interactive resize hintsRonan Pigott-0/+3
2020-07-10config/output: don't change output state before commitSimon Ser-2/+2
Previously, we called output_disable prior to wlr_output_commit. This mutates Sway's output state before the output commit actually succeeds. This results in Sway's state getting out-of-sync with wlroots'. An alternative fix [1] was to revert the changes made by output_disable in case of failure. This is a little complicated. Instead, this patch makes it so Sway's internal state is never changed before a successful wlr_output commit. We had two output flags: enabled and configured. However enabled was set prior to the output becoming enabled, and was used to prevent the output event handlers (specifically, the mode handler) from calling apply_output_config again (infinite loop). Rename enabled to enabling and use it exclusively for this purpose. Rename configure to enabled, because that's what it really means. [1]: https://github.com/swaywm/sway/pull/5521 Closes: https://github.com/swaywm/sway/issues/5483
2020-07-07Reload command now matches i3's implementationGeoffrey Casper-0/+1
2020-07-01commands/move: unwrap workspace container on move to new workspaceTudor Brindus-0/+3
If moving e.g. `T[app app]` into a new workspace with `workspace_layout tabbed`, then post-move the tree in that workspace will be `T[T[app app]]`. This still happens with horizontal or vertical workspace layout, but is less visible since those containers have no decorations. Fixes #5426.
2020-06-30seat: Refocus seat when wlr_drag is destroyedKenny Levinsen-0/+6
wlr_drag installs grabs for the full duration of the drag, leading to the drag target not being focused when the drag ends. This leads to unexpected focus behavior, especially for the keyboard which requires toggling focus away and back to set. We can only fix the focus once the grabs are released, so refocus the seat when the wlr_drag destroy event is received. Closes: https://github.com/swaywm/sway/issues/5116
2020-06-23Implement wlr-foreign-toplevel-management-v1Drew DeVault-0/+6
2020-06-19input: disable events for map_to_output devices when output not presentTudor Brindus-1/+3
Fixes #3449.
2020-06-18input/pointer: don't trigger pointer bindings for emulated inputTudor Brindus-1/+1
Prior to this commit, a tablet device could trigger mouse button down bindings if the pen was pressed on a surface that didn't bind tablet handlers -- but it wouldn't if the surface did bind tablet handlers. We should expose consistent behavior to users so that they don't have to care about emulated vs. non-emulated input, so stop triggering bindings for any non-pointer devices.
2020-06-18input/cursor: send idle events based off device type, not input typeTudor Brindus-1/+1
Previously, a tablet or touch device could report activity as a pointer device if it went through pointer emulation. This commit refactors idle sources to be consistently reported based on the type of the device that generated an input event, and now how that input event is being processed.
2020-06-17Add support for viewporterSimon Ser-0/+1
Depends on [1]. [1]: https://github.com/swaywm/wlroots/pull/2092
2020-06-16input/keyboard: wlr_keyboard_group enter and leaveBrian Ashworth-0/+2
This adds support for wlr_keyboard_group's enter and leave events. The enter event just updates the keyboard's state. The leave event updates the keyboard's state and if the surface was notified of a press event for any of the keycodes, it is refocused so that it can pick up the current keyboard state without triggering any keybinds.
2020-06-14i3-compat: add GET_BINDING_STATE IPC commandJason Nader-0/+3
2020-06-08tree/view: fix smart gaps when ancestor container is tabbed or stackedTudor Brindus-4/+5
Fixes #5406.
2020-06-09swaynag: allow specifying more buttons which execute and dismissGraham Christensen-0/+1
I don't love -z / -Z, but I figure this patch is far from being accepted for other reasons too.
2020-06-07tree/container: introduce `container_toplevel_ancestor` helperTudor Brindus-0/+7
This allows us to not have to explicitly write the same while loop everywhere.
2020-06-06common/util: fix `get_current_time_msec` returning microsecondsTudor Brindus-1/+7
This commit makes `get_current_time_msec` correctly return milliseconds as opposed to microseconds. It also considers the value of `tv_sec`, so we don't lose occasionally go back in time by one second. Finally, the function is moved into `util.c` so that it can be reused elsewhere without having to consider these pitfalls.
2020-06-05Save transform during transactionKalyan Sriram-0/+1
Closes: https://github.com/swaywm/sway/issues/5412
2020-06-03container: Remove useless surface dimensionsKenny Levinsen-1/+0
The adjustments to resize logic left them unnecessary.
2020-06-03view: Save all buffers associated with viewKenny Levinsen-5/+8
During the execution of a resize transaction, the buffer associated with a view's surface is saved and reused until the client acknowledges the resulting configure event. However, only one the main buffer of the main surface was stored and rendered, meaning that subsurfaces disappear during resize. Iterate over all, store and render buffers from all surfaces in the view to ensure that correct rendering is preserved.