summary refs log tree commit diff
Commit message (Collapse)AuthorAgeFilesLines
* Allow bare numbers for key and mouse bindings; taken from similarokan2021-12-241-5/+16
| | | | support in other parse.y's; from Leon Fischer <lfischer@airmail.cc>.
* sync parse.y changes from base; ok naddy@okan2021-11-221-14/+14
| | | | | | | | | | | | | | | original from naddy@: > Don't declare variables as "unsigned char *" that are passed to > functions that take "char *" arguments. Where such chars are > assigned to int or passed to ctype functions, explicitly cast them > to unsigned char. > > For OpenBSD's clang, -Wpointer-sign has been disabled by default, > but when the parse.y code was built elsewhere, the compiler would > complain. > > With help from millert@ > ok benno@ deraadt@
* Do not attempt to grab keys without a keycode; this incidentally allowsokan2021-11-191-0/+2
| | | | | | XF86 keys support. found and fix by Luis Henriques <henrix@camandro.org>
* Keep pointer within window on maximize/fullscreen togglekn2021-04-221-0/+4
| | | | | | | | | | | | | | | | | | Spawn a window, maximize it in any way, move the cursor to a window border that is not on the screen's edge and unmaximize again: While the window goes back the cursor stays at the screen's edge, i.e. focus is lost to the underlaying window. Moving, resizing, tiling or snapping windows in any way always moves the cursor along iff needed, e.g. using MS-[hjkl] to move a small window from the center to the edge keeps the cursor within window borders -- no matter what you do with the keyboard, focus stays on that window. Make CM-f, CM-m, CM-equal and CMS-equal (default bindings) for toggling full-screen mode, maximization, vertical maximization and horizontal maximization of the current window drag the cursor along if needed as well. OK okan kmos dv
* Fixed memory leak in xu_get_strprop.tobias2020-04-251-1/+3
| | | | | | | If a client calls XSetTextProperty for a window to clear all its properties, then allocated memory within libX11 is not freed. OK okan@
* Prevent out of boundary write with configuration files in which too manytobias2020-04-161-1/+1
| | | | | | | | | | quoted arguments are stored for other window managers. The quotation handling happens within the while loop without checking if the "end" limit has been already reached. If this happens, the final NULL assignment leads to an out of boundary write on stack. OK okan@
* Allow configuring a percentage window size of the master window duringokan2020-04-165-5/+45
| | | | htile/vtile actions. From Uwe Werler, with a few manpage tweaks.
* zap stray tabsokan2020-03-241-1/+1
|
* Instead of using _NET_ACTIVE_WINDOW on restart, use the pointer locationokan2020-03-245-40/+20
| | | | | to determine what client to set active. Reduces a round trip for every window.
* Add support for SIGINT/SIGTERM.okan2020-03-231-4/+9
|
* Simplify conditional construct.tim2020-03-201-5/+2
| | | | OK okan@
* Trim event_mask to those that the root window actually needs.okan2020-03-201-10/+7
|
* No need to lookup current client early; move to right before it isokan2020-03-201-3/+1
| | | | needed.
* Recommit 1.259, but now with TAILQ_FOREACH_SAFE.tim2020-03-161-9/+11
| | | | | | | | | | | From and OK okan@ Original commit message: Plug two memory leaks. Also get rid of a variable that is no longer necessary. OK okan@
* Revert previous. Causes a crash as reported by Tom Murphy.tim2020-03-141-9/+7
|
* Simplify list markup.tim2020-03-131-25/+2
| | | | OK okan@ schwarze@
* Plug two memory leaks. Also get rid of a variable that is no longertim2020-03-131-7/+9
| | | | | | necessary. OK okan@
* Remove ColormaskChange from event-mask since there's no event handler.okan2020-02-281-2/+2
|
* Unrelated style fixes, consistency changes and sorting, appropriateokan2020-02-2713-439/+458
| | | | | dosage/removal of wrappers, simplification of name queue, client cycle joins other kb/mb bound functions.
* Allow the 'empty' group clients to be window-{h,v}tile'd.okan2020-02-071-6/+0
| | | | Behaviour (or lack there of) noticed by Raf Czlonka.
* Map ('5') and allow mod5mask (altgr) as a modifier.okan2020-02-033-14/+9
| | | | From Artturi Alm (though changed from 'm' to '5')
* add, then use, xvasprintf, checking for appropriate return.okan2020-01-223-7/+15
|
* Ensure the pointer stays within client bounds after a window 'snap' (to edge).okan2020-01-211-0/+1
| | | | reported by Stefan Hagen.
* Because cwm warps the pointer during a client move (to stay within the client),okan2019-08-131-0/+2
| | | | | | | | | there's a window of time where an expose or enternotify event will get generated for a lower client; use a hammer and drain events after keyboard move/resize, until such a time that cwm doesn't warp the pointer. Behavior noticed by kn. ok kn@
* Fix regression from r1.107 (lost a return); kettenis@ pointed out the highokan2019-08-121-0/+1
| | | | | potential for a use-after-free (true!) where kn@ ran into the regression using an app that actually exercised the XGrabPointer() failure path.
* Add application sectionkn2019-07-091-2/+6
| | | | | | | | | | Link what is described as "applications" here to how they are actually defined in cwmrc(5). While here, call the configuration file what it is instead of reusing the default path (already mentioned in the FILES section). OK okan
* command uses execvp(3) not execve(2)kn2019-07-021-1/+1
| | | | util.c:u_exec() has been doing so since import.
* Plug a memory leak in log_debug(); OK okan@tim2019-04-291-0/+1
|
* Handle _NET_WM_NAME changes.tim2019-04-291-1/+2
| | | | | | | This fixes the problem where cwm's window menu wouldn't show Firefox's current window title if it contains non-ASCII characters. OK okan@
* Check the atom type on propertynotify before iterating.okan2019-03-111-3/+5
|
* use screen_find() for xrandr crtc changesokan2019-03-101-11/+8
|
* Find the managed screen from the parent window for client_current().okan2019-03-101-4/+8
|
* Print window id in hex; while here, remove unnecessary newline.okan2019-03-081-1/+1
|
* Similar to keypress event, fetch the screen from the event root window in theokan2019-03-081-6/+4
| | | | | buttonpress handler; bail if we don't manage the screen. Allows us to find the current client based on the screen/event root.
* extend verbose logging for key/button eventsokan2019-03-081-4/+7
|
* [keypress event] turns out we've been checking the wrong window for a matchingokan2019-03-081-6/+7
| | | | | | | | client thus always falling back to client_current(); while the current client is problaby right in most cases, use event's subwindow (not window) to find the client. Bail early if this event came to us from a screen we don't manage. This is result of us grabing all keybindings off the root window instead of selectively.
* add parans for readibilityokan2019-03-081-4/+4
|
* Teach client_current() to use a screen to find the current client instead ofokan2019-03-074-12/+19
| | | | | iterating over all (fallback if no screen provided for now). Initially convert trivial uses of client_current().
* check cc->gc directlyokan2019-03-071-4/+2
|
* zip extra linesokan2019-03-071-5/+1
|
* gc clientq inside groups, instead use the better maintained one per-screenokan2019-03-073-28/+40
|
* shuffle deck chairs: rename group actions to match intent for clarityokan2019-03-074-30/+30
|
* same thing as screen_find()okan2019-03-061-7/+3
|
* Separate out the menu window from the client resize/move geom window; in eachokan2019-03-046-80/+93
| | | | case, create and destroy on-demand. Isolate more menu specific code.
* fix a few misplaced (and misnamed) ewmh root window functionsokan2019-03-043-15/+15
|
* _NET_WORKAREA needs ngroups, so screen_update_geometry() needs to come afterokan2019-03-041-1/+1
| | | | conf_group().
* simplify xftcolor configokan2019-03-041-5/+2
|
* Tie group number and name together during config.okan2019-03-014-13/+32
|
* Move the group index (desktop number) check to the only 2 callers that requireokan2019-02-282-14/+6
| | | | checking due to ewmh.
* Ensure we don't action on the last group when the requested one is not found.okan2019-02-281-19/+17
|