aboutsummaryrefslogtreecommitdiff
path: root/dwl.c
Commit message (Collapse)AuthorAgeFilesLines
* misc fixes to xdg-toplevel-decorationLeonardo Hernández Hernández2024-02-061-2/+6
|
* send initial configure to xdg-toplevels (wlroots!4396)Leonardo Hernández Hernández2024-02-061-1/+4
| | | | | | We still need to fix xdg-popups References: https://gitlab.freedesktop.org/wlroots/wlroots/-/merge_requests/4396
* Merge remote-tracking branch 'upstream/main' into wlroots-nextLeonardo Hernández Hernández2024-02-071-17/+42
|\
| * allow toggling the layout before selecting a different oneGuido Cella2024-02-071-1/+2
| |
| * fix minimum sizeLeonardo Hernández Hernández2024-02-071-2/+2
| | | | | | | | continuation of 4043fc3093a73174cb63653ba9e742b4738f2ee5
| * place child clients above fullscreen clientsGuido Cella2024-02-051-5/+8
| | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | When a child window of a fullscreen client is mapped, the fullscreen is disabled, and if the previously fullscreen client is floating the child window is rendered below it and cannot be seen, causing confusion, though it is still focused and interactable. Fix this by putting children of fullscreen clients in LyrFS instead of LyrFloat, and by returning before the unset_fullscreen code is called when they are mapped. focusstack() now lets you switch focus from a fullscreen client to its child windows, otherwise if you switch focus from the child window to the fullscreen client you could not focus the child window again and the fullscreen client would stay unresponsive. Child clients are not reparented to LyrFloat after leaving fullscreen, so you could spawn a child window, focus back the fullscreen client, unfullscreen it, and the child window would still be drawn above other floating clients. Avoid dealing with this edge case to keep the line count low. These cases can be tested by pressing Ctrl+o in applications with an open file dialog.
| * make XWayland clients inherit tags and monitorsGuido Cella2024-02-051-2/+1
| | | | | | | | | | | | | | Revert 3213088 because the linked bug can no longer be reproduced with wlroots 0.17, and update client_get_parent() so it doesn't segfault with XWayland surfaces. This also allows reusing the p variable in the next commit.
| * remove useless wlr_scene_node_reparent() callsGuido Cella2024-02-051-2/+0
| | | | | | | | | | | | | | These don't do anything because wlr_scene_node_reparent() is immediately called again by setfloating() through setmon(). They are also a source of confusion because if you change the wlr_scene_node_reparent() call in applyrules() it takes a while to understand why it doesn't work.
| * Revert "No need to call updatemons ourselves"Leonardo Hernández Hernández2024-01-301-0/+3
| | | | | | | | | | | | Fixes: https://codeberg.org/dwl/dwl/issues/577 This reverts commit 26d7c9689f6e7eb699f2a63c2093c2a27e411ea3.
| * Correct specifier-data_type mismatchesA Frederick Christensen2024-01-261-4/+4
| |
| * configure xwayland surfaces without monitorsGuido Cella2024-01-251-1/+5
| | | | | | | | | | | | | | | | | | For wine clients often configurex11() is called before mapnotify() and therefore c->mon is NULL. configurex11 just returns early in that case, letting these clients stay in the wrong size. For example only the top left part of winecfg and wine uninstaller is drawn, or confirmation dialogs like when closing wine notepad are too big. Fix this by configuring their surfaces like before 88d386b.
| * implement the virtual pointer protocolGuido Cella2024-01-251-0/+17
| | | | | | | | This is used by programs like warpd.
| * do not arrange monitor if it's disabled (wlroots!4520)Leonardo Hernández Hernández2024-01-241-0/+4
| | | | | | | | | | | | | | This causes us to send negative values to xdg-configures (e.g a bug in our end) References: https://gitlab.freedesktop.org/wlroots/wlroots/-/merge_requests/4520 (cherry picked from commit 4043fc3093a73174cb63653ba9e742b4738f2ee5)
* | pass wl_event_loop to wlr_backend_autocreate (wlroots!4443)Leonardo Hernández Hernández2024-01-251-5/+9
| | | | | | | | References: https://gitlab.freedesktop.org/wlroots/wlroots/-/merge_requests/4443
* | do not arrange monitor if it's disabled (wlroots!4520)Leonardo Hernández Hernández2024-01-241-0/+4
| | | | | | | | | | | | This causes us to send negative values to xdg-configures (e.g a bug in our end) References: https://gitlab.freedesktop.org/wlroots/wlroots/-/merge_requests/4520
* | add support for axis_relative_direction event (wlroots!4003)Leonardo Hernández Hernández2024-01-241-1/+1
| | | | | | | | References: https://gitlab.freedesktop.org/wlroots/wlroots/-/merge_requests/4003
* | Revert "drop wl_drm (wlroots!4397)"Leonardo Hernández Hernández2024-01-241-1/+4
| | | | | | | | | | | | There still a lot software that uses this protocol This reverts commit facbe57fcbe74d27809eefdfe6aaac5150fbb954.
* | Merge remote-tracking branch 'upstream/main' into wlroots-nextLeonardo Hernández Hernández2024-01-241-21/+23
|\|
| * No need to call updatemons ourselvesDevin J. Pohly2024-01-201-3/+0
| | | | | | | | | | | | | | The output manager in wlroots emits an output_layout.change event when anything changes, so updatemons will be called anyway. ΔSLOC: -1
| * drop unused variableLeonardo Hernández Hernández2024-01-151-1/+0
| |
| * turn on -Wfloat-conversionLeonardo Hernández Hernández2024-01-151-9/+10
| |
| * turn on -Wsign-compareLeonardo Hernández Hernández2024-01-151-7/+9
| |
| * check if monitor is null before setting gammachoc2024-01-111-0/+2
| | | | | | | | fixes segfault on monitor disconnect when using wlsunset
| * Destroy fullscreen node after moving clients off monBen Jargowsky2024-01-061-1/+1
| |
| * fix posible NULL-dereference in wl_surface.commit handlerLeonardo Hernández Hernández2024-01-011-1/+1
| |
* | drop wl_drm (wlroots!4397)Leonardo Hernández Hernández2024-01-101-4/+1
| | | | | | | | References: https://gitlab.freedesktop.org/wlroots/wlroots/-/merge_requests/4397
* | don't send configure events to uninitialized xdg-toplevelsLeonardo Hernández Hernández2024-01-051-2/+3
| |
* | don't send configure events to uninitialized xdg-popupsLeonardo Hernández Hernández2024-01-051-16/+29
| |
* | only create wlr_presentation (wlroots!4482)Leonardo Hernández Hernández2023-12-271-2/+1
| | | | | | | | References: https://gitlab.freedesktop.org/wlroots/wlroots/-/merge_requests/4482
* | Merge remote-tracking branch 'upstream/main' into wlroots-nextLeonardo Hernández Hernández2023-12-271-15/+20
|\|
| * unset DISPLAY before setting up xwaylandLeonardo Hernández Hernández2023-12-271-0/+4
| |
| * only execute the first keybindingLeonardo Hernández Hernández2023-12-271-3/+2
| |
| * more style fixesLeonardo Hernández Hernández2023-12-271-13/+14
| | | | | | | | missed from the previous iteration
* | Merge remote-tracking branch 'upstream/main' into wlroots-nextLeonardo Hernández Hernández2023-12-261-141/+190
|\|
| * create a wlr_keyboard_group for virtual keyboardsLeonardo Hernández Hernández2023-12-251-2/+24
| | | | | | | | Fixes: https://codeberg.org/dwl/dwl/issues/554
| * fix typoLeonardo Hernández Hernández2023-12-181-1/+1
| | | | | | | | | | Fixes: 7afdc191fe4e9b3d16604b7f0c96f9741247e2d2 Thanks to: David Donahue <david.donahue2996@gmail.com>
| * tie xdg_toplevel_decorations to ClientLeonardo Hernández Hernández2023-12-181-31/+28
| | | | | | | | | | a xdg_toplevel can only have one xdg_toplevel_decoration so there is no need to have a new struct for decorations
| * Revert "nuke CSDs, hopefully for good!"Leonardo Hernández Hernández2023-12-181-2/+28
| | | | | | | | | | | | | | The compositor must respond to the client requesting a change to the decoration mode, it does not matter if the compositor chooses a different mode. This reverts commit 9071ce6c848ce214939fb84f85ae77de86de88d7.
| * Revert "remove typedef `Decoration`"Leonardo Hernández Hernández2023-12-181-0/+5
| | | | | | | | This reverts commit d1ff1e6f75d9c53c953957b5c0a64e0bcb40008b.
| * style fixesLeonardo Hernández Hernández2023-12-171-75/+77
| |
| * use wlr_keyboard_group to manage all keyboardsDavid Donahue2023-12-171-74/+71
| |
| * check toplevel resourcesLeonardo Hernández Hernández2023-12-121-1/+1
| | | | | | | | it's just a aesthetic change
* | Merge remote-tracking branch 'upstream/main' into wlroots-nextLeonardo Hernández Hernández2023-12-111-13/+18
|\| | | | | | | | | Fixes: https://codeberg.org/dwl/dwl/issues/432 Fixes: https://codeberg.org/dwl/dwl/issues/547
| * restore and respect rootcolorDima Krasner2023-12-111-0/+5
| |
| * merge X11Managed and X11Unmanaged into X11Leonardo Hernández Hernández2023-12-101-4/+4
| | | | | | | | | | now that client_is_unmanaged() checks the wlr struct we don't need to keep track of it ourselves
| * do not blindly try to send motion events when pointer button is pressedLeonardo Hernández Hernández2023-12-101-9/+9
| | | | | | | | we don't have to do this if the surface is the same
* | Merge branch 'main' into wlroots-nextLeonardo Hernández Hernández2023-12-071-26/+26
|\|
| * sort LISTEN calls in createnotify{,x11}Leonardo Hernández Hernández2023-12-071-4/+4
| |
| * use the same style for urgent() and sethints()Leonardo Hernández Hernández2023-12-071-4/+4
| |
| * remove an unneeded cast in createpointer()Leonardo Hernández Hernández2023-12-071-2/+1
| |