Commit Graph

1777 Commits

Author SHA1 Message Date
38f1d2b44b merge: merged allowkillrule 2026-03-20 17:56:13 +10:30
9599d4233d feat: applied allow kill rule 2026-03-20 13:18:27 +10:30
0c36b86ec0 chore: added patch file 2026-03-20 13:15:47 +10:30
7b555451ae chore: remove trayer 2026-03-14 21:27:49 +10:30
049d59cb62 chore: better systray spacing, color still off 2026-03-14 21:25:05 +10:30
c53b9adb0b fix: resolved merge with statuscmd patch 2026-03-14 21:00:17 +10:30
bd32ae7251 chore: added feishin to rules 2026-03-14 17:19:03 +10:30
2b79eebe56 more window rules 2026-03-14 17:19:03 +10:30
2be742a10a minor changes to class names/ window rules 2026-03-14 17:19:03 +10:30
ff84964004 calcurse 2026-03-14 17:19:03 +10:30
8b5a2450b0 cleen 2026-03-14 17:19:03 +10:30
7870806dee bit better, double chords cause issues 2026-03-14 17:19:03 +10:30
15c551aeac minor change trial 2026-03-14 17:19:03 +10:30
7000a285ac updates, updates, updates 2026-03-14 17:19:03 +10:30
c4c5c2f629 updates again, need to specify number of chords 2026-03-14 17:19:03 +10:30
aa2e57b45c new things, thanks luke 2026-03-14 17:19:03 +10:30
2f534f3c72 aaah, now I understand 2026-03-14 17:19:03 +10:30
1d76082949 merged and updated config 2026-03-14 17:19:03 +10:30
d5974cfd68 forgot to add patch file 2026-03-14 17:19:03 +10:30
48176963e1 patched keychord, bye bye keychain :( 2026-03-14 17:19:03 +10:30
2e3b858e90 patched statuscmd 2026-03-14 17:19:03 +10:30
eaf51e9509 patched uselessgap 2026-03-14 17:14:35 +10:30
c6404b0bd5 added patch file 2026-03-14 17:14:35 +10:30
8917f73a90 shift-tools patched? 2026-03-14 17:14:35 +10:30
6eebc90a68 patch file 2026-03-14 17:14:35 +10:30
0a2c925e7f patched restartsig 2026-03-14 17:14:35 +10:30
a96e1620b6 added patch file 2026-03-14 16:29:06 +10:30
2d6f8885aa patched pertag 2026-03-14 16:29:06 +10:30
0f418b662f added patch file 2026-03-14 16:29:06 +10:30
bbfa3173a5 patched movestack 2026-03-14 16:29:06 +10:30
43499f4084 added patch file 2026-03-14 16:29:06 +10:30
bb1a1e099f patched fullscreen 2026-03-14 16:29:06 +10:30
cc5663b239 added patch file 2026-03-14 16:29:06 +10:30
1865b2e608 patched attachtop 2026-03-14 16:29:06 +10:30
b3cd617256 added patch file 2026-03-14 16:29:06 +10:30
92c3f398a6 don't forget to fix keychain to keychord changes 2026-03-14 16:29:06 +10:30
ce10409f36 added my default config file, might need tweaking 2026-03-14 16:29:06 +10:30
cb6069c7e9 patched systray 2026-03-14 16:15:27 +10:30
9024a63920 added patch file 2026-03-14 15:26:59 +10:30
Ruben Gonzalez
44dbc6809d buttonpress: fix status text click area mismatch
The status bar in drawbar() calculates the text width as TEXTW(stext)
- lrpad + 2. However, the click detection in buttonpress() used
TEXTW(stext) without adjusting for that padding.

This created an "extra" clickable area of some pixels to the left of
the status text that would incorrectly trigger ClkStatusText actions
instead of ClkWinTitle.

Steps to reproduce:
1. Set a status text: xsetroot -name "HELLO"
2. Move the mouse to the empty space with some pixels close to the
left of the word "HELLO" but in the title area.
3. Middle-click (or any binding for ClkStatusText).
4. You can see that the status bar action is triggered (default a
terminal spawns), even though you clicked in the window title area.

This fix ensures that the clickable area matches the visual text.
2026-03-13 18:27:18 +01:00
Ruben Gonzalez
2bb919e634 sendmon: resize fullscreen windows to target monitor
When a fullscreen window is moved to another monitor (e.g. via
tagmon), its geometry does not always match the new monitor's
dimensions.

Steps to reproduce:
1. Start dwm with two monitors (A and B).
2. Open a window on Monitor A.
3. Make the window fullscreen (e.g. Firefox with F11).
4. Move the window to Monitor B using the tagmon shortcut (Mod+Shift+>).
5. Go to the other monitor (B), observe that the window is still
visible on Monitor A and its contents, even though the window's title
is seen on Monitor B bar.
6. Go to the monitor A where the window is still in fullscreen, remove
the fullscreen and the window automatically will go to monitor B.

This fix ensures that fullscreen windows are correctly resized to the
new monitor's geometry during the move.
2026-03-10 19:52:48 +01:00
NRK
c3dd6a829b more overflow fix in getatomprop()
commit 244fa852 (and a9aa0d8) tried to fix overflow by checking
the number of items returned. however this is not sufficient
since the format may be lower than 32 bits.

to reproduce the crash, i used the reproducer given in commit
244fa85 but changed the XChangeProperty line to the following to
set the property to a 1 element 16 bit item:

	short si = 1;
	XChangeProperty(d, w, net_wm_state, XA_ATOM, 16,
		PropModeReplace, (unsigned char *)&si, 1);

this client reliably crashes dwm under ASAN since dwm is trying
to read a 32 bit value from a 16 bit one. fix it by checking for
format == 32 as well.

also change the access type from Atom to long, on my machine
Atom is typedef-ed to long already but that may not be true
everywere. the XGetWindowProperty manpage says format == 32 is
returned as `long` so use `long` directly.

(N.B: it also might be worth checking if the returned type is
 XA_ATOM as well, but i wasn't able to cause any crashes by
 setting different types so i'm leaving it out for now.)
2026-02-20 15:31:29 +01:00
NRK
5c9f30300b getstate: fix access type and remove redundant cast
WM_STATE is defined to be format == 32 which xlib returns as
`long` and so accessing it as `unsigned char` is incorrect.

and also &p is already an `unsigned char **` and so the cast was
completely redundant.

given the redundant cast, i assume `p` was `long *` at some time
but was changed to `unsigned char *` later, but the pointer
access (and the cast) wasn't updated.

also add a `format == 32` check as safety measure before
accessing, just in case.
2026-02-20 15:31:28 +01:00
NRK
397d618f1c fix not updating _NET_ACTIVE_WINDOW
currently clients that set the input field of WM_HINTS to true
(c->neverfocus) will never be updated as _NET_ACTIVE_WINDOW even
when they are focused. according to the ICCCM [0] the input
field of WM_HINTS tells the WM to either use or not use
XSetInputFocus(), it shouldn't have any relation to
_NET_ACTIVE_WINDOW. EWMH spec [1] also does not mention any
relationship between the two.

this issue was noticed when launching games via steam/proton and
noticing that _NET_ACTIVE_WINDOW was always wrong/stale (i.e not
updated to the game window).

for reference I've looked at bspwm [2] and it also seems to set
_NET_ACTIVE_WINDOW regardless of whether the client has WM_HINTS
input true or not.

[0]: https://x.org/releases/X11R7.6/doc/xorg-docs/specs/ICCCM/icccm.html#input_focus
[1]: https://specifications.freedesktop.org/wm/1.5/ar01s03.html#id-1.4.10
[2]: c5cf7d3943/src/tree.c (L659-L662)
2026-02-13 10:16:08 +01:00
Hiltjo Posthuma
f63cde9354 bump version to 6.8 2026-01-30 11:18:38 +01:00
Chris Down
a9aa0d8ffb dwm: Fix getatomprop regression from heap overflow fix
Commit 244fa852fe ("dwm: Fix heap buffer overflow in getatomprop")
introduced a check for dl > 0 before dereferencing the property pointer.
However, I missed that the variable dl is passed to XGetWindowProperty
for both nitems_return and bytes_after_return parameters:

    XGetWindowProperty(..., &dl, &dl, &p)

The final value in dl is bytes_after_return, not nitems_return. For a
successfully read property, bytes_after is typically 0 (indicating all
data was retrieved), so the check `dl > 0` is always false and dwm never
reads any atom properties. So this is safe, but not very helpful :-)

dl is probably just a dummy variable anyway, so fix by using a separate
variable for nitems, and check nitems > 0 as originally intended.
2026-01-16 14:13:51 +01:00
Hiltjo Posthuma
85fe518c1a bump version to 6.7
Put the maintainer at the top and bump years (time flies).
2026-01-10 11:31:44 +01:00
Chris Down
244fa852fe dwm: Fix heap buffer overflow in getatomprop
When getatomprop() is called, it invokes XGetWindowProperty() to
retrieve an Atom. If the property exists but has zero elements (length
0), Xlib returns Success and sets p to a valid, non-NULL memory address
containing a single null byte.

However, dl (that is, the number of items) is 0. dwm blindly casts p to
Atom* and dereferences it. While Xlib guarantees that p is safe to read
as a string (that is, it is null-terminated), it does _not_ guarantee it
is safe to read as an Atom (an unsigned long).

The Atom type is a typedef for unsigned long. Reading an Atom (which
thus will either likely be 4 or 8 bytes) from a 1-byte allocated buffer
results in a heap buffer overflow. Since property content is user
controlled, this allows any client to trigger an out of bounds read
simply by setting a property with format 32 and length 0.

An example client which reliably crashes dwm under ASAN:

    #include <X11/Xlib.h>
    #include <X11/Xatom.h>
    #include <stdio.h>
    #include <stdlib.h>
    #include <unistd.h>

    int main(void) {
        Display *d;
        Window root, w;
        Atom net_wm_state;

        d = XOpenDisplay(NULL);
        if (!d) return 1;

        root = DefaultRootWindow(d);
        w = XCreateSimpleWindow(d, root, 10, 10, 200, 200, 1, 0, 0);
        net_wm_state = XInternAtom(d, "_NET_WM_STATE", False);
        if (net_wm_state == None) return 1;

        XChangeProperty(d, w, net_wm_state, XA_ATOM, 32,
                        PropModeReplace, NULL, 0);
        XMapWindow(d, w);
        XSync(d, False);
        sleep(1);

        XCloseDisplay(d);
        return 0;
    }

In order to avoid this, check that the number of items returned is
greater than zero before dereferencing the pointer.
2026-01-10 11:27:23 +01:00
Hiltjo Posthuma
7c3abae4e6 drw.c: drw_scm_free: call free inside
Because drw_scm_create() allocates it.
2025-09-29 18:48:27 +02:00
Hiltjo Posthuma
93f26863d1 cleanup schemes and colors 2025-09-27 12:10:17 +02:00