Compare commits
	
		
			85 Commits
		
	
	
		
	
	| Author | SHA1 | Date | |
|---|---|---|---|
| 
						 | 
					af632efafb | ||
| 
						 | 
					5130e64014 | ||
| 
						 | 
					48b71050ab | ||
| 
						 | 
					c959e1cb58 | ||
| 
						 | 
					10b140adff | ||
| 
						 | 
					fde880858a | ||
| 
						 | 
					e896c3107e | ||
| 
						 | 
					e7ece2aaba | ||
| 
						 | 
					7d5b1b38a2 | ||
| 
						 | 
					bfa185fac4 | ||
| 
						 | 
					36e11cc61c | ||
| 
						 | 
					3047114a1f | ||
| 
						 | 
					81f908b5c6 | ||
| 
						 | 
					795f7d0011 | ||
| 
						 | 
					99a906d9e3 | ||
| 
						 | 
					8fe17768f7 | ||
| 
						 | 
					bd69540724 | ||
| 
						 | 
					e4457dd31e | ||
| 
						 | 
					5e3c442a2f | ||
| 
						 | 
					b788a08745 | ||
| 
						 | 
					e9c7ebcddc | ||
| 
						 | 
					699c83b6ff | ||
| 
						 | 
					5015cfc93b | ||
| 
						 | 
					485c40d5f9 | ||
| 
						 | 
					41958715d4 | ||
| 
						 | 
					5ac75bb689 | ||
| 
						 | 
					a60b1c5d2f | ||
| 
						 | 
					0f49dbddfb | ||
| 
						 | 
					d194f2c726 | ||
| 
						 | 
					2769ef11ad | ||
| 
						 | 
					8faf64215e | ||
| 
						 | 
					c2fa943e86 | ||
| 
						 | 
					eaf997ee88 | ||
| 
						 | 
					d0b1d46ed4 | ||
| 
						 | 
					4134edfc38 | ||
| 
						 | 
					5315d6ae96 | ||
| 
						 | 
					0a4ab3b407 | ||
| 
						 | 
					cc1f6ffbc2 | ||
| 
						 | 
					8531dc3158 | ||
| 
						 | 
					ab1c6e3d00 | ||
| 
						 | 
					84d1b45060 | ||
| 
						 | 
					96163849d6 | ||
| 
						 | 
					cbf3a73d72 | ||
| 
						 | 
					61bb8b2241 | ||
| 
						 | 
					bb2e7222ba | ||
| 
						 | 
					f04cac6d6e | ||
| 
						 | 
					f09418bbb6 | ||
| 
						 | 
					ed3ab6b4fc | ||
| 
						 | 
					f087d20e6e | ||
| 
						 | 
					a8e9513783 | ||
| 
						 | 
					c82db690cc | ||
| 
						 | 
					cb3f58ad06 | ||
| 
						 | 
					b69c870a30 | ||
| 
						 | 
					e78b4a9207 | ||
| 
						 | 
					3cd4023fb3 | ||
| 
						 | 
					f40f86fa87 | ||
| 
						 | 
					c3a2e016bb | ||
| 
						 | 
					c8e9479186 | ||
| 
						 | 
					10dfa65860 | ||
| 
						 | 
					3bd8466e93 | ||
| 
						 | 
					76c8c16d79 | ||
| 
						 | 
					3cb34830eb | ||
| 
						 | 
					db2236001c | ||
| 
						 | 
					3756f7f6b8 | ||
| 
						 | 
					99f78fa553 | ||
| 
						 | 
					a9b6a312a7 | ||
| 
						 | 
					6aa8e37efe | ||
| 
						 | 
					ceac8c91ff | ||
| 
						 | 
					5b238c8dab | ||
| 
						 | 
					022d076054 | ||
| 
						 | 
					2952b68db8 | ||
| 
						 | 
					bb3bd6fec3 | ||
| 
						 | 
					e63bf22948 | ||
| 
						 | 
					5376947571 | ||
| 
						 | 
					975c898376 | ||
| 
						 | 
					a137a86a23 | ||
| 
						 | 
					839c7f6939 | ||
| 
						 | 
					7a59cd1457 | ||
| 
						 | 
					24849acada | ||
| 
						 | 
					ab9571bbc5 | ||
| 
						 | 
					56a31dc4a7 | ||
| 
						 | 
					7af4d439bd | ||
| 
						 | 
					cd2d7549b3 | ||
| 
						 | 
					3465bed290 | ||
| 
						 | 
					4ec3a673ff | 
							
								
								
									
										3
									
								
								.gitignore
									
									
									
									
										vendored
									
									
										Normal file
									
								
							
							
						
						
									
										3
									
								
								.gitignore
									
									
									
									
										vendored
									
									
										Normal file
									
								
							@@ -0,0 +1,3 @@
 | 
				
			|||||||
 | 
					.vscode/
 | 
				
			||||||
 | 
					*.o
 | 
				
			||||||
 | 
					dwm
 | 
				
			||||||
							
								
								
									
										44
									
								
								BUGS
									
									
									
									
									
								
							
							
						
						
									
										44
									
								
								BUGS
									
									
									
									
									
								
							@@ -1,44 +0,0 @@
 | 
				
			|||||||
---
 | 
					 | 
				
			||||||
 | 
					 | 
				
			||||||
18:17 < Biolunar> when i change my resolution in dwm (to a smaller one) and then back to the native, the top bar is not repainted. that's since 5.7.2, in 5.6 it worked fine
 | 
					 | 
				
			||||||
18:19 < Biolunar> is it just happening to me or a (known) bug?
 | 
					 | 
				
			||||||
18:24 < Biolunar> and in addition, mplayers fullscreen is limited to the small resolution after i changed it back to the native
 | 
					 | 
				
			||||||
 | 
					 | 
				
			||||||
reproducible with xrandr -s but not with --output and --mode, strange
 | 
					 | 
				
			||||||
 | 
					 | 
				
			||||||
---
 | 
					 | 
				
			||||||
 | 
					 | 
				
			||||||
yet another corner case:
 | 
					 | 
				
			||||||
open a terminal, focus another monitor, but without moving the mouse
 | 
					 | 
				
			||||||
pointer there
 | 
					 | 
				
			||||||
if there is no client on the other monitor to get the focus, then the
 | 
					 | 
				
			||||||
terminal will be unfocused but it will accept input
 | 
					 | 
				
			||||||
 | 
					 | 
				
			||||||
---
 | 
					 | 
				
			||||||
 | 
					 | 
				
			||||||
Donald Allen reported this:
 | 
					 | 
				
			||||||
 | 
					 | 
				
			||||||
starting emacs from dmenu in archlinux results in missing configure of emacs, but mod1-space or mod1-shift-space fix this problem. this problem is new and did not happen in 1.6 xorg servers
 | 
					 | 
				
			||||||
 | 
					 | 
				
			||||||
---
 | 
					 | 
				
			||||||
 | 
					 | 
				
			||||||
voltaic reports this:
 | 
					 | 
				
			||||||
 | 
					 | 
				
			||||||
When I use two monitors, one larger in resolution than the other, the
 | 
					 | 
				
			||||||
bar is drawn using the smaller x-dimension on both screens. I think
 | 
					 | 
				
			||||||
what's happening is that there are two bars drawn, but the short bar
 | 
					 | 
				
			||||||
is always on top of the long bar such that I can't see the information
 | 
					 | 
				
			||||||
under the short bar. If I switch to the small screen, hide the short
 | 
					 | 
				
			||||||
bar, and then switch to the large screen, the long bar is drawn
 | 
					 | 
				
			||||||
correctly.
 | 
					 | 
				
			||||||
 | 
					 | 
				
			||||||
A similar problem occurs when I have started dwm on a small resolution
 | 
					 | 
				
			||||||
monitor (laptop screen) and then I switch to a large external display.
 | 
					 | 
				
			||||||
When I do this, the bar itself is drawn for the original smaller
 | 
					 | 
				
			||||||
resolution, but the information to be printed on the bar is
 | 
					 | 
				
			||||||
right-aligned for a longer bar. So what I see is a bar that has the
 | 
					 | 
				
			||||||
right hand side of it cut-off. See attached screenshot.
 | 
					 | 
				
			||||||
 | 
					 | 
				
			||||||
I am using standard options for xrandr such as --output VGA1 --auto, etc.
 | 
					 | 
				
			||||||
 | 
					 | 
				
			||||||
---
 | 
					 | 
				
			||||||
							
								
								
									
										19
									
								
								LICENSE
									
									
									
									
									
								
							
							
						
						
									
										19
									
								
								LICENSE
									
									
									
									
									
								
							@@ -1,18 +1,23 @@
 | 
				
			|||||||
MIT/X Consortium License
 | 
					MIT/X Consortium License
 | 
				
			||||||
 | 
					
 | 
				
			||||||
© 2006-2014 Anselm R Garbe <anselm@garbe.us>
 | 
					© 2006-2019 Anselm R Garbe <anselm@garbe.ca>
 | 
				
			||||||
© 2010-2014 Hiltjo Posthuma <hiltjo@codemadness.org>
 | 
					 | 
				
			||||||
© 2007-2011 Peter Hartlich <sgkkr at hartlich dot com>
 | 
					 | 
				
			||||||
© 2010-2011 Connor Lane Smith <cls@lubutu.com>
 | 
					 | 
				
			||||||
© 2006-2009 Jukka Salmi <jukka at salmi dot ch>
 | 
					© 2006-2009 Jukka Salmi <jukka at salmi dot ch>
 | 
				
			||||||
© 2007-2009 Premysl Hruby <dfenze at gmail dot com>
 | 
					© 2006-2007 Sander van Dijk <a dot h dot vandijk at gmail dot com>
 | 
				
			||||||
 | 
					© 2007-2011 Peter Hartlich <sgkkr at hartlich dot com>
 | 
				
			||||||
© 2007-2009 Szabolcs Nagy <nszabolcs at gmail dot com>
 | 
					© 2007-2009 Szabolcs Nagy <nszabolcs at gmail dot com>
 | 
				
			||||||
© 2007-2009 Christof Musik <christof at sendfax dot de>
 | 
					© 2007-2009 Christof Musik <christof at sendfax dot de>
 | 
				
			||||||
© 2009 Mate Nagy <mnagy at port70 dot net>
 | 
					© 2007-2009 Premysl Hruby <dfenze at gmail dot com>
 | 
				
			||||||
© 2007-2008 Enno Gottox Boland <gottox at s01 dot de>
 | 
					© 2007-2008 Enno Gottox Boland <gottox at s01 dot de>
 | 
				
			||||||
© 2008 Martin Hurton <martin dot hurton at gmail dot com>
 | 
					© 2008 Martin Hurton <martin dot hurton at gmail dot com>
 | 
				
			||||||
© 2008 Neale Pickett <neale dot woozle dot org>
 | 
					© 2008 Neale Pickett <neale dot woozle dot org>
 | 
				
			||||||
© 2006-2007 Sander van Dijk <a dot h dot vandijk at gmail dot com>
 | 
					© 2009 Mate Nagy <mnagy at port70 dot net>
 | 
				
			||||||
 | 
					© 2010-2016 Hiltjo Posthuma <hiltjo@codemadness.org>
 | 
				
			||||||
 | 
					© 2010-2012 Connor Lane Smith <cls@lubutu.com>
 | 
				
			||||||
 | 
					© 2011 Christoph Lohmann <20h@r-36.net>
 | 
				
			||||||
 | 
					© 2015-2016 Quentin Rameau <quinq@fifth.space>
 | 
				
			||||||
 | 
					© 2015-2016 Eric Pruitt <eric.pruitt@gmail.com>
 | 
				
			||||||
 | 
					© 2016-2017 Markus Teich <markus.teich@stusta.mhn.de>
 | 
				
			||||||
 | 
					© 2020 Sravan Balaji <balajsra@umich.edu>
 | 
				
			||||||
 | 
					
 | 
				
			||||||
Permission is hereby granted, free of charge, to any person obtaining a
 | 
					Permission is hereby granted, free of charge, to any person obtaining a
 | 
				
			||||||
copy of this software and associated documentation files (the "Software"),
 | 
					copy of this software and associated documentation files (the "Software"),
 | 
				
			||||||
 
 | 
				
			|||||||
							
								
								
									
										43
									
								
								Makefile
									
									
									
									
									
								
							
							
						
						
									
										43
									
								
								Makefile
									
									
									
									
									
								
							@@ -15,46 +15,37 @@ options:
 | 
				
			|||||||
	@echo "CC       = ${CC}"
 | 
						@echo "CC       = ${CC}"
 | 
				
			||||||
 | 
					
 | 
				
			||||||
.c.o:
 | 
					.c.o:
 | 
				
			||||||
	@echo CC $<
 | 
						${CC} -c ${CFLAGS} $<
 | 
				
			||||||
	@${CC} -c ${CFLAGS} $<
 | 
					 | 
				
			||||||
 | 
					
 | 
				
			||||||
${OBJ}: config.h config.mk
 | 
					${OBJ}: config.h config.mk
 | 
				
			||||||
 | 
					
 | 
				
			||||||
config.h:
 | 
					config.h:
 | 
				
			||||||
	@echo creating $@ from config.def.h
 | 
						cp config.def.h $@
 | 
				
			||||||
	@cp config.def.h $@
 | 
					 | 
				
			||||||
 | 
					
 | 
				
			||||||
dwm: ${OBJ}
 | 
					dwm: ${OBJ}
 | 
				
			||||||
	@echo CC -o $@
 | 
						${CC} -o $@ ${OBJ} ${LDFLAGS}
 | 
				
			||||||
	@${CC} -o $@ ${OBJ} ${LDFLAGS}
 | 
					 | 
				
			||||||
 | 
					
 | 
				
			||||||
clean:
 | 
					clean:
 | 
				
			||||||
	@echo cleaning
 | 
						rm -f dwm ${OBJ} dwm-${VERSION}.tar.gz
 | 
				
			||||||
	@rm -f dwm ${OBJ} dwm-${VERSION}.tar.gz
 | 
					 | 
				
			||||||
 | 
					
 | 
				
			||||||
dist: clean
 | 
					dist: clean
 | 
				
			||||||
	@echo creating dist tarball
 | 
						mkdir -p dwm-${VERSION}
 | 
				
			||||||
	@mkdir -p dwm-${VERSION}
 | 
						cp -R LICENSE Makefile README config.def.h config.mk\
 | 
				
			||||||
	@cp -R LICENSE TODO BUGS Makefile README config.def.h config.mk \
 | 
					 | 
				
			||||||
		dwm.1 drw.h util.h ${SRC} dwm.png transient.c dwm-${VERSION}
 | 
							dwm.1 drw.h util.h ${SRC} dwm.png transient.c dwm-${VERSION}
 | 
				
			||||||
	@tar -cf dwm-${VERSION}.tar dwm-${VERSION}
 | 
						tar -cf dwm-${VERSION}.tar dwm-${VERSION}
 | 
				
			||||||
	@gzip dwm-${VERSION}.tar
 | 
						gzip dwm-${VERSION}.tar
 | 
				
			||||||
	@rm -rf dwm-${VERSION}
 | 
						rm -rf dwm-${VERSION}
 | 
				
			||||||
 | 
					
 | 
				
			||||||
install: all
 | 
					install: all
 | 
				
			||||||
	@echo installing executable file to ${DESTDIR}${PREFIX}/bin
 | 
						mkdir -p ${DESTDIR}${PREFIX}/bin
 | 
				
			||||||
	@mkdir -p ${DESTDIR}${PREFIX}/bin
 | 
						cp -f dwm ${DESTDIR}${PREFIX}/bin
 | 
				
			||||||
	@cp -f dwm ${DESTDIR}${PREFIX}/bin
 | 
						chmod 755 ${DESTDIR}${PREFIX}/bin/dwm
 | 
				
			||||||
	@chmod 755 ${DESTDIR}${PREFIX}/bin/dwm
 | 
						mkdir -p ${DESTDIR}${MANPREFIX}/man1
 | 
				
			||||||
	@echo installing manual page to ${DESTDIR}${MANPREFIX}/man1
 | 
						sed "s/VERSION/${VERSION}/g" < dwm.1 > ${DESTDIR}${MANPREFIX}/man1/dwm.1
 | 
				
			||||||
	@mkdir -p ${DESTDIR}${MANPREFIX}/man1
 | 
						chmod 644 ${DESTDIR}${MANPREFIX}/man1/dwm.1
 | 
				
			||||||
	@sed "s/VERSION/${VERSION}/g" < dwm.1 > ${DESTDIR}${MANPREFIX}/man1/dwm.1
 | 
					 | 
				
			||||||
	@chmod 644 ${DESTDIR}${MANPREFIX}/man1/dwm.1
 | 
					 | 
				
			||||||
 | 
					
 | 
				
			||||||
uninstall:
 | 
					uninstall:
 | 
				
			||||||
	@echo removing executable file from ${DESTDIR}${PREFIX}/bin
 | 
						rm -f ${DESTDIR}${PREFIX}/bin/dwm\
 | 
				
			||||||
	@rm -f ${DESTDIR}${PREFIX}/bin/dwm
 | 
							${DESTDIR}${MANPREFIX}/man1/dwm.1
 | 
				
			||||||
	@echo removing manual page from ${DESTDIR}${MANPREFIX}/man1
 | 
					 | 
				
			||||||
	@rm -f ${DESTDIR}${MANPREFIX}/man1/dwm.1
 | 
					 | 
				
			||||||
 | 
					
 | 
				
			||||||
.PHONY: all options clean dist install uninstall
 | 
					.PHONY: all options clean dist install uninstall
 | 
				
			||||||
 
 | 
				
			|||||||
							
								
								
									
										51
									
								
								README
									
									
									
									
									
								
							
							
						
						
									
										51
									
								
								README
									
									
									
									
									
								
							@@ -1,51 +0,0 @@
 | 
				
			|||||||
dwm - dynamic window manager
 | 
					 | 
				
			||||||
============================
 | 
					 | 
				
			||||||
dwm is an extremely fast, small, and dynamic window manager for X.
 | 
					 | 
				
			||||||
 | 
					 | 
				
			||||||
 | 
					 | 
				
			||||||
Requirements
 | 
					 | 
				
			||||||
------------
 | 
					 | 
				
			||||||
In order to build dwm you need the Xlib header files.
 | 
					 | 
				
			||||||
 | 
					 | 
				
			||||||
 | 
					 | 
				
			||||||
Installation
 | 
					 | 
				
			||||||
------------
 | 
					 | 
				
			||||||
Edit config.mk to match your local setup (dwm is installed into
 | 
					 | 
				
			||||||
the /usr/local namespace by default).
 | 
					 | 
				
			||||||
 | 
					 | 
				
			||||||
Afterwards enter the following command to build and install dwm (if
 | 
					 | 
				
			||||||
necessary as root):
 | 
					 | 
				
			||||||
 | 
					 | 
				
			||||||
    make clean install
 | 
					 | 
				
			||||||
 | 
					 | 
				
			||||||
If you are going to use the default bluegray color scheme it is highly
 | 
					 | 
				
			||||||
recommended to also install the bluegray files shipped in the dextra package.
 | 
					 | 
				
			||||||
 | 
					 | 
				
			||||||
 | 
					 | 
				
			||||||
Running dwm
 | 
					 | 
				
			||||||
-----------
 | 
					 | 
				
			||||||
Add the following line to your .xinitrc to start dwm using startx:
 | 
					 | 
				
			||||||
 | 
					 | 
				
			||||||
    exec dwm
 | 
					 | 
				
			||||||
 | 
					 | 
				
			||||||
In order to connect dwm to a specific display, make sure that
 | 
					 | 
				
			||||||
the DISPLAY environment variable is set correctly, e.g.:
 | 
					 | 
				
			||||||
 | 
					 | 
				
			||||||
    DISPLAY=foo.bar:1 exec dwm
 | 
					 | 
				
			||||||
 | 
					 | 
				
			||||||
(This will start dwm on display :1 of the host foo.bar.)
 | 
					 | 
				
			||||||
 | 
					 | 
				
			||||||
In order to display status info in the bar, you can do something
 | 
					 | 
				
			||||||
like this in your .xinitrc:
 | 
					 | 
				
			||||||
 | 
					 | 
				
			||||||
    while xsetroot -name "`date` `uptime | sed 's/.*,//'`"
 | 
					 | 
				
			||||||
    do
 | 
					 | 
				
			||||||
    	sleep 1
 | 
					 | 
				
			||||||
    done &
 | 
					 | 
				
			||||||
    exec dwm
 | 
					 | 
				
			||||||
 | 
					 | 
				
			||||||
 | 
					 | 
				
			||||||
Configuration
 | 
					 | 
				
			||||||
-------------
 | 
					 | 
				
			||||||
The configuration of dwm is done by creating a custom config.h
 | 
					 | 
				
			||||||
and (re)compiling the source code.
 | 
					 | 
				
			||||||
							
								
								
									
										79
									
								
								README.md
									
									
									
									
									
										Normal file
									
								
							
							
						
						
									
										79
									
								
								README.md
									
									
									
									
									
										Normal file
									
								
							@@ -0,0 +1,79 @@
 | 
				
			|||||||
 | 
					# Sravan's dwm - dynamic window manager
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					[dwm](https://dwm.suckless.org/) is an extremely fast, small, and dynamic window manager for X.
 | 
				
			||||||
 | 
					This is Sravan's fork of dwm with patches and custom modifications.
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					## dwm Information
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					### Requirements
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					In order to build dwm you need the Xlib header files.
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					### Installation
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					Edit config.mk to match your local setup (dwm is installed into
 | 
				
			||||||
 | 
					the /usr/local namespace by default).
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					Afterwards enter the following command to build and install dwm (if
 | 
				
			||||||
 | 
					necessary as root):
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					    make clean install
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					### Running dwm
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					Add the following line to your .xinitrc to start dwm using startx:
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					    exec dwm
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					In order to connect dwm to a specific display, make sure that
 | 
				
			||||||
 | 
					the DISPLAY environment variable is set correctly, e.g.:
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					    DISPLAY=foo.bar:1 exec dwm
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					(This will start dwm on display :1 of the host foo.bar.)
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					In order to display status info in the bar, you can do something
 | 
				
			||||||
 | 
					like this in your .xinitrc:
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					    while xsetroot -name "`date` `uptime | sed 's/.*,//'`"
 | 
				
			||||||
 | 
					    do
 | 
				
			||||||
 | 
					    	sleep 1
 | 
				
			||||||
 | 
					    done &
 | 
				
			||||||
 | 
					    exec dwm
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					### Configuration
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					The configuration of dwm is done by creating a custom config.h
 | 
				
			||||||
 | 
					and (re)compiling the source code.
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					## Personal Modifications
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					### Patches
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					* [autostart](https://dwm.suckless.org/patches/autostart/)
 | 
				
			||||||
 | 
					* [centeredmaster](https://dwm.suckless.org/patches/centeredmaster/)
 | 
				
			||||||
 | 
					* [combo](https://dwm.suckless.org/patches/combo/)
 | 
				
			||||||
 | 
					* [cyclelayouts](https://dwm.suckless.org/patches/cyclelayouts/)
 | 
				
			||||||
 | 
					* [gridmode](https://dwm.suckless.org/patches/gridmode/)
 | 
				
			||||||
 | 
					* [movestack](https://dwm.suckless.org/patches/movestack/)
 | 
				
			||||||
 | 
					* [restartsig](https://dwm.suckless.org/patches/restartsig/)
 | 
				
			||||||
 | 
					* [ru_gaps](https://dwm.suckless.org/patches/ru_gaps/)
 | 
				
			||||||
 | 
					* [systray](https://dwm.suckless.org/patches/systray/)
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					### Modifications
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					* Change mod key to super key (windows key)
 | 
				
			||||||
 | 
					* Change terminal from st to alacritty
 | 
				
			||||||
 | 
					* Change colors to follow [Dracula](https://draculatheme.com) theme
 | 
				
			||||||
 | 
					* Increase border to 3 pixels
 | 
				
			||||||
 | 
					* Set default gap size to 10 pixels
 | 
				
			||||||
 | 
					* Change tags to be [Font Awesome](https://fontawesome.com) icons
 | 
				
			||||||
 | 
					* Run programs and processes on autostart
 | 
				
			||||||
 | 
					* [Pulse Audio Volume Control](https://gist.github.com/palopezv/efd34059af6126ad970940bcc6a90f2e)
 | 
				
			||||||
 | 
					* Media Play/Pause, Prev, and Next Keybindings via [Playerctl](https://github.com/altdesktop/playerctl)
 | 
				
			||||||
 | 
					  * Arch Community Repo: [playerctl](https://www.archlinux.org/packages/community/x86_64/playerctl/)
 | 
				
			||||||
 | 
					* Use [light-locker](https://github.com/the-cavalry/light-locker) to lock screen with [LightDM](https://github.com/canonical/lightdm)
 | 
				
			||||||
 | 
					  * Arch Community Repo: [lightdm](https://www.archlinux.org/packages/extra/x86_64/lightdm/)
 | 
				
			||||||
 | 
					  * Arch Community Repo: [light-locker](https://www.archlinux.org/packages/community/x86_64/light-locker/)
 | 
				
			||||||
 | 
					* Brightness Increase and Decrease Keybindings via [acpilight](https://gitlab.com/wavexx/acpilight)
 | 
				
			||||||
 | 
					  * Arch Community Repo: [acpilight](https://www.archlinux.org/packages/community/any/acpilight/)
 | 
				
			||||||
							
								
								
									
										4
									
								
								TODO
									
									
									
									
									
								
							
							
						
						
									
										4
									
								
								TODO
									
									
									
									
									
								
							@@ -1,4 +0,0 @@
 | 
				
			|||||||
- add a flag to Key to execute the command on release (needed for commands
 | 
					 | 
				
			||||||
		affecting the keyboard grab, see scrot -s for example)
 | 
					 | 
				
			||||||
- add updategeom() hook for external tools like dzen
 | 
					 | 
				
			||||||
- consider onscreenkeyboard hooks for tablet deployment
 | 
					 | 
				
			||||||
							
								
								
									
										53
									
								
								autoquit.sh
									
									
									
									
									
										Executable file
									
								
							
							
						
						
									
										53
									
								
								autoquit.sh
									
									
									
									
									
										Executable file
									
								
							@@ -0,0 +1,53 @@
 | 
				
			|||||||
 | 
					#!/bin/bash
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					########################
 | 
				
			||||||
 | 
					# Startup Applications #
 | 
				
			||||||
 | 
					########################
 | 
				
			||||||
 | 
					# List of applications to kill on exit
 | 
				
			||||||
 | 
					declare -a applications_array=(\
 | 
				
			||||||
 | 
					    # System Tray Applications
 | 
				
			||||||
 | 
					    "volctl" \          # PulseAudio Volume Control
 | 
				
			||||||
 | 
					    "nyrna" \           # Nyrna Application Suspend
 | 
				
			||||||
 | 
					    "blueman-tray" \    # Blueman Bluetooth Manager
 | 
				
			||||||
 | 
					    "nm-applet" \       # Network Manager Applet
 | 
				
			||||||
 | 
					    "kdeconnect-indi" \ # KDE Connect
 | 
				
			||||||
 | 
					    "flameshot" \       # Flameshot Screenshot Tool
 | 
				
			||||||
 | 
					    "redshift-gtk" \    # Redshift Blue Light Filter
 | 
				
			||||||
 | 
					    # Background Processes
 | 
				
			||||||
 | 
					    "picom" \           # Picom Compositor
 | 
				
			||||||
 | 
					    "xfce4-notifyd" \   # Xfce Notification Daemon
 | 
				
			||||||
 | 
					    "greenclip" \       # Greenclip Clipboard Manager
 | 
				
			||||||
 | 
					    "redshift" \        # Redshift Blue Light Filter
 | 
				
			||||||
 | 
					    "polkit-gnome-au" \ # GNOME Polkit Authentication Agent
 | 
				
			||||||
 | 
					    "slstatus" \        # slstatus status bar
 | 
				
			||||||
 | 
					    "light-locker" \    # LightDM Locker
 | 
				
			||||||
 | 
					    # Hardware Driver Applications
 | 
				
			||||||
 | 
					    "solaar" \          # Logitech Mouse Driver
 | 
				
			||||||
 | 
					    "polychromatic-t" \ # Razer Keyboard Customization
 | 
				
			||||||
 | 
					    "optimus-manager" \ # Optimus Manager Qt
 | 
				
			||||||
 | 
					)
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					# Kill applications
 | 
				
			||||||
 | 
					for i in "${applications_array[@]}"
 | 
				
			||||||
 | 
					do
 | 
				
			||||||
 | 
					    pkill -9 $i &
 | 
				
			||||||
 | 
					done
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					#####################
 | 
				
			||||||
 | 
					# Cloud Drive Rsync #
 | 
				
			||||||
 | 
					#####################
 | 
				
			||||||
 | 
					# Local cloud storage directory
 | 
				
			||||||
 | 
					local_clone_dir="$HOME/Cloud"
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					# List of remotes as defined in rclone
 | 
				
			||||||
 | 
					declare -a remote_array=(\
 | 
				
			||||||
 | 
					    "OneDrive - Personal" \
 | 
				
			||||||
 | 
					    "Google Drive - Personal" \
 | 
				
			||||||
 | 
					)
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					# Unmount Remotes
 | 
				
			||||||
 | 
					for i in "${remote_array[@]}"
 | 
				
			||||||
 | 
					do
 | 
				
			||||||
 | 
					    local_path="$local_clone_dir"/"$i"
 | 
				
			||||||
 | 
					    fusermount -u "$local_path" &
 | 
				
			||||||
 | 
					done
 | 
				
			||||||
							
								
								
									
										62
									
								
								autostart.sh
									
									
									
									
									
										Executable file
									
								
							
							
						
						
									
										62
									
								
								autostart.sh
									
									
									
									
									
										Executable file
									
								
							@@ -0,0 +1,62 @@
 | 
				
			|||||||
 | 
					#!/bin/bash
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					########################
 | 
				
			||||||
 | 
					# Startup Applications #
 | 
				
			||||||
 | 
					########################
 | 
				
			||||||
 | 
					# List of applications to run on start
 | 
				
			||||||
 | 
					declare -a applications_array=(\
 | 
				
			||||||
 | 
					    # System Restore Processes
 | 
				
			||||||
 | 
					    "bash /home/sravan/.screenlayout/default-screen-layout.sh" \    # Restore default screen layout
 | 
				
			||||||
 | 
					    "nitrogen --restore" \                                          # Restore wallpaper
 | 
				
			||||||
 | 
					    # System Tray Applications
 | 
				
			||||||
 | 
					    "volctl" \                                                      # PulseAudio Volume Control
 | 
				
			||||||
 | 
					    "nyrna" \                                                       # Nyrna Application Suspend
 | 
				
			||||||
 | 
					    "blueman-tray" \                                                # Blueman Bluetooth Manager
 | 
				
			||||||
 | 
					    "nm-applet" \                                                   # Network Manager Applet
 | 
				
			||||||
 | 
					    "kdeconnect-indicator" \                                        # KDE Connect
 | 
				
			||||||
 | 
					    "flameshot" \                                                   # Flameshot Screenshot Tool
 | 
				
			||||||
 | 
					    # Background Processes
 | 
				
			||||||
 | 
					    "picom --config /home/sravan/.config/picom/picom.conf" \        # Picom Compositor
 | 
				
			||||||
 | 
					    "/usr/lib/xfce4/notifyd/xfce4-notifyd" \                        # Xfce Notification Daemon
 | 
				
			||||||
 | 
					    "greenclip daemon" \                                            # Greenclip Clipboard Manager
 | 
				
			||||||
 | 
					    "redshift -x" \                                                 # Reset redshift display gamma
 | 
				
			||||||
 | 
					    "redshift-gtk" \                                                # Redshift Blue Light Filter
 | 
				
			||||||
 | 
					    "/usr/lib/polkit-gnome/polkit-gnome-authentication-agent-1" \   # GNOME Polkit Authentication Agent
 | 
				
			||||||
 | 
					    "slstatus" \                                                    # slstatus status bar
 | 
				
			||||||
 | 
					    "light-locker --lock-on-suspend --lock-on-lid" \                # LightDM Locker
 | 
				
			||||||
 | 
					    # Hardware Driver Applications
 | 
				
			||||||
 | 
					    "solaar --window=hide" \                                        # Logitech Mouse Driver
 | 
				
			||||||
 | 
					    "polychromatic-tray-applet" \                                   # Razer Keyboard Customization
 | 
				
			||||||
 | 
					    "optimus-manager-qt" \                                          # Optimus Manager Qt
 | 
				
			||||||
 | 
					)
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					# Run applications (ignore if they don't exist)
 | 
				
			||||||
 | 
					for i in "${applications_array[@]}"
 | 
				
			||||||
 | 
					do
 | 
				
			||||||
 | 
					    if ! command -v $i > /dev/null
 | 
				
			||||||
 | 
					    then
 | 
				
			||||||
 | 
					        do_nothing() { :; }
 | 
				
			||||||
 | 
					    else
 | 
				
			||||||
 | 
					        $i &
 | 
				
			||||||
 | 
					    fi
 | 
				
			||||||
 | 
					done
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					#####################
 | 
				
			||||||
 | 
					# Cloud Drive Rsync #
 | 
				
			||||||
 | 
					#####################
 | 
				
			||||||
 | 
					# Local cloud storage directory
 | 
				
			||||||
 | 
					local_clone_dir="$HOME/Cloud"
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					# List of remotes as defined in rclone
 | 
				
			||||||
 | 
					declare -a remote_array=(\
 | 
				
			||||||
 | 
					    "OneDrive - Personal" \
 | 
				
			||||||
 | 
					    "Google Drive - Personal" \
 | 
				
			||||||
 | 
					)
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					# Mount Remotes
 | 
				
			||||||
 | 
					for i in "${remote_array[@]}"
 | 
				
			||||||
 | 
					do
 | 
				
			||||||
 | 
					    local_path="$local_clone_dir"/"$i"
 | 
				
			||||||
 | 
					    mkdir -p "$local_path"
 | 
				
			||||||
 | 
					    rclone mount "$i": "$local_path" &
 | 
				
			||||||
 | 
					done
 | 
				
			||||||
							
								
								
									
										26
									
								
								config.def.h
									
									
									
									
									
								
							
							
						
						
									
										26
									
								
								config.def.h
									
									
									
									
									
								
							@@ -1,20 +1,22 @@
 | 
				
			|||||||
/* See LICENSE file for copyright and license details. */
 | 
					/* See LICENSE file for copyright and license details. */
 | 
				
			||||||
 | 
					
 | 
				
			||||||
/* appearance */
 | 
					/* appearance */
 | 
				
			||||||
static const char *fonts[] = {
 | 
					 | 
				
			||||||
	"monospace:size=10"
 | 
					 | 
				
			||||||
};
 | 
					 | 
				
			||||||
static const char dmenufont[]       = "monospace:size=10";
 | 
					 | 
				
			||||||
static const char normbordercolor[] = "#444444";
 | 
					 | 
				
			||||||
static const char normbgcolor[]     = "#222222";
 | 
					 | 
				
			||||||
static const char normfgcolor[]     = "#bbbbbb";
 | 
					 | 
				
			||||||
static const char selbordercolor[]  = "#005577";
 | 
					 | 
				
			||||||
static const char selbgcolor[]      = "#005577";
 | 
					 | 
				
			||||||
static const char selfgcolor[]      = "#eeeeee";
 | 
					 | 
				
			||||||
static const unsigned int borderpx  = 1;        /* border pixel of windows */
 | 
					static const unsigned int borderpx  = 1;        /* border pixel of windows */
 | 
				
			||||||
static const unsigned int snap      = 32;       /* snap pixel */
 | 
					static const unsigned int snap      = 32;       /* snap pixel */
 | 
				
			||||||
static const int showbar            = 1;        /* 0 means no bar */
 | 
					static const int showbar            = 1;        /* 0 means no bar */
 | 
				
			||||||
static const int topbar             = 1;        /* 0 means bottom bar */
 | 
					static const int topbar             = 1;        /* 0 means bottom bar */
 | 
				
			||||||
 | 
					static const char *fonts[]          = { "monospace:size=10" };
 | 
				
			||||||
 | 
					static const char dmenufont[]       = "monospace:size=10";
 | 
				
			||||||
 | 
					static const char col_gray1[]       = "#222222";
 | 
				
			||||||
 | 
					static const char col_gray2[]       = "#444444";
 | 
				
			||||||
 | 
					static const char col_gray3[]       = "#bbbbbb";
 | 
				
			||||||
 | 
					static const char col_gray4[]       = "#eeeeee";
 | 
				
			||||||
 | 
					static const char col_cyan[]        = "#005577";
 | 
				
			||||||
 | 
					static const char *colors[][3]      = {
 | 
				
			||||||
 | 
						/*               fg         bg         border   */
 | 
				
			||||||
 | 
						[SchemeNorm] = { col_gray3, col_gray1, col_gray2 },
 | 
				
			||||||
 | 
						[SchemeSel]  = { col_gray4, col_cyan,  col_cyan  },
 | 
				
			||||||
 | 
					};
 | 
				
			||||||
 | 
					
 | 
				
			||||||
/* tagging */
 | 
					/* tagging */
 | 
				
			||||||
static const char *tags[] = { "1", "2", "3", "4", "5", "6", "7", "8", "9" };
 | 
					static const char *tags[] = { "1", "2", "3", "4", "5", "6", "7", "8", "9" };
 | 
				
			||||||
@@ -54,7 +56,7 @@ static const Layout layouts[] = {
 | 
				
			|||||||
 | 
					
 | 
				
			||||||
/* commands */
 | 
					/* commands */
 | 
				
			||||||
static char dmenumon[2] = "0"; /* component of dmenucmd, manipulated in spawn() */
 | 
					static char dmenumon[2] = "0"; /* component of dmenucmd, manipulated in spawn() */
 | 
				
			||||||
static const char *dmenucmd[] = { "dmenu_run", "-m", dmenumon, "-fn", dmenufont, "-nb", normbgcolor, "-nf", normfgcolor, "-sb", selbgcolor, "-sf", selfgcolor, NULL };
 | 
					static const char *dmenucmd[] = { "dmenu_run", "-m", dmenumon, "-fn", dmenufont, "-nb", col_gray1, "-nf", col_gray3, "-sb", col_cyan, "-sf", col_gray4, NULL };
 | 
				
			||||||
static const char *termcmd[]  = { "st", NULL };
 | 
					static const char *termcmd[]  = { "st", NULL };
 | 
				
			||||||
 | 
					
 | 
				
			||||||
static Key keys[] = {
 | 
					static Key keys[] = {
 | 
				
			||||||
@@ -95,7 +97,7 @@ static Key keys[] = {
 | 
				
			|||||||
};
 | 
					};
 | 
				
			||||||
 | 
					
 | 
				
			||||||
/* button definitions */
 | 
					/* button definitions */
 | 
				
			||||||
/* click can be ClkLtSymbol, ClkStatusText, ClkWinTitle, ClkClientWin, or ClkRootWin */
 | 
					/* click can be ClkTagBar, ClkLtSymbol, ClkStatusText, ClkWinTitle, ClkClientWin, or ClkRootWin */
 | 
				
			||||||
static Button buttons[] = {
 | 
					static Button buttons[] = {
 | 
				
			||||||
	/* click                event mask      button          function        argument */
 | 
						/* click                event mask      button          function        argument */
 | 
				
			||||||
	{ ClkLtSymbol,          0,              Button1,        setlayout,      {0} },
 | 
						{ ClkLtSymbol,          0,              Button1,        setlayout,      {0} },
 | 
				
			||||||
 
 | 
				
			|||||||
							
								
								
									
										164
									
								
								config.h
									
									
									
									
									
										Normal file
									
								
							
							
						
						
									
										164
									
								
								config.h
									
									
									
									
									
										Normal file
									
								
							@@ -0,0 +1,164 @@
 | 
				
			|||||||
 | 
					/* See LICENSE file for copyright and license details. */
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					/* includes */
 | 
				
			||||||
 | 
					#include <X11/XF86keysym.h>
 | 
				
			||||||
 | 
					#include "movestack.c"
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					/* appearance */
 | 
				
			||||||
 | 
					static const unsigned int borderpx  = 3;        /* border pixel of windows */
 | 
				
			||||||
 | 
					static const int gappx				= 15;		/* gaps between windows */
 | 
				
			||||||
 | 
					static const unsigned int snap      = 10;       /* snap pixel */
 | 
				
			||||||
 | 
					static const unsigned int systraypinning = 0;   /* 0: sloppy systray follows selected monitor, >0: pin systray to monitor X */
 | 
				
			||||||
 | 
					static const unsigned int systrayspacing = 2;   /* systray spacing */
 | 
				
			||||||
 | 
					static const int systraypinningfailfirst = 1;   /* 1: if pinning fails, display systray on the first monitor, False: display systray on the last monitor*/
 | 
				
			||||||
 | 
					static const int showsystray        = 1;     	/* 0 means no systray */
 | 
				
			||||||
 | 
					static const int showbar            = 1;        /* 0 means no bar */
 | 
				
			||||||
 | 
					static const int topbar             = 1;        /* 0 means bottom bar */
 | 
				
			||||||
 | 
					static const char *fonts[]          = { "NotoSans Nerd Font:size=10" };
 | 
				
			||||||
 | 
					static const char col_gray1[]       = "#282a36"; /* background color */
 | 
				
			||||||
 | 
					static const char col_gray2[]       = "#44475a"; /* inactive window border color */
 | 
				
			||||||
 | 
					static const char col_gray3[]       = "#f8f8f2"; /* font color */
 | 
				
			||||||
 | 
					static const char col_gray4[]       = "#282a36"; /* current tag and current window font color */
 | 
				
			||||||
 | 
					static const char col_cyan[]        = "#bd93f9"; /* Top bar second color and active window border color */
 | 
				
			||||||
 | 
					static const char *colors[][3]      = {
 | 
				
			||||||
 | 
						/*               fg         bg         border   */
 | 
				
			||||||
 | 
						[SchemeNorm] = { col_gray3, col_gray1, col_gray2 },
 | 
				
			||||||
 | 
						[SchemeSel]  = { col_gray4, col_cyan,  col_cyan  },
 | 
				
			||||||
 | 
					};
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					/* tagging */
 | 
				
			||||||
 | 
					static const char *tags[] = { " ₁", "龎 ₂", " ₃", " ₄", "爵 ₅", " ₆", " ₇", " ₈", " ₉" };
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					static const Rule rules[] = {
 | 
				
			||||||
 | 
						/* xprop(1):
 | 
				
			||||||
 | 
						 *	WM_CLASS(STRING) = instance, class
 | 
				
			||||||
 | 
						 *	WM_NAME(STRING) = title
 | 
				
			||||||
 | 
						 */
 | 
				
			||||||
 | 
						/* class      instance    title       tags mask     isfloating   monitor */
 | 
				
			||||||
 | 
						{ "origin",	  NULL,		  NULL,		  0,			1,			 -1 },
 | 
				
			||||||
 | 
					};
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					/* layout(s) */
 | 
				
			||||||
 | 
					static const float mfact     = 0.55; /* factor of master area size [0.05..0.95] */
 | 
				
			||||||
 | 
					static const int nmaster     = 1;    /* number of clients in master area */
 | 
				
			||||||
 | 
					static const int resizehints = 1;    /* 1 means respect size hints in tiled resizals */
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					#include "layouts.c"
 | 
				
			||||||
 | 
					static const Layout layouts[] = {
 | 
				
			||||||
 | 
						/* symbol     arrange function */
 | 
				
			||||||
 | 
						{ "[]=",      tile },    /* first entry is default */
 | 
				
			||||||
 | 
						{ "><>",      NULL },    /* no layout function means floating behavior */
 | 
				
			||||||
 | 
						{ "[M]",      monocle },
 | 
				
			||||||
 | 
						{ "|M|",      centeredmaster },
 | 
				
			||||||
 | 
						{ ">M>",      centeredfloatingmaster },
 | 
				
			||||||
 | 
						{ "HHH",      grid },
 | 
				
			||||||
 | 
						{ NULL,       NULL },
 | 
				
			||||||
 | 
					};
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					/* key definitions */
 | 
				
			||||||
 | 
					#define MODKEY Mod4Mask		/* Mod1Mask = Alt, Mod4Mask = Super */
 | 
				
			||||||
 | 
					#define TAGKEYS(KEY,TAG) \
 | 
				
			||||||
 | 
						{ MODKEY,                       KEY,      comboview,      {.ui = 1 << TAG} }, \
 | 
				
			||||||
 | 
						{ MODKEY|ControlMask,           KEY,      toggleview,     {.ui = 1 << TAG} }, \
 | 
				
			||||||
 | 
						{ MODKEY|ShiftMask,             KEY,      combotag,       {.ui = 1 << TAG} }, \
 | 
				
			||||||
 | 
						{ MODKEY|ControlMask|ShiftMask, KEY,      toggletag,      {.ui = 1 << TAG} },
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					/* helper for spawning shell commands in the pre dwm-5.0 fashion */
 | 
				
			||||||
 | 
					#define SHCMD(cmd) { .v = (const char*[]){ "/bin/sh", "-c", cmd, NULL } }
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					/* configuration parameters */
 | 
				
			||||||
 | 
					static const char rootdir[] = "/home/sravan/.config"; /* Location of dwm source code */
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					/* commands */
 | 
				
			||||||
 | 
					static const char *rofiruncmd[]			= { "rofi", "-show", "drun",	  NULL };
 | 
				
			||||||
 | 
					static const char *roficlipcmd[]		= { "rofi", "-show", "clipboard", NULL };
 | 
				
			||||||
 | 
					static const char *lockcmd[]			= { "light-locker-command", "--lock",  NULL };
 | 
				
			||||||
 | 
					static const char *sleepcmd[]			= { "systemctl",			"suspend", NULL };
 | 
				
			||||||
 | 
					static const char *termcmd[]			= { "alacritty", NULL };
 | 
				
			||||||
 | 
					static const char *upvolcmd[]			= { "/usr/bin/pactl", "set-sink-volume", "@DEFAULT_SINK@", "+1%",     NULL };
 | 
				
			||||||
 | 
					static const char *downvolcmd[]			= { "/usr/bin/pactl", "set-sink-volume", "@DEFAULT_SINK@", "-1%",     NULL };
 | 
				
			||||||
 | 
					static const char *mutevolcmd[]			= { "/usr/bin/pactl", "set-sink-mute",   "@DEFAULT_SINK@", "toggle",  NULL };
 | 
				
			||||||
 | 
					static const char *brightness_up[]		= { "xbacklight", "-inc", "1", NULL };
 | 
				
			||||||
 | 
					static const char *brightness_down[]	= { "xbacklight", "-dec", "1", NULL };
 | 
				
			||||||
 | 
					static const char *playerplaypausecmd[]	= { "playerctl", "--player=playerctld", "play-pause", NULL };
 | 
				
			||||||
 | 
					static const char *playernextcmd[]		= { "playerctl", "--player=playerctld", "next", 	  NULL };
 | 
				
			||||||
 | 
					static const char *playerprevcmd[]		= { "playerctl", "--player=playerctld", "previous",   NULL };
 | 
				
			||||||
 | 
					static const char *flameshotcmd[]		= { "flameshot", "gui",	NULL };
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					/* key definitions */
 | 
				
			||||||
 | 
					static Key keys[] = {
 | 
				
			||||||
 | 
						/* modifier						key							function		argument */
 | 
				
			||||||
 | 
						{ MODKEY,						XK_p,						spawn,          {.v = rofiruncmd} },
 | 
				
			||||||
 | 
						{ MODKEY,						XK_c,						spawn,          {.v = roficlipcmd} },
 | 
				
			||||||
 | 
						{ MODKEY|ShiftMask,				XK_l,						spawn,          {.v = lockcmd} },
 | 
				
			||||||
 | 
						{ MODKEY|ShiftMask,				XK_s,						spawn,          {.v = sleepcmd} },
 | 
				
			||||||
 | 
						{ MODKEY|ShiftMask,				XK_Return,					spawn,          {.v = termcmd} },
 | 
				
			||||||
 | 
						{ MODKEY,           			XK_b,      					togglebar,      {0} },
 | 
				
			||||||
 | 
						{ MODKEY,           			XK_j,      					focusstack,     {.i = +1} },
 | 
				
			||||||
 | 
						{ MODKEY,           			XK_k,      					focusstack,     {.i = -1} },
 | 
				
			||||||
 | 
						{ MODKEY,           			XK_i,      					incnmaster,     {.i = +1} },
 | 
				
			||||||
 | 
						{ MODKEY,           			XK_d,      					incnmaster,     {.i = -1} },
 | 
				
			||||||
 | 
						{ MODKEY,           			XK_h,						setmfact,       {.f = -0.05} },
 | 
				
			||||||
 | 
						{ MODKEY,           			XK_l,						setmfact,       {.f = +0.05} },
 | 
				
			||||||
 | 
						{ MODKEY|ShiftMask,				XK_j,						movestack,      {.i = +1} },
 | 
				
			||||||
 | 
						{ MODKEY|ShiftMask,				XK_k,						movestack,      {.i = -1} },
 | 
				
			||||||
 | 
						{ MODKEY,           			XK_Return,					zoom,           {0} },
 | 
				
			||||||
 | 
						{ MODKEY,           			XK_Tab,						view,           {0} },
 | 
				
			||||||
 | 
						{ MODKEY|ShiftMask, 			XK_c,						killclient,     {0} },
 | 
				
			||||||
 | 
						{ MODKEY,           			XK_t,						setlayout,      {.v = &layouts[0]} },
 | 
				
			||||||
 | 
						{ MODKEY,           			XK_f,						setlayout,      {.v = &layouts[1]} },
 | 
				
			||||||
 | 
						{ MODKEY,           			XK_m,						setlayout,      {.v = &layouts[2]} },
 | 
				
			||||||
 | 
						{ MODKEY,						XK_u,						setlayout,		{.v = &layouts[3]} },
 | 
				
			||||||
 | 
						{ MODKEY,						XK_o,						setlayout,		{.v = &layouts[4]} },
 | 
				
			||||||
 | 
						{ MODKEY,						XK_g,						setlayout,		{.v = &layouts[5]} },
 | 
				
			||||||
 | 
						{ MODKEY|ControlMask,			XK_comma,					cyclelayout,	{.i = -1 } },
 | 
				
			||||||
 | 
						{ MODKEY|ControlMask,			XK_period,					cyclelayout,	{.i = +1 } },
 | 
				
			||||||
 | 
						{ MODKEY,           			XK_space,					setlayout,      {0} },
 | 
				
			||||||
 | 
						{ MODKEY|ShiftMask, 			XK_space,					togglefloating, {0} },
 | 
				
			||||||
 | 
						{ MODKEY,           			XK_0,						view,           {.ui = ~0} },
 | 
				
			||||||
 | 
						{ MODKEY|ShiftMask, 			XK_0,						tag,            {.ui = ~0} },
 | 
				
			||||||
 | 
						{ MODKEY,           			XK_comma,					focusmon,       {.i = -1} },
 | 
				
			||||||
 | 
						{ MODKEY,           			XK_period,					focusmon,       {.i = +1} },
 | 
				
			||||||
 | 
						{ MODKEY|ShiftMask, 			XK_comma,					tagmon,         {.i = -1} },
 | 
				
			||||||
 | 
						{ MODKEY|ShiftMask, 			XK_period, 					tagmon,         {.i = +1} },
 | 
				
			||||||
 | 
						{ MODKEY,						XK_minus,					setgaps,        {.i = -5 } },
 | 
				
			||||||
 | 
						{ MODKEY,						XK_equal,					setgaps,        {.i = +5 } },
 | 
				
			||||||
 | 
						{ MODKEY|ShiftMask,				XK_equal,					setgaps,        {.i = 0  } },
 | 
				
			||||||
 | 
						{ 0,							XF86XK_AudioLowerVolume,	spawn,			{.v = downvolcmd} },
 | 
				
			||||||
 | 
						{ 0,                			XF86XK_AudioMute,			spawn,			{.v = mutevolcmd} },
 | 
				
			||||||
 | 
						{ 0,                			XF86XK_AudioRaiseVolume,	spawn,			{.v = upvolcmd} },
 | 
				
			||||||
 | 
						{ 0, 							XF86XK_MonBrightnessUp,		spawn,			{.v = brightness_up} },
 | 
				
			||||||
 | 
						{ 0, 							XF86XK_MonBrightnessDown,	spawn,			{.v = brightness_down} },
 | 
				
			||||||
 | 
						{ 0,							XF86XK_AudioPlay,			spawn,			{.v = playerplaypausecmd} },
 | 
				
			||||||
 | 
						{ 0,							XF86XK_AudioNext,			spawn,			{.v = playernextcmd} },
 | 
				
			||||||
 | 
						{ 0,							XF86XK_AudioPrev,			spawn,			{.v = playerprevcmd} },
 | 
				
			||||||
 | 
						{ 0,							XK_Print,					spawn,			{.v = flameshotcmd} },
 | 
				
			||||||
 | 
						TAGKEYS(            			XK_1,                      					0)
 | 
				
			||||||
 | 
						TAGKEYS(            			XK_2,                      					1)
 | 
				
			||||||
 | 
						TAGKEYS(            			XK_3,                      					2)
 | 
				
			||||||
 | 
						TAGKEYS(            			XK_4,                      					3)
 | 
				
			||||||
 | 
						TAGKEYS(            			XK_5,                      					4)
 | 
				
			||||||
 | 
						TAGKEYS(            			XK_6,                      					5)
 | 
				
			||||||
 | 
						TAGKEYS(            			XK_7,                      					6)
 | 
				
			||||||
 | 
						TAGKEYS(            			XK_8,                      					7)
 | 
				
			||||||
 | 
						TAGKEYS(            			XK_9,                      					8)
 | 
				
			||||||
 | 
						{ MODKEY|ShiftMask, 			XK_q,      					quit,			{0} },
 | 
				
			||||||
 | 
						{ MODKEY|ControlMask|ShiftMask,	XK_q,      					quit,           {1} },
 | 
				
			||||||
 | 
					};
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					/* button definitions */
 | 
				
			||||||
 | 
					/* click can be ClkTagBar, ClkLtSymbol, ClkStatusText, ClkWinTitle, ClkClientWin, or ClkRootWin */
 | 
				
			||||||
 | 
					static Button buttons[] = {
 | 
				
			||||||
 | 
						/* click                event mask      button          function        argument */
 | 
				
			||||||
 | 
						{ ClkLtSymbol,          0,              Button1,        setlayout,      {0} },
 | 
				
			||||||
 | 
						{ ClkLtSymbol,          0,              Button3,        setlayout,      {.v = &layouts[2]} },
 | 
				
			||||||
 | 
						{ ClkWinTitle,          0,              Button2,        zoom,           {0} },
 | 
				
			||||||
 | 
						{ ClkStatusText,        0,              Button2,        spawn,          {.v = termcmd } },
 | 
				
			||||||
 | 
						{ ClkClientWin,         MODKEY,         Button1,        movemouse,      {0} },
 | 
				
			||||||
 | 
						{ ClkClientWin,         MODKEY,         Button2,        togglefloating, {0} },
 | 
				
			||||||
 | 
						{ ClkClientWin,         MODKEY,         Button3,        resizemouse,    {0} },
 | 
				
			||||||
 | 
						{ ClkTagBar,            0,              Button1,        view,           {0} },
 | 
				
			||||||
 | 
						{ ClkTagBar,            0,              Button3,        toggleview,     {0} },
 | 
				
			||||||
 | 
						{ ClkTagBar,            MODKEY,         Button1,        tag,            {0} },
 | 
				
			||||||
 | 
						{ ClkTagBar,            MODKEY,         Button3,        toggletag,      {0} },
 | 
				
			||||||
 | 
					};
 | 
				
			||||||
@@ -1,5 +1,5 @@
 | 
				
			|||||||
# dwm version
 | 
					# dwm version
 | 
				
			||||||
VERSION = 6.1
 | 
					VERSION = 6.2
 | 
				
			||||||
 | 
					
 | 
				
			||||||
# Customize below to fit your system
 | 
					# Customize below to fit your system
 | 
				
			||||||
 | 
					
 | 
				
			||||||
@@ -25,10 +25,10 @@ INCS = -I${X11INC} -I${FREETYPEINC}
 | 
				
			|||||||
LIBS = -L${X11LIB} -lX11 ${XINERAMALIBS} ${FREETYPELIBS}
 | 
					LIBS = -L${X11LIB} -lX11 ${XINERAMALIBS} ${FREETYPELIBS}
 | 
				
			||||||
 | 
					
 | 
				
			||||||
# flags
 | 
					# flags
 | 
				
			||||||
CPPFLAGS = -D_BSD_SOURCE -D_POSIX_C_SOURCE=2 -DVERSION=\"${VERSION}\" ${XINERAMAFLAGS}
 | 
					CPPFLAGS = -D_DEFAULT_SOURCE -D_BSD_SOURCE -D_POSIX_C_SOURCE=200809L -DVERSION=\"${VERSION}\" ${XINERAMAFLAGS}
 | 
				
			||||||
#CFLAGS   = -g -std=c99 -pedantic -Wall -O0 ${INCS} ${CPPFLAGS}
 | 
					#CFLAGS   = -g -std=c99 -pedantic -Wall -O0 ${INCS} ${CPPFLAGS}
 | 
				
			||||||
CFLAGS   = -std=c99 -pedantic -Wall -Wno-deprecated-declarations -Os ${INCS} ${CPPFLAGS}
 | 
					CFLAGS   = -std=c99 -pedantic -Wall -Wno-deprecated-declarations -Os ${INCS} ${CPPFLAGS}
 | 
				
			||||||
LDFLAGS  = -s ${LIBS}
 | 
					LDFLAGS  = ${LIBS}
 | 
				
			||||||
 | 
					
 | 
				
			||||||
# Solaris
 | 
					# Solaris
 | 
				
			||||||
#CFLAGS = -fast ${INCS} -DVERSION=\"${VERSION}\"
 | 
					#CFLAGS = -fast ${INCS} -DVERSION=\"${VERSION}\"
 | 
				
			||||||
 
 | 
				
			|||||||
							
								
								
									
										274
									
								
								drw.c
									
									
									
									
									
								
							
							
						
						
									
										274
									
								
								drw.c
									
									
									
									
									
								
							@@ -63,9 +63,8 @@ utf8decode(const char *c, long *u, size_t clen)
 | 
				
			|||||||
Drw *
 | 
					Drw *
 | 
				
			||||||
drw_create(Display *dpy, int screen, Window root, unsigned int w, unsigned int h)
 | 
					drw_create(Display *dpy, int screen, Window root, unsigned int w, unsigned int h)
 | 
				
			||||||
{
 | 
					{
 | 
				
			||||||
	Drw *drw;
 | 
						Drw *drw = ecalloc(1, sizeof(Drw));
 | 
				
			||||||
 | 
					
 | 
				
			||||||
	drw = ecalloc(1, sizeof(Drw));
 | 
					 | 
				
			||||||
	drw->dpy = dpy;
 | 
						drw->dpy = dpy;
 | 
				
			||||||
	drw->screen = screen;
 | 
						drw->screen = screen;
 | 
				
			||||||
	drw->root = root;
 | 
						drw->root = root;
 | 
				
			||||||
@@ -73,7 +72,6 @@ drw_create(Display *dpy, int screen, Window root, unsigned int w, unsigned int h
 | 
				
			|||||||
	drw->h = h;
 | 
						drw->h = h;
 | 
				
			||||||
	drw->drawable = XCreatePixmap(dpy, root, w, h, DefaultDepth(dpy, screen));
 | 
						drw->drawable = XCreatePixmap(dpy, root, w, h, DefaultDepth(dpy, screen));
 | 
				
			||||||
	drw->gc = XCreateGC(dpy, root, 0, NULL);
 | 
						drw->gc = XCreateGC(dpy, root, 0, NULL);
 | 
				
			||||||
	drw->fontcount = 0;
 | 
					 | 
				
			||||||
	XSetLineAttributes(dpy, drw->gc, 1, LineSolid, CapButt, JoinMiter);
 | 
						XSetLineAttributes(dpy, drw->gc, 1, LineSolid, CapButt, JoinMiter);
 | 
				
			||||||
 | 
					
 | 
				
			||||||
	return drw;
 | 
						return drw;
 | 
				
			||||||
@@ -82,6 +80,9 @@ drw_create(Display *dpy, int screen, Window root, unsigned int w, unsigned int h
 | 
				
			|||||||
void
 | 
					void
 | 
				
			||||||
drw_resize(Drw *drw, unsigned int w, unsigned int h)
 | 
					drw_resize(Drw *drw, unsigned int w, unsigned int h)
 | 
				
			||||||
{
 | 
					{
 | 
				
			||||||
 | 
						if (!drw)
 | 
				
			||||||
 | 
							return;
 | 
				
			||||||
 | 
					
 | 
				
			||||||
	drw->w = w;
 | 
						drw->w = w;
 | 
				
			||||||
	drw->h = h;
 | 
						drw->h = h;
 | 
				
			||||||
	if (drw->drawable)
 | 
						if (drw->drawable)
 | 
				
			||||||
@@ -92,84 +93,70 @@ drw_resize(Drw *drw, unsigned int w, unsigned int h)
 | 
				
			|||||||
void
 | 
					void
 | 
				
			||||||
drw_free(Drw *drw)
 | 
					drw_free(Drw *drw)
 | 
				
			||||||
{
 | 
					{
 | 
				
			||||||
	size_t i;
 | 
					 | 
				
			||||||
 | 
					 | 
				
			||||||
	for (i = 0; i < drw->fontcount; i++)
 | 
					 | 
				
			||||||
		drw_font_free(drw->fonts[i]);
 | 
					 | 
				
			||||||
	XFreePixmap(drw->dpy, drw->drawable);
 | 
						XFreePixmap(drw->dpy, drw->drawable);
 | 
				
			||||||
	XFreeGC(drw->dpy, drw->gc);
 | 
						XFreeGC(drw->dpy, drw->gc);
 | 
				
			||||||
 | 
						drw_fontset_free(drw->fonts);
 | 
				
			||||||
	free(drw);
 | 
						free(drw);
 | 
				
			||||||
}
 | 
					}
 | 
				
			||||||
 | 
					
 | 
				
			||||||
/* This function is an implementation detail. Library users should use
 | 
					/* This function is an implementation detail. Library users should use
 | 
				
			||||||
 * drw_font_create instead.
 | 
					 * drw_fontset_create instead.
 | 
				
			||||||
 */
 | 
					 */
 | 
				
			||||||
static Fnt *
 | 
					static Fnt *
 | 
				
			||||||
drw_font_xcreate(Drw *drw, const char *fontname, FcPattern *fontpattern)
 | 
					xfont_create(Drw *drw, const char *fontname, FcPattern *fontpattern)
 | 
				
			||||||
{
 | 
					{
 | 
				
			||||||
	Fnt *font;
 | 
						Fnt *font;
 | 
				
			||||||
	XftFont *xfont = NULL;
 | 
						XftFont *xfont = NULL;
 | 
				
			||||||
	FcPattern *pattern = NULL;
 | 
						FcPattern *pattern = NULL;
 | 
				
			||||||
 | 
					
 | 
				
			||||||
	if (fontname) {
 | 
						if (fontname) {
 | 
				
			||||||
		/* Using the pattern found at font->xfont->pattern does not yield same
 | 
							/* Using the pattern found at font->xfont->pattern does not yield the
 | 
				
			||||||
		 * the same substitution results as using the pattern returned by
 | 
							 * same substitution results as using the pattern returned by
 | 
				
			||||||
		 * FcNameParse; using the latter results in the desired fallback
 | 
							 * FcNameParse; using the latter results in the desired fallback
 | 
				
			||||||
		 * behaviour whereas the former just results in
 | 
							 * behaviour whereas the former just results in missing-character
 | 
				
			||||||
		 * missing-character-rectangles being drawn, at least with some fonts.
 | 
							 * rectangles being drawn, at least with some fonts. */
 | 
				
			||||||
		 */
 | 
					 | 
				
			||||||
		if (!(xfont = XftFontOpenName(drw->dpy, drw->screen, fontname))) {
 | 
							if (!(xfont = XftFontOpenName(drw->dpy, drw->screen, fontname))) {
 | 
				
			||||||
			fprintf(stderr, "error, cannot load font: '%s'\n", fontname);
 | 
								fprintf(stderr, "error, cannot load font from name: '%s'\n", fontname);
 | 
				
			||||||
			return NULL;
 | 
								return NULL;
 | 
				
			||||||
		}
 | 
							}
 | 
				
			||||||
		if (!(pattern = FcNameParse((FcChar8 *) fontname))) {
 | 
							if (!(pattern = FcNameParse((FcChar8 *) fontname))) {
 | 
				
			||||||
			fprintf(stderr, "error, cannot load font: '%s'\n", fontname);
 | 
								fprintf(stderr, "error, cannot parse font name to pattern: '%s'\n", fontname);
 | 
				
			||||||
			XftFontClose(drw->dpy, xfont);
 | 
								XftFontClose(drw->dpy, xfont);
 | 
				
			||||||
			return NULL;
 | 
								return NULL;
 | 
				
			||||||
		}
 | 
							}
 | 
				
			||||||
	} else if (fontpattern) {
 | 
						} else if (fontpattern) {
 | 
				
			||||||
		if (!(xfont = XftFontOpenPattern(drw->dpy, fontpattern))) {
 | 
							if (!(xfont = XftFontOpenPattern(drw->dpy, fontpattern))) {
 | 
				
			||||||
			fprintf(stderr, "error, cannot load font pattern.\n");
 | 
								fprintf(stderr, "error, cannot load font from pattern.\n");
 | 
				
			||||||
			return NULL;
 | 
								return NULL;
 | 
				
			||||||
		}
 | 
							}
 | 
				
			||||||
	} else {
 | 
						} else {
 | 
				
			||||||
		die("no font specified.\n");
 | 
							die("no font specified.");
 | 
				
			||||||
 | 
						}
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
						/* Do not allow using color fonts. This is a workaround for a BadLength
 | 
				
			||||||
 | 
						 * error from Xft with color glyphs. Modelled on the Xterm workaround. See
 | 
				
			||||||
 | 
						 * https://bugzilla.redhat.com/show_bug.cgi?id=1498269
 | 
				
			||||||
 | 
						 * https://lists.suckless.org/dev/1701/30932.html
 | 
				
			||||||
 | 
						 * https://bugs.debian.org/cgi-bin/bugreport.cgi?bug=916349
 | 
				
			||||||
 | 
						 * and lots more all over the internet.
 | 
				
			||||||
 | 
						 */
 | 
				
			||||||
 | 
						FcBool iscol;
 | 
				
			||||||
 | 
						if(FcPatternGetBool(xfont->pattern, FC_COLOR, 0, &iscol) == FcResultMatch && iscol) {
 | 
				
			||||||
 | 
							XftFontClose(drw->dpy, xfont);
 | 
				
			||||||
 | 
							return NULL;
 | 
				
			||||||
	}
 | 
						}
 | 
				
			||||||
 | 
					
 | 
				
			||||||
	font = ecalloc(1, sizeof(Fnt));
 | 
						font = ecalloc(1, sizeof(Fnt));
 | 
				
			||||||
	font->xfont = xfont;
 | 
						font->xfont = xfont;
 | 
				
			||||||
	font->pattern = pattern;
 | 
						font->pattern = pattern;
 | 
				
			||||||
	font->ascent = xfont->ascent;
 | 
						font->h = xfont->ascent + xfont->descent;
 | 
				
			||||||
	font->descent = xfont->descent;
 | 
					 | 
				
			||||||
	font->h = font->ascent + font->descent;
 | 
					 | 
				
			||||||
	font->dpy = drw->dpy;
 | 
						font->dpy = drw->dpy;
 | 
				
			||||||
 | 
					
 | 
				
			||||||
	return font;
 | 
						return font;
 | 
				
			||||||
}
 | 
					}
 | 
				
			||||||
 | 
					
 | 
				
			||||||
Fnt*
 | 
					static void
 | 
				
			||||||
drw_font_create(Drw *drw, const char *fontname)
 | 
					xfont_free(Fnt *font)
 | 
				
			||||||
{
 | 
					 | 
				
			||||||
	return drw_font_xcreate(drw, fontname, NULL);
 | 
					 | 
				
			||||||
}
 | 
					 | 
				
			||||||
 | 
					 | 
				
			||||||
void
 | 
					 | 
				
			||||||
drw_load_fonts(Drw* drw, const char *fonts[], size_t fontcount)
 | 
					 | 
				
			||||||
{
 | 
					 | 
				
			||||||
	size_t i;
 | 
					 | 
				
			||||||
	Fnt *font;
 | 
					 | 
				
			||||||
 | 
					 | 
				
			||||||
	for (i = 0; i < fontcount; i++) {
 | 
					 | 
				
			||||||
		if (drw->fontcount >= DRW_FONT_CACHE_SIZE) {
 | 
					 | 
				
			||||||
			die("font cache exhausted.\n");
 | 
					 | 
				
			||||||
		} else if ((font = drw_font_xcreate(drw, fonts[i], NULL))) {
 | 
					 | 
				
			||||||
			drw->fonts[drw->fontcount++] = font;
 | 
					 | 
				
			||||||
		}
 | 
					 | 
				
			||||||
	}
 | 
					 | 
				
			||||||
}
 | 
					 | 
				
			||||||
 | 
					 | 
				
			||||||
void
 | 
					 | 
				
			||||||
drw_font_free(Fnt *font)
 | 
					 | 
				
			||||||
{
 | 
					{
 | 
				
			||||||
	if (!font)
 | 
						if (!font)
 | 
				
			||||||
		return;
 | 
							return;
 | 
				
			||||||
@@ -179,55 +166,98 @@ drw_font_free(Fnt *font)
 | 
				
			|||||||
	free(font);
 | 
						free(font);
 | 
				
			||||||
}
 | 
					}
 | 
				
			||||||
 | 
					
 | 
				
			||||||
Clr *
 | 
					Fnt*
 | 
				
			||||||
drw_clr_create(Drw *drw, const char *clrname)
 | 
					drw_fontset_create(Drw* drw, const char *fonts[], size_t fontcount)
 | 
				
			||||||
{
 | 
					{
 | 
				
			||||||
	Clr *clr;
 | 
						Fnt *cur, *ret = NULL;
 | 
				
			||||||
 | 
						size_t i;
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
						if (!drw || !fonts)
 | 
				
			||||||
 | 
							return NULL;
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
						for (i = 1; i <= fontcount; i++) {
 | 
				
			||||||
 | 
							if ((cur = xfont_create(drw, fonts[fontcount - i], NULL))) {
 | 
				
			||||||
 | 
								cur->next = ret;
 | 
				
			||||||
 | 
								ret = cur;
 | 
				
			||||||
 | 
							}
 | 
				
			||||||
 | 
						}
 | 
				
			||||||
 | 
						return (drw->fonts = ret);
 | 
				
			||||||
 | 
					}
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					void
 | 
				
			||||||
 | 
					drw_fontset_free(Fnt *font)
 | 
				
			||||||
 | 
					{
 | 
				
			||||||
 | 
						if (font) {
 | 
				
			||||||
 | 
							drw_fontset_free(font->next);
 | 
				
			||||||
 | 
							xfont_free(font);
 | 
				
			||||||
 | 
						}
 | 
				
			||||||
 | 
					}
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					void
 | 
				
			||||||
 | 
					drw_clr_create(Drw *drw, Clr *dest, const char *clrname)
 | 
				
			||||||
 | 
					{
 | 
				
			||||||
 | 
						if (!drw || !dest || !clrname)
 | 
				
			||||||
 | 
							return;
 | 
				
			||||||
 | 
					
 | 
				
			||||||
	clr = ecalloc(1, sizeof(Clr));
 | 
					 | 
				
			||||||
	if (!XftColorAllocName(drw->dpy, DefaultVisual(drw->dpy, drw->screen),
 | 
						if (!XftColorAllocName(drw->dpy, DefaultVisual(drw->dpy, drw->screen),
 | 
				
			||||||
	                       DefaultColormap(drw->dpy, drw->screen),
 | 
						                       DefaultColormap(drw->dpy, drw->screen),
 | 
				
			||||||
	                       clrname, &clr->rgb))
 | 
						                       clrname, dest))
 | 
				
			||||||
		die("error, cannot allocate color '%s'\n", clrname);
 | 
							die("error, cannot allocate color '%s'", clrname);
 | 
				
			||||||
	clr->pix = clr->rgb.pixel;
 | 
					}
 | 
				
			||||||
 | 
					
 | 
				
			||||||
	return clr;
 | 
					/* Wrapper to create color schemes. The caller has to call free(3) on the
 | 
				
			||||||
 | 
					 * returned color scheme when done using it. */
 | 
				
			||||||
 | 
					Clr *
 | 
				
			||||||
 | 
					drw_scm_create(Drw *drw, const char *clrnames[], size_t clrcount)
 | 
				
			||||||
 | 
					{
 | 
				
			||||||
 | 
						size_t i;
 | 
				
			||||||
 | 
						Clr *ret;
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
						/* need at least two colors for a scheme */
 | 
				
			||||||
 | 
						if (!drw || !clrnames || clrcount < 2 || !(ret = ecalloc(clrcount, sizeof(XftColor))))
 | 
				
			||||||
 | 
							return NULL;
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
						for (i = 0; i < clrcount; i++)
 | 
				
			||||||
 | 
							drw_clr_create(drw, &ret[i], clrnames[i]);
 | 
				
			||||||
 | 
						return ret;
 | 
				
			||||||
}
 | 
					}
 | 
				
			||||||
 | 
					
 | 
				
			||||||
void
 | 
					void
 | 
				
			||||||
drw_clr_free(Clr *clr)
 | 
					drw_setfontset(Drw *drw, Fnt *set)
 | 
				
			||||||
{
 | 
					{
 | 
				
			||||||
	free(clr);
 | 
						if (drw)
 | 
				
			||||||
 | 
							drw->fonts = set;
 | 
				
			||||||
}
 | 
					}
 | 
				
			||||||
 | 
					
 | 
				
			||||||
void
 | 
					void
 | 
				
			||||||
drw_setscheme(Drw *drw, ClrScheme *scheme)
 | 
					drw_setscheme(Drw *drw, Clr *scm)
 | 
				
			||||||
{
 | 
					{
 | 
				
			||||||
	drw->scheme = scheme;
 | 
						if (drw)
 | 
				
			||||||
 | 
							drw->scheme = scm;
 | 
				
			||||||
}
 | 
					}
 | 
				
			||||||
 | 
					
 | 
				
			||||||
void
 | 
					void
 | 
				
			||||||
drw_rect(Drw *drw, int x, int y, unsigned int w, unsigned int h, int filled, int empty, int invert)
 | 
					drw_rect(Drw *drw, int x, int y, unsigned int w, unsigned int h, int filled, int invert)
 | 
				
			||||||
{
 | 
					{
 | 
				
			||||||
	if (!drw->scheme)
 | 
						if (!drw || !drw->scheme)
 | 
				
			||||||
		return;
 | 
							return;
 | 
				
			||||||
	XSetForeground(drw->dpy, drw->gc, invert ? drw->scheme->bg->pix : drw->scheme->fg->pix);
 | 
						XSetForeground(drw->dpy, drw->gc, invert ? drw->scheme[ColBg].pixel : drw->scheme[ColFg].pixel);
 | 
				
			||||||
	if (filled)
 | 
						if (filled)
 | 
				
			||||||
		XFillRectangle(drw->dpy, drw->drawable, drw->gc, x, y, w + 1, h + 1);
 | 
							XFillRectangle(drw->dpy, drw->drawable, drw->gc, x, y, w, h);
 | 
				
			||||||
	else if (empty)
 | 
						else
 | 
				
			||||||
		XDrawRectangle(drw->dpy, drw->drawable, drw->gc, x, y, w, h);
 | 
							XDrawRectangle(drw->dpy, drw->drawable, drw->gc, x, y, w - 1, h - 1);
 | 
				
			||||||
}
 | 
					}
 | 
				
			||||||
 | 
					
 | 
				
			||||||
int
 | 
					int
 | 
				
			||||||
drw_text(Drw *drw, int x, int y, unsigned int w, unsigned int h, const char *text, int invert)
 | 
					drw_text(Drw *drw, int x, int y, unsigned int w, unsigned int h, unsigned int lpad, const char *text, int invert)
 | 
				
			||||||
{
 | 
					{
 | 
				
			||||||
	char buf[1024];
 | 
						char buf[1024];
 | 
				
			||||||
	int tx, ty, th;
 | 
						int ty;
 | 
				
			||||||
	Extnts tex;
 | 
						unsigned int ew;
 | 
				
			||||||
	XftDraw *d = NULL;
 | 
						XftDraw *d = NULL;
 | 
				
			||||||
	Fnt *curfont, *nextfont;
 | 
						Fnt *usedfont, *curfont, *nextfont;
 | 
				
			||||||
	size_t i, len;
 | 
						size_t i, len;
 | 
				
			||||||
	int utf8strlen, utf8charlen, render;
 | 
						int utf8strlen, utf8charlen, render = x || y || w || h;
 | 
				
			||||||
	long utf8codepoint = 0;
 | 
						long utf8codepoint = 0;
 | 
				
			||||||
	const char *utf8str;
 | 
						const char *utf8str;
 | 
				
			||||||
	FcCharSet *fccharset;
 | 
						FcCharSet *fccharset;
 | 
				
			||||||
@@ -236,66 +266,67 @@ drw_text(Drw *drw, int x, int y, unsigned int w, unsigned int h, const char *tex
 | 
				
			|||||||
	XftResult result;
 | 
						XftResult result;
 | 
				
			||||||
	int charexists = 0;
 | 
						int charexists = 0;
 | 
				
			||||||
 | 
					
 | 
				
			||||||
	if (!drw->scheme || !drw->fontcount)
 | 
						if (!drw || (render && !drw->scheme) || !text || !drw->fonts)
 | 
				
			||||||
		return 0;
 | 
							return 0;
 | 
				
			||||||
 | 
					
 | 
				
			||||||
	if (!(render = x || y || w || h)) {
 | 
						if (!render) {
 | 
				
			||||||
		w = ~w;
 | 
							w = ~w;
 | 
				
			||||||
	} else {
 | 
						} else {
 | 
				
			||||||
		XSetForeground(drw->dpy, drw->gc, invert ?
 | 
							XSetForeground(drw->dpy, drw->gc, drw->scheme[invert ? ColFg : ColBg].pixel);
 | 
				
			||||||
		               drw->scheme->fg->pix : drw->scheme->bg->pix);
 | 
					 | 
				
			||||||
		XFillRectangle(drw->dpy, drw->drawable, drw->gc, x, y, w, h);
 | 
							XFillRectangle(drw->dpy, drw->drawable, drw->gc, x, y, w, h);
 | 
				
			||||||
		d = XftDrawCreate(drw->dpy, drw->drawable,
 | 
							d = XftDrawCreate(drw->dpy, drw->drawable,
 | 
				
			||||||
		                  DefaultVisual(drw->dpy, drw->screen),
 | 
							                  DefaultVisual(drw->dpy, drw->screen),
 | 
				
			||||||
		                  DefaultColormap(drw->dpy, drw->screen));
 | 
							                  DefaultColormap(drw->dpy, drw->screen));
 | 
				
			||||||
 | 
							x += lpad;
 | 
				
			||||||
 | 
							w -= lpad;
 | 
				
			||||||
	}
 | 
						}
 | 
				
			||||||
 | 
					
 | 
				
			||||||
	curfont = drw->fonts[0];
 | 
						usedfont = drw->fonts;
 | 
				
			||||||
	while (1) {
 | 
						while (1) {
 | 
				
			||||||
		utf8strlen = 0;
 | 
							utf8strlen = 0;
 | 
				
			||||||
		utf8str = text;
 | 
							utf8str = text;
 | 
				
			||||||
		nextfont = NULL;
 | 
							nextfont = NULL;
 | 
				
			||||||
		while (*text) {
 | 
							while (*text) {
 | 
				
			||||||
			utf8charlen = utf8decode(text, &utf8codepoint, UTF_SIZ);
 | 
								utf8charlen = utf8decode(text, &utf8codepoint, UTF_SIZ);
 | 
				
			||||||
			for (i = 0; i < drw->fontcount; i++) {
 | 
								for (curfont = drw->fonts; curfont; curfont = curfont->next) {
 | 
				
			||||||
				charexists = charexists || XftCharExists(drw->dpy, drw->fonts[i]->xfont, utf8codepoint);
 | 
									charexists = charexists || XftCharExists(drw->dpy, curfont->xfont, utf8codepoint);
 | 
				
			||||||
				if (charexists) {
 | 
									if (charexists) {
 | 
				
			||||||
					if (drw->fonts[i] == curfont) {
 | 
										if (curfont == usedfont) {
 | 
				
			||||||
						utf8strlen += utf8charlen;
 | 
											utf8strlen += utf8charlen;
 | 
				
			||||||
						text += utf8charlen;
 | 
											text += utf8charlen;
 | 
				
			||||||
					} else {
 | 
										} else {
 | 
				
			||||||
						nextfont = drw->fonts[i];
 | 
											nextfont = curfont;
 | 
				
			||||||
					}
 | 
										}
 | 
				
			||||||
					break;
 | 
										break;
 | 
				
			||||||
				}
 | 
									}
 | 
				
			||||||
			}
 | 
								}
 | 
				
			||||||
 | 
					
 | 
				
			||||||
			if (!charexists || (nextfont && nextfont != curfont))
 | 
								if (!charexists || nextfont)
 | 
				
			||||||
				break;
 | 
									break;
 | 
				
			||||||
			else
 | 
								else
 | 
				
			||||||
				charexists = 0;
 | 
									charexists = 0;
 | 
				
			||||||
		}
 | 
							}
 | 
				
			||||||
 | 
					
 | 
				
			||||||
		if (utf8strlen) {
 | 
							if (utf8strlen) {
 | 
				
			||||||
			drw_font_getexts(curfont, utf8str, utf8strlen, &tex);
 | 
								drw_font_getexts(usedfont, utf8str, utf8strlen, &ew, NULL);
 | 
				
			||||||
			/* shorten text if necessary */
 | 
								/* shorten text if necessary */
 | 
				
			||||||
			for (len = MIN(utf8strlen, (sizeof buf) - 1); len && (tex.w > w - drw->fonts[0]->h || w < drw->fonts[0]->h); len--)
 | 
								for (len = MIN(utf8strlen, sizeof(buf) - 1); len && ew > w; len--)
 | 
				
			||||||
				drw_font_getexts(curfont, utf8str, len, &tex);
 | 
									drw_font_getexts(usedfont, utf8str, len, &ew, NULL);
 | 
				
			||||||
 | 
					
 | 
				
			||||||
			if (len) {
 | 
								if (len) {
 | 
				
			||||||
				memcpy(buf, utf8str, len);
 | 
									memcpy(buf, utf8str, len);
 | 
				
			||||||
				buf[len] = '\0';
 | 
									buf[len] = '\0';
 | 
				
			||||||
				if (len < utf8strlen)
 | 
									if (len < utf8strlen)
 | 
				
			||||||
					for (i = len; i && i > len - 3; buf[--i] = '.');
 | 
										for (i = len; i && i > len - 3; buf[--i] = '.')
 | 
				
			||||||
 | 
											; /* NOP */
 | 
				
			||||||
 | 
					
 | 
				
			||||||
				if (render) {
 | 
									if (render) {
 | 
				
			||||||
					th = curfont->ascent + curfont->descent;
 | 
										ty = y + (h - usedfont->h) / 2 + usedfont->xfont->ascent;
 | 
				
			||||||
					ty = y + (h / 2) - (th / 2) + curfont->ascent;
 | 
										XftDrawStringUtf8(d, &drw->scheme[invert ? ColBg : ColFg],
 | 
				
			||||||
					tx = x + (h / 2);
 | 
										                  usedfont->xfont, x, ty, (XftChar8 *)buf, len);
 | 
				
			||||||
					XftDrawStringUtf8(d, invert ? &drw->scheme->bg->rgb : &drw->scheme->fg->rgb, curfont->xfont, tx, ty, (XftChar8 *)buf, len);
 | 
					 | 
				
			||||||
				}
 | 
									}
 | 
				
			||||||
				x += tex.w;
 | 
									x += ew;
 | 
				
			||||||
				w -= tex.w;
 | 
									w -= ew;
 | 
				
			||||||
			}
 | 
								}
 | 
				
			||||||
		}
 | 
							}
 | 
				
			||||||
 | 
					
 | 
				
			||||||
@@ -303,28 +334,24 @@ drw_text(Drw *drw, int x, int y, unsigned int w, unsigned int h, const char *tex
 | 
				
			|||||||
			break;
 | 
								break;
 | 
				
			||||||
		} else if (nextfont) {
 | 
							} else if (nextfont) {
 | 
				
			||||||
			charexists = 0;
 | 
								charexists = 0;
 | 
				
			||||||
			curfont = nextfont;
 | 
								usedfont = nextfont;
 | 
				
			||||||
		} else {
 | 
							} else {
 | 
				
			||||||
			/* Regardless of whether or not a fallback font is found, the
 | 
								/* Regardless of whether or not a fallback font is found, the
 | 
				
			||||||
			 * character must be drawn.
 | 
								 * character must be drawn. */
 | 
				
			||||||
			 */
 | 
					 | 
				
			||||||
			charexists = 1;
 | 
								charexists = 1;
 | 
				
			||||||
 | 
					
 | 
				
			||||||
			if (drw->fontcount >= DRW_FONT_CACHE_SIZE)
 | 
					 | 
				
			||||||
				continue;
 | 
					 | 
				
			||||||
 | 
					 | 
				
			||||||
			fccharset = FcCharSetCreate();
 | 
								fccharset = FcCharSetCreate();
 | 
				
			||||||
			FcCharSetAddChar(fccharset, utf8codepoint);
 | 
								FcCharSetAddChar(fccharset, utf8codepoint);
 | 
				
			||||||
 | 
					
 | 
				
			||||||
			if (!drw->fonts[0]->pattern) {
 | 
								if (!drw->fonts->pattern) {
 | 
				
			||||||
				/* Refer to the comment in drw_font_xcreate for more
 | 
									/* Refer to the comment in xfont_create for more information. */
 | 
				
			||||||
				 * information. */
 | 
									die("the first font in the cache must be loaded from a font string.");
 | 
				
			||||||
				die("the first font in the cache must be loaded from a font string.\n");
 | 
					 | 
				
			||||||
			}
 | 
								}
 | 
				
			||||||
 | 
					
 | 
				
			||||||
			fcpattern = FcPatternDuplicate(drw->fonts[0]->pattern);
 | 
								fcpattern = FcPatternDuplicate(drw->fonts->pattern);
 | 
				
			||||||
			FcPatternAddCharSet(fcpattern, FC_CHARSET, fccharset);
 | 
								FcPatternAddCharSet(fcpattern, FC_CHARSET, fccharset);
 | 
				
			||||||
			FcPatternAddBool(fcpattern, FC_SCALABLE, FcTrue);
 | 
								FcPatternAddBool(fcpattern, FC_SCALABLE, FcTrue);
 | 
				
			||||||
 | 
								FcPatternAddBool(fcpattern, FC_COLOR, FcFalse);
 | 
				
			||||||
 | 
					
 | 
				
			||||||
			FcConfigSubstitute(NULL, fcpattern, FcMatchPattern);
 | 
								FcConfigSubstitute(NULL, fcpattern, FcMatchPattern);
 | 
				
			||||||
			FcDefaultSubstitute(fcpattern);
 | 
								FcDefaultSubstitute(fcpattern);
 | 
				
			||||||
@@ -334,12 +361,14 @@ drw_text(Drw *drw, int x, int y, unsigned int w, unsigned int h, const char *tex
 | 
				
			|||||||
			FcPatternDestroy(fcpattern);
 | 
								FcPatternDestroy(fcpattern);
 | 
				
			||||||
 | 
					
 | 
				
			||||||
			if (match) {
 | 
								if (match) {
 | 
				
			||||||
				curfont = drw_font_xcreate(drw, NULL, match);
 | 
									usedfont = xfont_create(drw, NULL, match);
 | 
				
			||||||
				if (curfont && XftCharExists(drw->dpy, curfont->xfont, utf8codepoint)) {
 | 
									if (usedfont && XftCharExists(drw->dpy, usedfont->xfont, utf8codepoint)) {
 | 
				
			||||||
					drw->fonts[drw->fontcount++] = curfont;
 | 
										for (curfont = drw->fonts; curfont->next; curfont = curfont->next)
 | 
				
			||||||
 | 
											; /* NOP */
 | 
				
			||||||
 | 
										curfont->next = usedfont;
 | 
				
			||||||
				} else {
 | 
									} else {
 | 
				
			||||||
					drw_font_free(curfont);
 | 
										xfont_free(usedfont);
 | 
				
			||||||
					curfont = drw->fonts[0];
 | 
										usedfont = drw->fonts;
 | 
				
			||||||
				}
 | 
									}
 | 
				
			||||||
			}
 | 
								}
 | 
				
			||||||
		}
 | 
							}
 | 
				
			||||||
@@ -347,34 +376,40 @@ drw_text(Drw *drw, int x, int y, unsigned int w, unsigned int h, const char *tex
 | 
				
			|||||||
	if (d)
 | 
						if (d)
 | 
				
			||||||
		XftDrawDestroy(d);
 | 
							XftDrawDestroy(d);
 | 
				
			||||||
 | 
					
 | 
				
			||||||
	return x;
 | 
						return x + (render ? w : 0);
 | 
				
			||||||
}
 | 
					}
 | 
				
			||||||
 | 
					
 | 
				
			||||||
void
 | 
					void
 | 
				
			||||||
drw_map(Drw *drw, Window win, int x, int y, unsigned int w, unsigned int h)
 | 
					drw_map(Drw *drw, Window win, int x, int y, unsigned int w, unsigned int h)
 | 
				
			||||||
{
 | 
					{
 | 
				
			||||||
 | 
						if (!drw)
 | 
				
			||||||
 | 
							return;
 | 
				
			||||||
 | 
					
 | 
				
			||||||
	XCopyArea(drw->dpy, drw->drawable, win, drw->gc, x, y, w, h, x, y);
 | 
						XCopyArea(drw->dpy, drw->drawable, win, drw->gc, x, y, w, h, x, y);
 | 
				
			||||||
	XSync(drw->dpy, False);
 | 
						XSync(drw->dpy, False);
 | 
				
			||||||
}
 | 
					}
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					unsigned int
 | 
				
			||||||
 | 
					drw_fontset_getwidth(Drw *drw, const char *text)
 | 
				
			||||||
 | 
					{
 | 
				
			||||||
 | 
						if (!drw || !drw->fonts || !text)
 | 
				
			||||||
 | 
							return 0;
 | 
				
			||||||
 | 
						return drw_text(drw, 0, 0, 0, 0, 0, text, 0);
 | 
				
			||||||
 | 
					}
 | 
				
			||||||
 | 
					
 | 
				
			||||||
void
 | 
					void
 | 
				
			||||||
drw_font_getexts(Fnt *font, const char *text, unsigned int len, Extnts *tex)
 | 
					drw_font_getexts(Fnt *font, const char *text, unsigned int len, unsigned int *w, unsigned int *h)
 | 
				
			||||||
{
 | 
					{
 | 
				
			||||||
	XGlyphInfo ext;
 | 
						XGlyphInfo ext;
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
						if (!font || !text)
 | 
				
			||||||
 | 
							return;
 | 
				
			||||||
 | 
					
 | 
				
			||||||
	XftTextExtentsUtf8(font->dpy, font->xfont, (XftChar8 *)text, len, &ext);
 | 
						XftTextExtentsUtf8(font->dpy, font->xfont, (XftChar8 *)text, len, &ext);
 | 
				
			||||||
	tex->h = font->h;
 | 
						if (w)
 | 
				
			||||||
	tex->w = ext.xOff;
 | 
							*w = ext.xOff;
 | 
				
			||||||
}
 | 
						if (h)
 | 
				
			||||||
 | 
							*h = font->h;
 | 
				
			||||||
unsigned int
 | 
					 | 
				
			||||||
drw_font_getexts_width(Fnt *font, const char *text, unsigned int len)
 | 
					 | 
				
			||||||
{
 | 
					 | 
				
			||||||
	Extnts tex;
 | 
					 | 
				
			||||||
 | 
					 | 
				
			||||||
	drw_font_getexts(font, text, len, &tex);
 | 
					 | 
				
			||||||
 | 
					 | 
				
			||||||
	return tex.w;
 | 
					 | 
				
			||||||
}
 | 
					}
 | 
				
			||||||
 | 
					
 | 
				
			||||||
Cur *
 | 
					Cur *
 | 
				
			||||||
@@ -382,7 +417,9 @@ drw_cur_create(Drw *drw, int shape)
 | 
				
			|||||||
{
 | 
					{
 | 
				
			||||||
	Cur *cur;
 | 
						Cur *cur;
 | 
				
			||||||
 | 
					
 | 
				
			||||||
	cur = ecalloc(1, sizeof(Cur));
 | 
						if (!drw || !(cur = ecalloc(1, sizeof(Cur))))
 | 
				
			||||||
 | 
							return NULL;
 | 
				
			||||||
 | 
					
 | 
				
			||||||
	cur->cursor = XCreateFontCursor(drw->dpy, shape);
 | 
						cur->cursor = XCreateFontCursor(drw->dpy, shape);
 | 
				
			||||||
 | 
					
 | 
				
			||||||
	return cur;
 | 
						return cur;
 | 
				
			||||||
@@ -393,6 +430,7 @@ drw_cur_free(Drw *drw, Cur *cursor)
 | 
				
			|||||||
{
 | 
					{
 | 
				
			||||||
	if (!cursor)
 | 
						if (!cursor)
 | 
				
			||||||
		return;
 | 
							return;
 | 
				
			||||||
 | 
					
 | 
				
			||||||
	XFreeCursor(drw->dpy, cursor->cursor);
 | 
						XFreeCursor(drw->dpy, cursor->cursor);
 | 
				
			||||||
	free(cursor);
 | 
						free(cursor);
 | 
				
			||||||
}
 | 
					}
 | 
				
			||||||
 
 | 
				
			|||||||
							
								
								
									
										63
									
								
								drw.h
									
									
									
									
									
								
							
							
						
						
									
										63
									
								
								drw.h
									
									
									
									
									
								
							@@ -1,29 +1,19 @@
 | 
				
			|||||||
/* See LICENSE file for copyright and license details. */
 | 
					/* See LICENSE file for copyright and license details. */
 | 
				
			||||||
#define DRW_FONT_CACHE_SIZE 32
 | 
					 | 
				
			||||||
 | 
					 | 
				
			||||||
typedef struct {
 | 
					 | 
				
			||||||
	unsigned long pix;
 | 
					 | 
				
			||||||
	XftColor rgb;
 | 
					 | 
				
			||||||
} Clr;
 | 
					 | 
				
			||||||
 | 
					
 | 
				
			||||||
typedef struct {
 | 
					typedef struct {
 | 
				
			||||||
	Cursor cursor;
 | 
						Cursor cursor;
 | 
				
			||||||
} Cur;
 | 
					} Cur;
 | 
				
			||||||
 | 
					
 | 
				
			||||||
typedef struct {
 | 
					typedef struct Fnt {
 | 
				
			||||||
	Display *dpy;
 | 
						Display *dpy;
 | 
				
			||||||
	int ascent;
 | 
					 | 
				
			||||||
	int descent;
 | 
					 | 
				
			||||||
	unsigned int h;
 | 
						unsigned int h;
 | 
				
			||||||
	XftFont *xfont;
 | 
						XftFont *xfont;
 | 
				
			||||||
	FcPattern *pattern;
 | 
						FcPattern *pattern;
 | 
				
			||||||
 | 
						struct Fnt *next;
 | 
				
			||||||
} Fnt;
 | 
					} Fnt;
 | 
				
			||||||
 | 
					
 | 
				
			||||||
typedef struct {
 | 
					enum { ColFg, ColBg, ColBorder }; /* Clr scheme index */
 | 
				
			||||||
	Clr *fg;
 | 
					typedef XftColor Clr;
 | 
				
			||||||
	Clr *bg;
 | 
					 | 
				
			||||||
	Clr *border;
 | 
					 | 
				
			||||||
} ClrScheme;
 | 
					 | 
				
			||||||
 | 
					
 | 
				
			||||||
typedef struct {
 | 
					typedef struct {
 | 
				
			||||||
	unsigned int w, h;
 | 
						unsigned int w, h;
 | 
				
			||||||
@@ -32,43 +22,36 @@ typedef struct {
 | 
				
			|||||||
	Window root;
 | 
						Window root;
 | 
				
			||||||
	Drawable drawable;
 | 
						Drawable drawable;
 | 
				
			||||||
	GC gc;
 | 
						GC gc;
 | 
				
			||||||
	ClrScheme *scheme;
 | 
						Clr *scheme;
 | 
				
			||||||
	size_t fontcount;
 | 
						Fnt *fonts;
 | 
				
			||||||
	Fnt *fonts[DRW_FONT_CACHE_SIZE];
 | 
					 | 
				
			||||||
} Drw;
 | 
					} Drw;
 | 
				
			||||||
 | 
					
 | 
				
			||||||
typedef struct {
 | 
					 | 
				
			||||||
	unsigned int w;
 | 
					 | 
				
			||||||
	unsigned int h;
 | 
					 | 
				
			||||||
} Extnts;
 | 
					 | 
				
			||||||
 | 
					 | 
				
			||||||
/* Drawable abstraction */
 | 
					/* Drawable abstraction */
 | 
				
			||||||
Drw *drw_create(Display *, int, Window, unsigned int, unsigned int);
 | 
					Drw *drw_create(Display *dpy, int screen, Window win, unsigned int w, unsigned int h);
 | 
				
			||||||
void drw_resize(Drw *, unsigned int, unsigned int);
 | 
					void drw_resize(Drw *drw, unsigned int w, unsigned int h);
 | 
				
			||||||
void drw_free(Drw *);
 | 
					void drw_free(Drw *drw);
 | 
				
			||||||
 | 
					
 | 
				
			||||||
/* Fnt abstraction */
 | 
					/* Fnt abstraction */
 | 
				
			||||||
Fnt *drw_font_create(Drw *, const char *);
 | 
					Fnt *drw_fontset_create(Drw* drw, const char *fonts[], size_t fontcount);
 | 
				
			||||||
void drw_load_fonts(Drw *, const char *[], size_t);
 | 
					void drw_fontset_free(Fnt* set);
 | 
				
			||||||
void drw_font_free(Fnt *);
 | 
					unsigned int drw_fontset_getwidth(Drw *drw, const char *text);
 | 
				
			||||||
void drw_font_getexts(Fnt *, const char *, unsigned int, Extnts *);
 | 
					void drw_font_getexts(Fnt *font, const char *text, unsigned int len, unsigned int *w, unsigned int *h);
 | 
				
			||||||
unsigned int drw_font_getexts_width(Fnt *, const char *, unsigned int);
 | 
					 | 
				
			||||||
 | 
					
 | 
				
			||||||
/* Colour abstraction */
 | 
					/* Colorscheme abstraction */
 | 
				
			||||||
Clr *drw_clr_create(Drw *, const char *);
 | 
					void drw_clr_create(Drw *drw, Clr *dest, const char *clrname);
 | 
				
			||||||
void drw_clr_free(Clr *);
 | 
					Clr *drw_scm_create(Drw *drw, const char *clrnames[], size_t clrcount);
 | 
				
			||||||
 | 
					
 | 
				
			||||||
/* Cursor abstraction */
 | 
					/* Cursor abstraction */
 | 
				
			||||||
Cur *drw_cur_create(Drw *, int);
 | 
					Cur *drw_cur_create(Drw *drw, int shape);
 | 
				
			||||||
void drw_cur_free(Drw *, Cur *);
 | 
					void drw_cur_free(Drw *drw, Cur *cursor);
 | 
				
			||||||
 | 
					
 | 
				
			||||||
/* Drawing context manipulation */
 | 
					/* Drawing context manipulation */
 | 
				
			||||||
void drw_setfont(Drw *, Fnt *);
 | 
					void drw_setfontset(Drw *drw, Fnt *set);
 | 
				
			||||||
void drw_setscheme(Drw *, ClrScheme *);
 | 
					void drw_setscheme(Drw *drw, Clr *scm);
 | 
				
			||||||
 | 
					
 | 
				
			||||||
/* Drawing functions */
 | 
					/* Drawing functions */
 | 
				
			||||||
void drw_rect(Drw *, int, int, unsigned int, unsigned int, int, int, int);
 | 
					void drw_rect(Drw *drw, int x, int y, unsigned int w, unsigned int h, int filled, int invert);
 | 
				
			||||||
int drw_text(Drw *, int, int, unsigned int, unsigned int, const char *, int);
 | 
					int drw_text(Drw *drw, int x, int y, unsigned int w, unsigned int h, unsigned int lpad, const char *text, int invert);
 | 
				
			||||||
 | 
					
 | 
				
			||||||
/* Map functions */
 | 
					/* Map functions */
 | 
				
			||||||
void drw_map(Drw *, Window, int, int, unsigned int, unsigned int);
 | 
					void drw_map(Drw *drw, Window win, int x, int y, unsigned int w, unsigned int h);
 | 
				
			||||||
 
 | 
				
			|||||||
							
								
								
									
										99
									
								
								dwm.1
									
									
									
									
									
								
							
							
						
						
									
										99
									
								
								dwm.1
									
									
									
									
									
								
							@@ -10,8 +10,9 @@ and floating layouts. Either layout can be applied dynamically, optimising the
 | 
				
			|||||||
environment for the application in use and the task performed.
 | 
					environment for the application in use and the task performed.
 | 
				
			||||||
.P
 | 
					.P
 | 
				
			||||||
In tiled layouts windows are managed in a master and stacking area. The master
 | 
					In tiled layouts windows are managed in a master and stacking area. The master
 | 
				
			||||||
area contains the window which currently needs most attention, whereas the
 | 
					area on the left contains one window by default, and the stacking area on the
 | 
				
			||||||
stacking area contains all other windows. In monocle layout all windows are
 | 
					right contains all other windows. The number of master area windows can be
 | 
				
			||||||
 | 
					adjusted from zero to an arbitrary number. In monocle layout all windows are
 | 
				
			||||||
maximised to the screen size. In floating layout windows can be resized and
 | 
					maximised to the screen size. In floating layout windows can be resized and
 | 
				
			||||||
moved freely. Dialog windows are always managed floating, regardless of the
 | 
					moved freely. Dialog windows are always managed floating, regardless of the
 | 
				
			||||||
layout applied.
 | 
					layout applied.
 | 
				
			||||||
@@ -29,10 +30,18 @@ top left corner.  The tags which are applied to one or more windows are
 | 
				
			|||||||
indicated with an empty square in the top left corner.
 | 
					indicated with an empty square in the top left corner.
 | 
				
			||||||
.P
 | 
					.P
 | 
				
			||||||
dwm draws a small border around windows to indicate the focus state.
 | 
					dwm draws a small border around windows to indicate the focus state.
 | 
				
			||||||
 | 
					.P
 | 
				
			||||||
 | 
					On start, dwm can start additional programs that may be specified in two special
 | 
				
			||||||
 | 
					shell scripts (see the FILES section below), autostart_blocking.sh and
 | 
				
			||||||
 | 
					autostart.sh.  The former is executed first and dwm will wait for its
 | 
				
			||||||
 | 
					termination before starting.  The latter is executed in the background before
 | 
				
			||||||
 | 
					dwm enters its handler loop.
 | 
				
			||||||
 | 
					.P
 | 
				
			||||||
 | 
					Either of these files may be omitted.
 | 
				
			||||||
.SH OPTIONS
 | 
					.SH OPTIONS
 | 
				
			||||||
.TP
 | 
					.TP
 | 
				
			||||||
.B \-v
 | 
					.B \-v
 | 
				
			||||||
prints version information to standard output, then exits.
 | 
					prints version information to stderr, then exits.
 | 
				
			||||||
.SH USAGE
 | 
					.SH USAGE
 | 
				
			||||||
.SS Status bar
 | 
					.SS Status bar
 | 
				
			||||||
.TP
 | 
					.TP
 | 
				
			||||||
@@ -59,6 +68,26 @@ click on a tag label adds/removes that tag to/from the focused window.
 | 
				
			|||||||
Start
 | 
					Start
 | 
				
			||||||
.BR st(1).
 | 
					.BR st(1).
 | 
				
			||||||
.TP
 | 
					.TP
 | 
				
			||||||
 | 
					.B Mod1\-p
 | 
				
			||||||
 | 
					Spawn
 | 
				
			||||||
 | 
					.BR rofi(1)
 | 
				
			||||||
 | 
					for launching other programs.
 | 
				
			||||||
 | 
					.TP
 | 
				
			||||||
 | 
					.B Mod1\-c
 | 
				
			||||||
 | 
					Spawn
 | 
				
			||||||
 | 
					.BR rofi(1)
 | 
				
			||||||
 | 
					for Greenclip clipboard manager
 | 
				
			||||||
 | 
					.TP
 | 
				
			||||||
 | 
					.B Mod1\-Shift\-n
 | 
				
			||||||
 | 
					Spawn
 | 
				
			||||||
 | 
					.BR light-locker(1)
 | 
				
			||||||
 | 
					to lock screen.
 | 
				
			||||||
 | 
					.TP
 | 
				
			||||||
 | 
					.B Mod1\-Shift\-s
 | 
				
			||||||
 | 
					Spawn
 | 
				
			||||||
 | 
					.BR suspend(1)
 | 
				
			||||||
 | 
					to lock screen and go to sleep.
 | 
				
			||||||
 | 
					.TP
 | 
				
			||||||
.B Mod1\-,
 | 
					.B Mod1\-,
 | 
				
			||||||
Focus previous screen, if any.
 | 
					Focus previous screen, if any.
 | 
				
			||||||
.TP
 | 
					.TP
 | 
				
			||||||
@@ -71,6 +100,15 @@ Send focused window to previous screen, if any.
 | 
				
			|||||||
.B Mod1\-Shift\-.
 | 
					.B Mod1\-Shift\-.
 | 
				
			||||||
Send focused window to next screen, if any.
 | 
					Send focused window to next screen, if any.
 | 
				
			||||||
.TP
 | 
					.TP
 | 
				
			||||||
 | 
					.B Mod1\--
 | 
				
			||||||
 | 
					Decrease window gap.
 | 
				
			||||||
 | 
					.TP
 | 
				
			||||||
 | 
					.B Mod1\-=
 | 
				
			||||||
 | 
					Increase window gap.
 | 
				
			||||||
 | 
					.TP
 | 
				
			||||||
 | 
					.B Mod1\-Shift\-=
 | 
				
			||||||
 | 
					Reset window gap to 0.
 | 
				
			||||||
 | 
					.TP
 | 
				
			||||||
.B Mod1\-b
 | 
					.B Mod1\-b
 | 
				
			||||||
Toggles bar on and off.
 | 
					Toggles bar on and off.
 | 
				
			||||||
.TP
 | 
					.TP
 | 
				
			||||||
@@ -83,9 +121,24 @@ Sets floating layout.
 | 
				
			|||||||
.B Mod1\-m
 | 
					.B Mod1\-m
 | 
				
			||||||
Sets monocle layout.
 | 
					Sets monocle layout.
 | 
				
			||||||
.TP
 | 
					.TP
 | 
				
			||||||
 | 
					.B Mod1\-u
 | 
				
			||||||
 | 
					Sets centered master layout.
 | 
				
			||||||
 | 
					.TP
 | 
				
			||||||
 | 
					.B Mod1\-o
 | 
				
			||||||
 | 
					Sets centered floating master layout.
 | 
				
			||||||
 | 
					.TP
 | 
				
			||||||
 | 
					.B Mod1\-g
 | 
				
			||||||
 | 
					Sets grid layout.
 | 
				
			||||||
 | 
					.TP
 | 
				
			||||||
.B Mod1\-space
 | 
					.B Mod1\-space
 | 
				
			||||||
Toggles between current and previous layout.
 | 
					Toggles between current and previous layout.
 | 
				
			||||||
.TP
 | 
					.TP
 | 
				
			||||||
 | 
					.B Mod1\-Control\-,
 | 
				
			||||||
 | 
					Cycles backwards in layout list.
 | 
				
			||||||
 | 
					.TP
 | 
				
			||||||
 | 
					.B Mod1\-Control\-.
 | 
				
			||||||
 | 
					Cycles forwards in layout list.
 | 
				
			||||||
 | 
					.TP
 | 
				
			||||||
.B Mod1\-j
 | 
					.B Mod1\-j
 | 
				
			||||||
Focus next window.
 | 
					Focus next window.
 | 
				
			||||||
.TP
 | 
					.TP
 | 
				
			||||||
@@ -93,10 +146,10 @@ Focus next window.
 | 
				
			|||||||
Focus previous window.
 | 
					Focus previous window.
 | 
				
			||||||
.TP
 | 
					.TP
 | 
				
			||||||
.B Mod1\-i
 | 
					.B Mod1\-i
 | 
				
			||||||
Increase clients in master area.
 | 
					Increase number of windows in master area.
 | 
				
			||||||
.TP
 | 
					.TP
 | 
				
			||||||
.B Mod1\-d
 | 
					.B Mod1\-d
 | 
				
			||||||
Decrease clients in master area.
 | 
					Decrease number of windows in master area.
 | 
				
			||||||
.TP
 | 
					.TP
 | 
				
			||||||
.B Mod1\-l
 | 
					.B Mod1\-l
 | 
				
			||||||
Increase master area size.
 | 
					Increase master area size.
 | 
				
			||||||
@@ -136,6 +189,9 @@ Add/remove all windows with nth tag to/from the view.
 | 
				
			|||||||
.TP
 | 
					.TP
 | 
				
			||||||
.B Mod1\-Shift\-q
 | 
					.B Mod1\-Shift\-q
 | 
				
			||||||
Quit dwm.
 | 
					Quit dwm.
 | 
				
			||||||
 | 
					.TP
 | 
				
			||||||
 | 
					.B Mod1\-Control\-Shift\-q
 | 
				
			||||||
 | 
					Restart dwm.
 | 
				
			||||||
.SS Mouse commands
 | 
					.SS Mouse commands
 | 
				
			||||||
.TP
 | 
					.TP
 | 
				
			||||||
.B Mod1\-Button1
 | 
					.B Mod1\-Button1
 | 
				
			||||||
@@ -146,13 +202,32 @@ Toggles focused window between floating and tiled state.
 | 
				
			|||||||
.TP
 | 
					.TP
 | 
				
			||||||
.B Mod1\-Button3
 | 
					.B Mod1\-Button3
 | 
				
			||||||
Resize focused window while dragging. Tiled windows will be toggled to the floating state.
 | 
					Resize focused window while dragging. Tiled windows will be toggled to the floating state.
 | 
				
			||||||
 | 
					.SH FILES
 | 
				
			||||||
 | 
					The files containing programs to be started along with dwm are searched for in
 | 
				
			||||||
 | 
					the dwm root directory.
 | 
				
			||||||
 | 
					.P
 | 
				
			||||||
 | 
					The first existing directory is scanned for any of the autostart files below.
 | 
				
			||||||
 | 
					.TP 15
 | 
				
			||||||
 | 
					autostart.sh
 | 
				
			||||||
 | 
					This file is started as a shell background process before dwm enters its handler
 | 
				
			||||||
 | 
					loop.
 | 
				
			||||||
 | 
					.TP 15
 | 
				
			||||||
 | 
					autostart_blocking.sh
 | 
				
			||||||
 | 
					This file is started before any autostart.sh; dwm waits for its termination.
 | 
				
			||||||
.SH CUSTOMIZATION
 | 
					.SH CUSTOMIZATION
 | 
				
			||||||
dwm is customized by creating a custom config.h and (re)compiling the source
 | 
					dwm is customized by creating a custom config.h and (re)compiling the source
 | 
				
			||||||
code. This keeps it fast, secure and simple.
 | 
					code. This keeps it fast, secure and simple.
 | 
				
			||||||
 | 
					.SH SIGNALS
 | 
				
			||||||
 | 
					.TP
 | 
				
			||||||
 | 
					.B SIGHUP - 1
 | 
				
			||||||
 | 
					Restart the dwm process.
 | 
				
			||||||
 | 
					.TP
 | 
				
			||||||
 | 
					.B SIGTERM - 15
 | 
				
			||||||
 | 
					Cleanly terminate the dwm process.
 | 
				
			||||||
.SH SEE ALSO
 | 
					.SH SEE ALSO
 | 
				
			||||||
.BR dmenu (1),
 | 
					.BR rofi (1),
 | 
				
			||||||
.BR st (1)
 | 
					.BR st (1)
 | 
				
			||||||
.SH BUGS
 | 
					.SH ISSUES
 | 
				
			||||||
Java applications which use the XToolkit/XAWT backend may draw grey windows
 | 
					Java applications which use the XToolkit/XAWT backend may draw grey windows
 | 
				
			||||||
only. The XToolkit/XAWT backend breaks ICCCM-compliance in recent JDK 1.5 and early
 | 
					only. The XToolkit/XAWT backend breaks ICCCM-compliance in recent JDK 1.5 and early
 | 
				
			||||||
JDK 1.6 versions, because it assumes a reparenting window manager. Possible workarounds
 | 
					JDK 1.6 versions, because it assumes a reparenting window manager. Possible workarounds
 | 
				
			||||||
@@ -166,11 +241,5 @@ or
 | 
				
			|||||||
(to pretend that a non-reparenting window manager is running that the
 | 
					(to pretend that a non-reparenting window manager is running that the
 | 
				
			||||||
XToolkit/XAWT backend can recognize) or when using OpenJDK setting the environment variable
 | 
					XToolkit/XAWT backend can recognize) or when using OpenJDK setting the environment variable
 | 
				
			||||||
.BR _JAVA_AWT_WM_NONREPARENTING=1 .
 | 
					.BR _JAVA_AWT_WM_NONREPARENTING=1 .
 | 
				
			||||||
.P
 | 
					.SH BUGS
 | 
				
			||||||
GTK 2.10.9+ versions contain a broken
 | 
					Send all bug reports with a patch to hackers@suckless.org.
 | 
				
			||||||
.BR Save\-As
 | 
					 | 
				
			||||||
file dialog implementation,
 | 
					 | 
				
			||||||
which requests to reconfigure its window size in an endless loop. However, its
 | 
					 | 
				
			||||||
window is still respondable during this state, so you can simply ignore the flicker
 | 
					 | 
				
			||||||
until a new GTK version appears, which will fix this bug, approximately
 | 
					 | 
				
			||||||
GTK 2.10.12+ versions.
 | 
					 | 
				
			||||||
 
 | 
				
			|||||||
							
								
								
									
										27
									
								
								layouts.c
									
									
									
									
									
										Normal file
									
								
							
							
						
						
									
										27
									
								
								layouts.c
									
									
									
									
									
										Normal file
									
								
							@@ -0,0 +1,27 @@
 | 
				
			|||||||
 | 
					void
 | 
				
			||||||
 | 
					grid(Monitor *m) {
 | 
				
			||||||
 | 
						unsigned int i, n, cx, cy, cw, ch, aw, ah, cols, rows;
 | 
				
			||||||
 | 
						Client *c;
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
						for(n = 0, c = nexttiled(m->clients); c; c = nexttiled(c->next))
 | 
				
			||||||
 | 
							n++;
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
						/* grid dimensions */
 | 
				
			||||||
 | 
						for(rows = 0; rows <= n/2; rows++)
 | 
				
			||||||
 | 
							if(rows*rows >= n)
 | 
				
			||||||
 | 
								break;
 | 
				
			||||||
 | 
						cols = (rows && (rows - 1) * rows >= n) ? rows - 1 : rows;
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
						/* window geoms (cell height/width) */
 | 
				
			||||||
 | 
						ch = m->wh / (rows ? rows : 1);
 | 
				
			||||||
 | 
						cw = m->ww / (cols ? cols : 1);
 | 
				
			||||||
 | 
						for(i = 0, c = nexttiled(m->clients); c; c = nexttiled(c->next)) {
 | 
				
			||||||
 | 
							cx = m->wx + (i / rows) * cw;
 | 
				
			||||||
 | 
							cy = m->wy + (i % rows) * ch;
 | 
				
			||||||
 | 
							/* adjust height/width of last row/column's windows */
 | 
				
			||||||
 | 
							ah = ((i + 1) % rows == 0) ? m->wh - ch * rows : 0;
 | 
				
			||||||
 | 
							aw = (i >= rows * (cols - 1)) ? m->ww - cw * cols : 0;
 | 
				
			||||||
 | 
							resize(c, cx, cy, cw - 2 * c->bw + aw, ch - 2 * c->bw + ah, False);
 | 
				
			||||||
 | 
							i++;
 | 
				
			||||||
 | 
						}
 | 
				
			||||||
 | 
					}
 | 
				
			||||||
							
								
								
									
										48
									
								
								movestack.c
									
									
									
									
									
										Normal file
									
								
							
							
						
						
									
										48
									
								
								movestack.c
									
									
									
									
									
										Normal file
									
								
							@@ -0,0 +1,48 @@
 | 
				
			|||||||
 | 
					void
 | 
				
			||||||
 | 
					movestack(const Arg *arg) {
 | 
				
			||||||
 | 
						Client *c = NULL, *p = NULL, *pc = NULL, *i;
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
						if(arg->i > 0) {
 | 
				
			||||||
 | 
							/* find the client after selmon->sel */
 | 
				
			||||||
 | 
							for(c = selmon->sel->next; c && (!ISVISIBLE(c) || c->isfloating); c = c->next);
 | 
				
			||||||
 | 
							if(!c)
 | 
				
			||||||
 | 
								for(c = selmon->clients; c && (!ISVISIBLE(c) || c->isfloating); c = c->next);
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
						}
 | 
				
			||||||
 | 
						else {
 | 
				
			||||||
 | 
							/* find the client before selmon->sel */
 | 
				
			||||||
 | 
							for(i = selmon->clients; i != selmon->sel; i = i->next)
 | 
				
			||||||
 | 
								if(ISVISIBLE(i) && !i->isfloating)
 | 
				
			||||||
 | 
									c = i;
 | 
				
			||||||
 | 
							if(!c)
 | 
				
			||||||
 | 
								for(; i; i = i->next)
 | 
				
			||||||
 | 
									if(ISVISIBLE(i) && !i->isfloating)
 | 
				
			||||||
 | 
										c = i;
 | 
				
			||||||
 | 
						}
 | 
				
			||||||
 | 
						/* find the client before selmon->sel and c */
 | 
				
			||||||
 | 
						for(i = selmon->clients; i && (!p || !pc); i = i->next) {
 | 
				
			||||||
 | 
							if(i->next == selmon->sel)
 | 
				
			||||||
 | 
								p = i;
 | 
				
			||||||
 | 
							if(i->next == c)
 | 
				
			||||||
 | 
								pc = i;
 | 
				
			||||||
 | 
						}
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
						/* swap c and selmon->sel selmon->clients in the selmon->clients list */
 | 
				
			||||||
 | 
						if(c && c != selmon->sel) {
 | 
				
			||||||
 | 
							Client *temp = selmon->sel->next==c?selmon->sel:selmon->sel->next;
 | 
				
			||||||
 | 
							selmon->sel->next = c->next==selmon->sel?c:c->next;
 | 
				
			||||||
 | 
							c->next = temp;
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
							if(p && p != c)
 | 
				
			||||||
 | 
								p->next = c;
 | 
				
			||||||
 | 
							if(pc && pc != selmon->sel)
 | 
				
			||||||
 | 
								pc->next = selmon->sel;
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
							if(selmon->sel == selmon->clients)
 | 
				
			||||||
 | 
								selmon->clients = c;
 | 
				
			||||||
 | 
							else if(c == selmon->clients)
 | 
				
			||||||
 | 
								selmon->clients = selmon->sel;
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
							arrange(selmon);
 | 
				
			||||||
 | 
						}
 | 
				
			||||||
 | 
					}
 | 
				
			||||||
							
								
								
									
										4
									
								
								util.c
									
									
									
									
									
								
							
							
						
						
									
										4
									
								
								util.c
									
									
									
									
									
								
							@@ -12,7 +12,7 @@ ecalloc(size_t nmemb, size_t size)
 | 
				
			|||||||
	void *p;
 | 
						void *p;
 | 
				
			||||||
 | 
					
 | 
				
			||||||
	if (!(p = calloc(nmemb, size)))
 | 
						if (!(p = calloc(nmemb, size)))
 | 
				
			||||||
		perror(NULL);
 | 
							die("calloc:");
 | 
				
			||||||
	return p;
 | 
						return p;
 | 
				
			||||||
}
 | 
					}
 | 
				
			||||||
 | 
					
 | 
				
			||||||
@@ -27,6 +27,8 @@ die(const char *fmt, ...) {
 | 
				
			|||||||
	if (fmt[0] && fmt[strlen(fmt)-1] == ':') {
 | 
						if (fmt[0] && fmt[strlen(fmt)-1] == ':') {
 | 
				
			||||||
		fputc(' ', stderr);
 | 
							fputc(' ', stderr);
 | 
				
			||||||
		perror(NULL);
 | 
							perror(NULL);
 | 
				
			||||||
 | 
						} else {
 | 
				
			||||||
 | 
							fputc('\n', stderr);
 | 
				
			||||||
	}
 | 
						}
 | 
				
			||||||
 | 
					
 | 
				
			||||||
	exit(1);
 | 
						exit(1);
 | 
				
			||||||
 
 | 
				
			|||||||
							
								
								
									
										4
									
								
								util.h
									
									
									
									
									
								
							
							
						
						
									
										4
									
								
								util.h
									
									
									
									
									
								
							@@ -4,5 +4,5 @@
 | 
				
			|||||||
#define MIN(A, B)               ((A) < (B) ? (A) : (B))
 | 
					#define MIN(A, B)               ((A) < (B) ? (A) : (B))
 | 
				
			||||||
#define BETWEEN(X, A, B)        ((A) <= (X) && (X) <= (B))
 | 
					#define BETWEEN(X, A, B)        ((A) <= (X) && (X) <= (B))
 | 
				
			||||||
 | 
					
 | 
				
			||||||
void die(const char *errstr, ...);
 | 
					void die(const char *fmt, ...);
 | 
				
			||||||
void *ecalloc(size_t, size_t);
 | 
					void *ecalloc(size_t nmemb, size_t size);
 | 
				
			||||||
 
 | 
				
			|||||||
		Reference in New Issue
	
	Block a user