integrated yiyus mouse.diff (though the bar click handling is slightly broken, I'm to tired to debug it now, yiyus could you please?)
This commit is contained in:
		
							parent
							
								
									e3838e8585
								
							
						
					
					
						commit
						5cd65f8cd8
					
				
							
								
								
									
										60
									
								
								config.def.h
									
									
									
									
									
								
							
							
						
						
									
										60
									
								
								config.def.h
									
									
									
									
									
								
							| @ -39,10 +39,10 @@ static Layout layouts[] = { | |||||||
| /* key definitions */ | /* key definitions */ | ||||||
| #define MODKEY Mod1Mask | #define MODKEY Mod1Mask | ||||||
| #define TAGKEYS(KEY,TAG) \ | #define TAGKEYS(KEY,TAG) \ | ||||||
|         { MODKEY,                       KEY,      view,           TAG }, \ | 	{ MODKEY,                       KEY,      view,           {.ui = 1 << TAG} }, \ | ||||||
|         { MODKEY|ControlMask,           KEY,      toggleview,     TAG }, \ | 	{ MODKEY|ControlMask,           KEY,      toggleview,     {.ui = 1 << TAG} }, \ | ||||||
|         { MODKEY|ShiftMask,             KEY,      tag,            TAG }, \ | 	{ MODKEY|ShiftMask,             KEY,      tag,            {.ui = 1 << TAG} }, \ | ||||||
|         { MODKEY|ControlMask|ShiftMask, KEY,      toggletag,      TAG }, | 	{ MODKEY|ControlMask|ShiftMask, KEY,      toggletag,      {.ui = 1 << TAG} }, | ||||||
| 
 | 
 | ||||||
| /* helper for spawning shell commands */ | /* helper for spawning shell commands */ | ||||||
| #define SHCMD(cmd) { .v = (char*[]){ "/bin/sh", "-c", cmd, NULL } } | #define SHCMD(cmd) { .v = (char*[]){ "/bin/sh", "-c", cmd, NULL } } | ||||||
| @ -64,14 +64,48 @@ static Key keys[] = { | |||||||
| 	{ MODKEY|ShiftMask,             XK_space,  togglefloating, {0} }, | 	{ MODKEY|ShiftMask,             XK_space,  togglefloating, {0} }, | ||||||
| 	{ MODKEY,                       XK_0,      view,           {.ui = ~0 } }, | 	{ MODKEY,                       XK_0,      view,           {.ui = ~0 } }, | ||||||
| 	{ MODKEY|ShiftMask,             XK_0,      tag,            {.ui = ~0 } }, | 	{ MODKEY|ShiftMask,             XK_0,      tag,            {.ui = ~0 } }, | ||||||
| 	TAGKEYS(                        XK_1,                      {.ui = 1 << 0} ) | 	TAGKEYS(                        XK_1,                      0) | ||||||
| 	TAGKEYS(                        XK_2,                      {.ui = 1 << 1} ) | 	TAGKEYS(                        XK_2,                      1) | ||||||
| 	TAGKEYS(                        XK_3,                      {.ui = 1 << 2} ) | 	TAGKEYS(                        XK_3,                      2) | ||||||
| 	TAGKEYS(                        XK_4,                      {.ui = 1 << 3} ) | 	TAGKEYS(                        XK_4,                      3) | ||||||
| 	TAGKEYS(                        XK_5,                      {.ui = 1 << 4} ) | 	TAGKEYS(                        XK_5,                      4) | ||||||
| 	TAGKEYS(                        XK_6,                      {.ui = 1 << 5} ) | 	TAGKEYS(                        XK_6,                      5) | ||||||
| 	TAGKEYS(                        XK_7,                      {.ui = 1 << 6} ) | 	TAGKEYS(                        XK_7,                      6) | ||||||
| 	TAGKEYS(                        XK_8,                      {.ui = 1 << 7} ) | 	TAGKEYS(                        XK_8,                      7) | ||||||
| 	TAGKEYS(                        XK_9,                      {.ui = 1 << 8} ) | 	TAGKEYS(                        XK_9,                      8) | ||||||
| 	{ MODKEY|ShiftMask,             XK_q,      quit,           {0} }, | 	{ MODKEY|ShiftMask,             XK_q,      quit,           {0} }, | ||||||
| }; | }; | ||||||
|  | 
 | ||||||
|  | /* button definitions */ | ||||||
|  | #define TAGBUTTONS(TAG) \ | ||||||
|  | 	{ TAG,                  0,              Button1,        view,           {.ui = 1 << TAG} }, \ | ||||||
|  | 	{ TAG,                  0,              Button3,        toggleview,     {.ui = 1 << TAG} }, \ | ||||||
|  | 	{ TAG,                  MODKEY,         Button1,        tag,            {.ui = 1 << TAG} }, \ | ||||||
|  | 	{ TAG,                  MODKEY,         Button3,        toggletag,      {.ui = 1 << TAG} }, | ||||||
|  | 
 | ||||||
|  | /* click can be a tag number (starting at 0),
 | ||||||
|  |  * ClkLtSymbol, ClkStatusText, ClkWinTitle, ClkClientWin, or ClkRootWin */ | ||||||
|  | static Button buttons[] = { | ||||||
|  | 	/* click                event mask      button          function        argument */ | ||||||
|  | 	{ ClkLtSymbol,          0,              Button1,        togglelayout,   {0} }, | ||||||
|  | 	{ ClkLtSymbol,          0,              Button3,        togglemax,      {0} }, | ||||||
|  | 	{ ClkWinTitle,          0,              Button1,        movemouse,      {0} }, | ||||||
|  | 	{ ClkWinTitle,          0,              Button2,        zoom,           {0} }, | ||||||
|  | 	{ ClkWinTitle,          0,              Button3,        resizemouse,    {0} }, | ||||||
|  | 	{ ClkWinTitle,          0,              Button4,        focusstack,     {.i = +1 } }, | ||||||
|  | 	{ ClkWinTitle,          0,              Button5,        focusstack,     {.i = -1 } }, | ||||||
|  | 	{ ClkClientWin,         MODKEY,         Button1,        movemouse,      {0} }, | ||||||
|  | 	{ ClkClientWin,         MODKEY,         Button2,        togglefloating, {0} }, | ||||||
|  | 	{ ClkClientWin,         MODKEY,         Button3,        resizemouse,    {0} }, | ||||||
|  | 	{ ClkRootWin,           Button1Mask,    Button3,        spawn,          {.v = (char *[]){"uxterm", NULL}} }, | ||||||
|  | 	TAGBUTTONS(0) | ||||||
|  | 	TAGBUTTONS(1) | ||||||
|  | 	TAGBUTTONS(2) | ||||||
|  | 	TAGBUTTONS(3) | ||||||
|  | 	TAGBUTTONS(4) | ||||||
|  | 	TAGBUTTONS(5) | ||||||
|  | 	TAGBUTTONS(6) | ||||||
|  | 	TAGBUTTONS(7) | ||||||
|  | 	TAGBUTTONS(8) | ||||||
|  | }; | ||||||
|  | 
 | ||||||
|  | |||||||
							
								
								
									
										99
									
								
								dwm.c
									
									
									
									
									
								
							
							
						
						
									
										99
									
								
								dwm.c
									
									
									
									
									
								
							| @ -59,10 +59,28 @@ enum { CurNormal, CurResize, CurMove, CurLast };        /* cursor */ | |||||||
| enum { ColBorder, ColFG, ColBG, ColLast };              /* color */ | enum { ColBorder, ColFG, ColBG, ColLast };              /* color */ | ||||||
| enum { NetSupported, NetWMName, NetLast };              /* EWMH atoms */ | enum { NetSupported, NetWMName, NetLast };              /* EWMH atoms */ | ||||||
| enum { WMProtocols, WMDelete, WMName, WMState, WMLast };/* default atoms */ | enum { WMProtocols, WMDelete, WMName, WMState, WMLast };/* default atoms */ | ||||||
|  | enum { ClkLtSymbol = -1, ClkStatusText = -2, ClkWinTitle = -3, | ||||||
|  |        ClkClientWin = -4, ClkRootWin = -5, ClkLast = -6};/* clicks */ | ||||||
| 
 | 
 | ||||||
| /* typedefs */ | /* typedefs */ | ||||||
| typedef unsigned int uint; | typedef unsigned int uint; | ||||||
| typedef unsigned long ulong; | typedef unsigned long ulong; | ||||||
|  | 
 | ||||||
|  | typedef union { | ||||||
|  | 	int i; | ||||||
|  | 	uint ui; | ||||||
|  | 	float f; | ||||||
|  | 	void *v; | ||||||
|  | } Arg; | ||||||
|  | 
 | ||||||
|  | typedef struct { | ||||||
|  | 	uint click; | ||||||
|  | 	uint mask; | ||||||
|  | 	uint button; | ||||||
|  | 	void (*func)(const Arg *arg); | ||||||
|  | 	const Arg arg; | ||||||
|  | } Button; | ||||||
|  | 
 | ||||||
| typedef struct Client Client; | typedef struct Client Client; | ||||||
| struct Client { | struct Client { | ||||||
| 	char name[256]; | 	char name[256]; | ||||||
| @ -92,13 +110,6 @@ typedef struct { | |||||||
| 	} font; | 	} font; | ||||||
| } DC; /* draw context */ | } DC; /* draw context */ | ||||||
| 
 | 
 | ||||||
| typedef union { |  | ||||||
| 	int i; |  | ||||||
| 	uint ui; |  | ||||||
| 	float f; |  | ||||||
| 	void *v; |  | ||||||
| } Arg; |  | ||||||
| 
 |  | ||||||
| typedef struct { | typedef struct { | ||||||
| 	uint mod; | 	uint mod; | ||||||
| 	KeySym keysym; | 	KeySym keysym; | ||||||
| @ -157,12 +168,12 @@ static void killclient(const Arg *arg); | |||||||
| static void manage(Window w, XWindowAttributes *wa); | static void manage(Window w, XWindowAttributes *wa); | ||||||
| static void mappingnotify(XEvent *e); | static void mappingnotify(XEvent *e); | ||||||
| static void maprequest(XEvent *e); | static void maprequest(XEvent *e); | ||||||
| static void movemouse(Client *c); | static void movemouse(const Arg *arg); | ||||||
| static Client *nexttiled(Client *c); | static Client *nexttiled(Client *c); | ||||||
| static void propertynotify(XEvent *e); | static void propertynotify(XEvent *e); | ||||||
| static void quit(const Arg *arg); | static void quit(const Arg *arg); | ||||||
| static void resize(Client *c, int x, int y, int w, int h, Bool sizehints); | static void resize(Client *c, int x, int y, int w, int h, Bool sizehints); | ||||||
| static void resizemouse(Client *c); | static void resizemouse(const Arg *arg); | ||||||
| static void restack(void); | static void restack(void); | ||||||
| static void run(void); | static void run(void); | ||||||
| static void scan(void); | static void scan(void); | ||||||
| @ -297,50 +308,31 @@ attachstack(Client *c) { | |||||||
| 
 | 
 | ||||||
| void | void | ||||||
| buttonpress(XEvent *e) { | buttonpress(XEvent *e) { | ||||||
| 	uint i, mask; | 	uint i, x, click; | ||||||
| 	int x; |  | ||||||
| 	Client *c; | 	Client *c; | ||||||
| 	XButtonPressedEvent *ev = &e->xbutton; | 	XButtonPressedEvent *ev = &e->xbutton; | ||||||
| 
 | 
 | ||||||
|  | 	click = ClkRootWin; | ||||||
| 	if(ev->window == barwin) { | 	if(ev->window == barwin) { | ||||||
| 		x = 0; | 		x = 0; | ||||||
| 		for(i = 0; i < LENGTH(tags); i++) { | 		for(i = 0; i < LENGTH(tags) && ev->x >= x; i++) { | ||||||
| 			x += TEXTW(tags[i]); | 			x += TEXTW(tags[i]); | ||||||
| 			if(ev->x < x) { | 			if(i < LENGTH(tags) || ev->x <= x) | ||||||
| 				mask = 1 << i; | 				click = i - 1; | ||||||
| 				if(ev->button == Button1) { | 			else if(ev->x < x + blw) | ||||||
| 					if(ev->state & MODKEY) | 				click = ClkLtSymbol; | ||||||
| 						tag((Arg*)&mask); | 			else if(ev->x > wx + ww - TEXTW(stext)) | ||||||
|  | 				click = ClkStatusText; | ||||||
| 			else | 			else | ||||||
| 						view((Arg*)&mask); | 				click = ClkWinTitle; | ||||||
| 				} |  | ||||||
| 				else if(ev->button == Button3) { |  | ||||||
| 					if(ev->state & MODKEY) |  | ||||||
| 						toggletag((Arg*)&mask); |  | ||||||
| 					else |  | ||||||
| 						toggleview((Arg*)&mask); |  | ||||||
| 				} |  | ||||||
| 				return; |  | ||||||
| 		} | 		} | ||||||
| 	} | 	} | ||||||
| 		if(ev->x < x + blw) { | 	else if((c = getclient(ev->window))) | ||||||
| 			if(ev->button == Button1) | 		click = ClkClientWin; | ||||||
| 				togglelayout(NULL); | 
 | ||||||
| 			else if(ev->button == Button3) | 	for(i = 0; i < LENGTH(buttons); i++) | ||||||
| 				togglemax(NULL); | 		if(click == buttons[i].click && buttons[i].func && buttons[i].button == ev->button && CLEANMASK(buttons[i].mask) == CLEANMASK(ev->state)) | ||||||
| 		} | 			buttons[i].func(&buttons[i].arg); | ||||||
| 	} |  | ||||||
| 	else if((c = getclient(ev->window))) { |  | ||||||
| 		focus(c); |  | ||||||
| 		if(CLEANMASK(ev->state) != MODKEY || (ismax && !c->isfixed)) |  | ||||||
| 			return; |  | ||||||
| 		if(ev->button == Button1) |  | ||||||
| 			movemouse(c); |  | ||||||
| 		else if(ev->button == Button2) |  | ||||||
| 			togglefloating(NULL); |  | ||||||
| 		else if(ev->button == Button3 && !c->isfixed) |  | ||||||
| 			resizemouse(c); |  | ||||||
| 	} |  | ||||||
| } | } | ||||||
| 
 | 
 | ||||||
| void | void | ||||||
| @ -971,12 +963,15 @@ maprequest(XEvent *e) { | |||||||
| } | } | ||||||
| 
 | 
 | ||||||
| void | void | ||||||
| movemouse(Client *c) { | movemouse(const Arg *arg) { | ||||||
| 	int x1, y1, ocx, ocy, di, nx, ny; | 	int x1, y1, ocx, ocy, di, nx, ny; | ||||||
| 	uint dui; | 	uint dui; | ||||||
|  | 	Client *c; | ||||||
| 	Window dummy; | 	Window dummy; | ||||||
| 	XEvent ev; | 	XEvent ev; | ||||||
| 
 | 
 | ||||||
|  | 	if(!(c = sel)) | ||||||
|  | 		return; | ||||||
| 	restack(); | 	restack(); | ||||||
| 	ocx = nx = c->x; | 	ocx = nx = c->x; | ||||||
| 	ocy = ny = c->y; | 	ocy = ny = c->y; | ||||||
| @ -984,6 +979,11 @@ movemouse(Client *c) { | |||||||
| 	None, cursor[CurMove], CurrentTime) != GrabSuccess) | 	None, cursor[CurMove], CurrentTime) != GrabSuccess) | ||||||
| 		return; | 		return; | ||||||
| 	XQueryPointer(dpy, root, &dummy, &dummy, &x1, &y1, &di, &di, &dui); | 	XQueryPointer(dpy, root, &dummy, &dummy, &x1, &y1, &di, &di, &dui); | ||||||
|  | 	if(x1 < c->x || x1 > c->x + c->w || y1 < c->y || y1 > c->y + c->h) { | ||||||
|  | 		XWarpPointer(dpy, None, c->win, 0, 0, 0, 0, 0, 0); | ||||||
|  | 		x1 = c->x + 1; | ||||||
|  | 		y1 = c->y + 1; | ||||||
|  | 	} | ||||||
| 	for(;;) { | 	for(;;) { | ||||||
| 		XMaskEvent(dpy, MOUSEMASK|ExposureMask|SubstructureRedirectMask, &ev); | 		XMaskEvent(dpy, MOUSEMASK|ExposureMask|SubstructureRedirectMask, &ev); | ||||||
| 		switch (ev.type) { | 		switch (ev.type) { | ||||||
| @ -1131,11 +1131,14 @@ resize(Client *c, int x, int y, int w, int h, Bool sizehints) { | |||||||
| } | } | ||||||
| 
 | 
 | ||||||
| void | void | ||||||
| resizemouse(Client *c) { | resizemouse(const Arg *arg) { | ||||||
| 	int ocx, ocy; | 	int ocx, ocy; | ||||||
| 	int nw, nh; | 	int nw, nh; | ||||||
|  | 	Client *c; | ||||||
| 	XEvent ev; | 	XEvent ev; | ||||||
| 
 | 
 | ||||||
|  | 	if(!(c = sel)) | ||||||
|  | 		return; | ||||||
| 	restack(); | 	restack(); | ||||||
| 	ocx = c->x; | 	ocx = c->x; | ||||||
| 	ocy = c->y; | 	ocy = c->y; | ||||||
| @ -1377,7 +1380,7 @@ setup(void) { | |||||||
| 			PropModeReplace, (unsigned char *) netatom, NetLast); | 			PropModeReplace, (unsigned char *) netatom, NetLast); | ||||||
| 
 | 
 | ||||||
| 	/* select for events */ | 	/* select for events */ | ||||||
| 	wa.event_mask = SubstructureRedirectMask|SubstructureNotifyMask | 	wa.event_mask = SubstructureRedirectMask|SubstructureNotifyMask|ButtonPressMask | ||||||
| 			|EnterWindowMask|LeaveWindowMask|StructureNotifyMask; | 			|EnterWindowMask|LeaveWindowMask|StructureNotifyMask; | ||||||
| 	XChangeWindowAttributes(dpy, root, CWEventMask|CWCursor, &wa); | 	XChangeWindowAttributes(dpy, root, CWEventMask|CWCursor, &wa); | ||||||
| 	XSelectInput(dpy, root, wa.event_mask); | 	XSelectInput(dpy, root, wa.event_mask); | ||||||
| @ -1643,7 +1646,7 @@ updatewmhints(Client *c) { | |||||||
| void | void | ||||||
| view(const Arg *arg) { | view(const Arg *arg) { | ||||||
| 	seltags ^= 1; /* toggle sel tagset */ | 	seltags ^= 1; /* toggle sel tagset */ | ||||||
| 	if(arg && (arg->ui & TAGMASK)) | 	if(arg && (arg->ui & TAGMASK) && (arg->ui & TAGMASK) != tagset[seltags ^ 1]) | ||||||
| 		tagset[seltags] = arg->i & TAGMASK; | 		tagset[seltags] = arg->i & TAGMASK; | ||||||
| 	arrange(); | 	arrange(); | ||||||
| } | } | ||||||
|  | |||||||
		Loading…
	
	
			
			x
			
			
		
	
		Reference in New Issue
	
	Block a user
	 Anselm R Garbe
						Anselm R Garbe