diff options
| -rw-r--r-- | config.def.h | 3 | ||||
| -rw-r--r-- | config.mk | 2 | ||||
| -rw-r--r-- | dwm.c | 46 | 
3 files changed, 31 insertions, 20 deletions
| diff --git a/config.def.h b/config.def.h index 061ad66..9efa774 100644 --- a/config.def.h +++ b/config.def.h @@ -56,7 +56,8 @@ static const Layout layouts[] = {  #define SHCMD(cmd) { .v = (const char*[]){ "/bin/sh", "-c", cmd, NULL } }  /* commands */ -static const char *dmenucmd[] = { "dmenu_run", "-fn", dmenufont, "-nb", col_gray1, "-nf", col_gray3, "-sb", col_cyan, "-sf", col_gray4, NULL }; +static char dmenumon[2] = "0"; /* component of dmenucmd, manipulated in spawn() */ +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 Key keys[] = { @@ -1,5 +1,5 @@  # dwm version -VERSION = 6.3 +VERSION = 6.4  # Customize below to fit your system @@ -206,7 +206,6 @@ static void setmfact(const Arg *arg);  static void setup(void);  static void seturgent(Client *c, int urg);  static void showhide(Client *c); -static void sigchld(int unused);  static void spawn(const Arg *arg);  static void tag(const Arg *arg);  static void tagmon(const Arg *arg); @@ -956,16 +955,26 @@ grabkeys(void)  {  	updatenumlockmask();  	{ -		unsigned int i, j; +		unsigned int i, j, k;  		unsigned int modifiers[] = { 0, LockMask, numlockmask, numlockmask|LockMask }; -		KeyCode code; +		int start, end, skip; +		KeySym *syms;  		XUngrabKey(dpy, AnyKey, AnyModifier, root); -		for (i = 0; i < LENGTH(keys); i++) -			if ((code = XKeysymToKeycode(dpy, keys[i].keysym))) -				for (j = 0; j < LENGTH(modifiers); j++) -					XGrabKey(dpy, code, keys[i].mod | modifiers[j], root, -						True, GrabModeAsync, GrabModeAsync); +		XDisplayKeycodes(dpy, &start, &end); +		syms = XGetKeyboardMapping(dpy, start, end - start + 1, &skip); +		if (!syms) +			return; +		for (k = start; k <= end; k++) +			for (i = 0; i < LENGTH(keys); i++) +				/* skip modifier codes, we do that ourselves */ +				if (keys[i].keysym == syms[(k - start) * skip]) +					for (j = 0; j < LENGTH(modifiers); j++) +						XGrabKey(dpy, k, +							 keys[i].mod | modifiers[j], +							 root, True, +							 GrabModeAsync, GrabModeAsync); +		XFree(syms);  	}  } @@ -1534,9 +1543,16 @@ setup(void)  	int i;  	XSetWindowAttributes wa;  	Atom utf8string; +	struct sigaction sa; -	/* clean up any zombies immediately */ -	sigchld(0); +	/* do not transform children into zombies when they terminate */ +	sigemptyset(&sa.sa_mask); +	sa.sa_flags = SA_NOCLDSTOP | SA_NOCLDWAIT | SA_RESTART; +	sa.sa_handler = SIG_IGN; +	sigaction(SIGCHLD, &sa, NULL); + +	/* clean up any zombies (inherited from .xinitrc etc) immediately */ +	while (waitpid(-1, NULL, WNOHANG) > 0);  	/* init screen */  	screen = DefaultScreen(dpy); @@ -1630,16 +1646,10 @@ showhide(Client *c)  }  void -sigchld(int unused) -{ -	if (signal(SIGCHLD, sigchld) == SIG_ERR) -		die("can't install SIGCHLD handler:"); -	while (0 < waitpid(-1, NULL, WNOHANG)); -} - -void  spawn(const Arg *arg)  { +	if (arg->v == dmenucmd) +		dmenumon[0] = '0' + selmon->num;  	if (fork() == 0) {  		if (dpy)  			close(ConnectionNumber(dpy)); | 
