aboutsummaryrefslogtreecommitdiffstats
path: root/dwl.c
AgeCommit message (Collapse)AuthorLines
2023-11-25do not check if a layer surface has monitor on commitLeonardo Hernández Hernández-6/+0
We do not allow creating them w/o monitor and they are destroyed when destroying their monitor
2023-11-25send wl_surface.enter before initial commitLeonardo Hernández Hernández-0/+1
It's not necessary but it'll help clients to render a perfect first frame
2023-11-25destroy the layer-suface's scene tree for popupsLeonardo Hernández Hernández-0/+1
2023-11-25use wlr_box_equal() instead of memcmpLeonardo Hernández Hernández-1/+1
2023-11-25simplify settings popups scene tree parentLeonardo Hernández Hernández-3/+2
2023-11-25simplify check for wlr_layer_surface.outputLeonardo Hernández Hernández-4/+2
2023-11-25use sizeof(*pointer) instead of sizeof(struct)Leonardo Hernández Hernández-1/+1
2023-11-25make sure to unlink Monitor.request_state listenerLeonardo Hernández Hernández-1/+3
2023-11-25Merge branch 'wlroots-next'Leonardo Hernández Hernández-176/+249
2023-11-21try to apply gamma LUT in updatemonsLeonardo Hernández Hernández-1/+1
this in the case the output was re-enabled
2023-11-21ignore wl_surface.commit for xwayland clientsLeonardo Hernández Hernández-2/+0
This is no longer needed
2023-11-21Do not send repeated xdg_toplevel.configure_boundsLeonardo Hernández Hernández-0/+1
Fixes: 32e66f45827cc8016ca2cef65ba61840f43fcc85
2023-11-21resize clients on commitLeonardo Hernández Hernández-0/+3
Fixes: https://github.com/djpohly/dwl/issues/515 This reverts commit 4567979b16b0509bb80b6102ecb9b601b3cf6fa1.
2023-11-19createkeyboard: do not segfault if xkb_keymap_new_from_names returns NULLlink2xt-0/+2
Passing NULL to wlr_keyboard_set_keymap results in a segfault. Example: Thread 1 "dwl" received signal SIGSEGV, Segmentation fault. 0x00007ffff7e49b64 in xkb_keymap_ref () from /usr/lib/libxkbcommon.so.0 (gdb) bt #0 0x00007ffff7e49b64 in xkb_keymap_ref () at /usr/lib/libxkbcommon.so.0 #1 0x00007ffff7f06389 in wlr_keyboard_set_keymap () at /usr/lib/libwlroots.so.11 #2 0x000055555555bc54 in createkeyboard () #3 0x000055555555c283 in inputdevice () #4 0x00007ffff7e8101e in wl_signal_emit_mutable () at /usr/lib/libwayland-server.so.0 #5 0x00007ffff7e8101e in wl_signal_emit_mutable () at /usr/lib/libwayland-server.so.0 #6 0x00007ffff7edb52c in () at /usr/lib/libwlroots.so.11 #7 0x00007ffff7ee44b6 in () at /usr/lib/libwlroots.so.11 #8 0x000055555555fe66 in main ()
2023-11-18do not try to enable adaptive syncLeonardo Hernández Hernández-5/+0
2023-11-17fix the position of the cursor image after turning all the monitors onLeonardo Hernández Hernández-0/+7
2023-11-17remove unused #includeLeonardo Hernández Hernández-1/+0
2023-11-17do not check if `session` is non-NULLLeonardo Hernández Hernández-2/+1
wlr_session_change_vt() is a no-op if session == NULL
2023-11-17do not explicitly destroy some wlroots interfacesLeonardo Hernández Hernández-6/+3
they are destroyed when the wayland display is destroyed
2023-11-17fix docsLeonardo Hernández Hernández-19/+19
copied from tinywl
2023-11-17fix destroynotify() docsLeonardo Hernández Hernández-1/+1
References: https://gitlab.freedesktop.org/wlroots/wlroots/-/merge_requests/4421
2023-11-17prevent a use-after-free at exitLeonardo Hernández Hernández-0/+1
2023-11-17do not compute layout box twiceLeonardo Hernández Hernández-2/+2
2023-11-17make sure fullscreen clients have the right sizeLeonardo Hernández Hernández-0/+3
2023-11-17fix screen artifacts when setting gammaLeonardo Hernández Hernández-15/+32
the artifacts were caused because we tried to set the gamma right after receiving the event, this resulted in two pending page-flips, which not always play well together. This also seems to fix a screen freeze when turning on a monitor that has gamma. Additionally the current method won't work once [0] is merged [0]: https://gitlab.freedesktop.org/wlroots/wlroots/-/merge_requests/4423
2023-11-14use wlr_scene_subsurface_tree_set_clipLeonardo Hernández Hernández-0/+3
References: https://gitlab.freedesktop.org/wlroots/wlroots/-/merge_requests/4131 Closes: https://github.com/djpohly/dwl/issues/411
2023-11-14Revert "respect size hints"Leonardo Hernández Hernández-13/+3
This reverts commit 72e0a560d9836c5e8658003f548203bcd722e565.
2023-11-01use newer cursor naming specLeonardo Hernández Hernández-5/+5
References: https://www.freedesktop.org/wiki/Specifications/cursor-spec/ References: https://gitlab.freedesktop.org/wlroots/wlroots/-/merge_requests/4416
2023-11-01ignore maximize events for clients using xdg-shell v5 and newerLeonardo Hernández Hernández-1/+6
2023-10-13Merge remote-tracking branch 'upstream/main' into wlroots-nextLeonardo Hernández Hernández-1/+2
2023-10-10check client is mapped before setting border colorBen Collerson-1/+2
For some reason brave configured for as a wayland client triggers this code on startup and segfaults. Checking if the client is mapped fixes this, like with the previous fix for urgent border colour. References: 887fde65a3010905aa10f373cfcfe540cfc1781e Fixes: 72a7d78a1a7926a207539eb50f44b2e1eb089d49
2023-10-09Merge remote-tracking branch 'upstream/main' into wlroots-nextLeonardo Hernández Hernández-6/+10
2023-10-09use <xcb/xcb.h> instead of <X11/Xlib.h>Leonardo Hernández Hernández-5/+5
2023-10-09only set border color for urgent *and* mapped X11 clientsLeonardo Hernández Hernández-1/+4
this fixes a segfault when the client emits .set_hints but it's not mapped Fixes: 72a7d78a1a7926a207539eb50f44b2e1eb089d49
2023-10-09Merge remote-tracking branch 'upstream/main' into wlroots-nextLeonardo Hernández Hernández-10/+15
2023-10-09Revert "just add define"Leonardo Hernández Hernández-1/+1
I'm going to make some changes in the config file anyway This reverts commit e5367753bb90add013ee5d170a110064298ac2c4.
2023-10-09add [-d] flag to enable debug loggingLeonardo Hernández Hernández-2/+6
2023-10-09simplify setting the border color of clientsLeonardo Hernández Hernández-13/+5
2023-10-09make the borders red borders for urgent clientsLeonardo Hernández Hernández-0/+8
iirc this is the same behavior of dwm
2023-09-29Check if c is fullscreen before reparenting it to LyrFloatingForrest Bushstone-3/+4
Closes: https://github.com/djpohly/dwl/issues/487
2023-09-29make sure that fullscreen clients are on the correct screen when isfloating ↵Forrest Bushstone-1/+1
is true Bug: https://github.com/djpohly/dwl/issues/487
2023-09-24Merge remote-tracking branch 'upstream/main' into wlroots-nextLeonardo Hernández Hernández-59/+59
2023-09-06call setfloating in setmonLeonardo Hernández Hernández-0/+1
since in the previous commit we may not applying floating in clients this is to make sure we do
2023-09-06return early if the client doesn't have monitor in setfloatingLeonardo Hernández Hernández-0/+2
there is still a bug, but for now this prevents a segfault Bug: https://github.com/djpohly/dwl/issues/472
2023-08-22just add defineBen Collerson-1/+1
2023-08-22tagcount should have been a #defineBen Collerson-1/+1
2023-08-22return nothing in xytonode()Leonardo Hernández Hernández-3/+2
we do not use the node
2023-08-22Style: use early-return to clarify codeDevin J. Pohly-44/+52
Use an early return to avoid indenting the main logic instead of wrapping the tail of a function in an if statement. No functional change, except for a handful of places where printstatus() was being called spuriously (tag, toggletag, toggleview). ΔSLOC: 0
2023-08-22No need to send surface.leave/enter eventsDevin J. Pohly-6/+2
The scene graph implementation sends these for us, and it does so more accurately than our overly-simplified approach. Layer shell surfaces don't appear to receive these events at all, according to my WAYLAND_DEBUG experiments with bemenu and dtao. ΔSLOC: -4
2023-08-18don't resize clients on commitLeonardo Hernández Hernández-6/+0
It creates an infinite commit-resize loop when scale != 1