Compare commits
	
		
			1 Commits
		
	
	
		
			df372959b0
			...
			master
		
	
	| Author | SHA1 | Date | |
|---|---|---|---|
|   | 196da2f243 | 
| @@ -1,3 +1,4 @@ | |||||||
| dwm-swallow-6.3.diff | dwm-swallow-6.3.diff | ||||||
| dwm-hide_vacant_tags-6.4.diff | dwm-hide_vacant_tags-6.4.diff | ||||||
| dwm-pertag-20200914-61bb8b2.diff | dwm-pertag-20200914-61bb8b2.diff | ||||||
|  | dwm-statuscmd-20241009-8933ebc.diff | ||||||
|   | |||||||
							
								
								
									
										0
									
								
								.pc/dwm-statuscmd-20241009-8933ebc.diff/.timestamp
									
									
									
									
									
										Normal file
									
								
							
							
						
						
									
										0
									
								
								.pc/dwm-statuscmd-20241009-8933ebc.diff/.timestamp
									
									
									
									
									
										Normal file
									
								
							
							
								
								
									
										120
									
								
								.pc/dwm-statuscmd-20241009-8933ebc.diff/config.def.h
									
									
									
									
									
										Normal file
									
								
							
							
						
						
									
										120
									
								
								.pc/dwm-statuscmd-20241009-8933ebc.diff/config.def.h
									
									
									
									
									
										Normal file
									
								
							| @@ -0,0 +1,120 @@ | |||||||
|  | /* See LICENSE file for copyright and license details. */ | ||||||
|  |  | ||||||
|  | /* appearance */ | ||||||
|  | static const unsigned int borderpx  = 1;        /* border pixel of windows */ | ||||||
|  | static const unsigned int snap      = 32;       /* snap pixel */ | ||||||
|  | static const int swallowfloating    = 0;        /* 1 means swallow floating windows by default */ | ||||||
|  | static const int showbar            = 1;        /* 0 means no 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 */ | ||||||
|  | static const char *tags[] = { "1", "2", "3", "4", "5", "6", "7", "8", "9" }; | ||||||
|  |  | ||||||
|  | static const Rule rules[] = { | ||||||
|  | 	/* xprop(1): | ||||||
|  | 	 *	WM_CLASS(STRING) = instance, class | ||||||
|  | 	 *	WM_NAME(STRING) = title | ||||||
|  | 	 */ | ||||||
|  | 	/* class     instance  title           tags mask  isfloating  isterminal  noswallow  monitor */ | ||||||
|  | 	{ "Gimp",    NULL,     NULL,           0,         1,          0,           0,        -1 }, | ||||||
|  | 	{ "Firefox", NULL,     NULL,           1 << 8,    0,          0,          -1,        -1 }, | ||||||
|  | 	{ "St",      NULL,     NULL,           0,         0,          1,           0,        -1 }, | ||||||
|  | 	{ NULL,      NULL,     "Event Tester", 0,         0,          0,           1,        -1 }, /* xev */ | ||||||
|  | }; | ||||||
|  |  | ||||||
|  | /* 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 */ | ||||||
|  | static const int lockfullscreen = 1; /* 1 will force focus on the fullscreen window */ | ||||||
|  | static const int refreshrate = 120;  /* refresh rate (per second) for client move/resize */ | ||||||
|  |  | ||||||
|  | static const Layout layouts[] = { | ||||||
|  | 	/* symbol     arrange function */ | ||||||
|  | 	{ "[]=",      tile },    /* first entry is default */ | ||||||
|  | 	{ "><>",      NULL },    /* no layout function means floating behavior */ | ||||||
|  | 	{ "[M]",      monocle }, | ||||||
|  | }; | ||||||
|  |  | ||||||
|  | /* key definitions */ | ||||||
|  | #define MODKEY Mod1Mask | ||||||
|  | #define TAGKEYS(KEY,TAG) \ | ||||||
|  | 	{ MODKEY,                       KEY,      view,           {.ui = 1 << TAG} }, \ | ||||||
|  | 	{ MODKEY|ControlMask,           KEY,      toggleview,     {.ui = 1 << TAG} }, \ | ||||||
|  | 	{ MODKEY|ShiftMask,             KEY,      tag,            {.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 } } | ||||||
|  |  | ||||||
|  | /* commands */ | ||||||
|  | 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[] = { | ||||||
|  | 	/* modifier                     key        function        argument */ | ||||||
|  | 	{ MODKEY,                       XK_p,      spawn,          {.v = dmenucmd } }, | ||||||
|  | 	{ 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,                       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_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 } }, | ||||||
|  | 	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} }, | ||||||
|  | }; | ||||||
|  |  | ||||||
|  | /* button definitions */ | ||||||
|  | /* click can be ClkTagBar, ClkLtSymbol, ClkStatusText, ClkWinTitle, ClkClientWin, or ClkRootWin */ | ||||||
|  | static const 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} }, | ||||||
|  | }; | ||||||
|  |  | ||||||
							
								
								
									
										2468
									
								
								.pc/dwm-statuscmd-20241009-8933ebc.diff/dwm.c
									
									
									
									
									
										Normal file
									
								
							
							
						
						
									
										2468
									
								
								.pc/dwm-statuscmd-20241009-8933ebc.diff/dwm.c
									
									
									
									
									
										Normal file
									
								
							
										
											
												File diff suppressed because it is too large
												Load Diff
											
										
									
								
							| @@ -5,6 +5,7 @@ | |||||||
| * [Swallow](https://dwm.suckless.org/patches/swallow/) *Note: I had to change "St" in my config.h to "st" for this to work with st* | * [Swallow](https://dwm.suckless.org/patches/swallow/) *Note: I had to change "St" in my config.h to "st" for this to work with st* | ||||||
| * [Hide Vacant Tags](https://dwm.suckless.org/patches/hide_vacant_tags/) | * [Hide Vacant Tags](https://dwm.suckless.org/patches/hide_vacant_tags/) | ||||||
| * [Pertag](https://dwm.suckless.org/patches/pertag/) | * [Pertag](https://dwm.suckless.org/patches/pertag/) | ||||||
|  | * [statuscmd](https://dwm.suckless.org/patches/statuscmd/) *Note: intended to be used with [dwmblocks](https://git.mjwilson.org/mike/dwmblocks-async)* | ||||||
|  |  | ||||||
| ### Patch Management | ### Patch Management | ||||||
|  |  | ||||||
|   | |||||||
| @@ -59,6 +59,8 @@ static const Layout layouts[] = { | |||||||
| /* helper for spawning shell commands in the pre dwm-5.0 fashion */ | /* helper for spawning shell commands in the pre dwm-5.0 fashion */ | ||||||
| #define SHCMD(cmd) { .v = (const char*[]){ "/bin/sh", "-c", cmd, NULL } } | #define SHCMD(cmd) { .v = (const char*[]){ "/bin/sh", "-c", cmd, NULL } } | ||||||
|  |  | ||||||
|  | #define STATUSBAR "dwmblocks" | ||||||
|  |  | ||||||
| /* 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", col_gray1, "-nf", col_gray3, "-sb", col_cyan, "-sf", col_gray4, NULL }; | static const char *dmenucmd[] = { "dmenu_run", "-m", dmenumon, "-fn", dmenufont, "-nb", col_gray1, "-nf", col_gray3, "-sb", col_cyan, "-sf", col_gray4, NULL }; | ||||||
| @@ -108,7 +110,9 @@ static const Button buttons[] = { | |||||||
| 	{ ClkLtSymbol,          0,              Button1,        setlayout,      {0} }, | 	{ ClkLtSymbol,          0,              Button1,        setlayout,      {0} }, | ||||||
| 	{ ClkLtSymbol,          0,              Button3,        setlayout,      {.v = &layouts[2]} }, | 	{ ClkLtSymbol,          0,              Button3,        setlayout,      {.v = &layouts[2]} }, | ||||||
| 	{ ClkWinTitle,          0,              Button2,        zoom,           {0} }, | 	{ ClkWinTitle,          0,              Button2,        zoom,           {0} }, | ||||||
| 	{ ClkStatusText,        0,              Button2,        spawn,          {.v = termcmd } }, | 	{ ClkStatusText,        0,              Button1,        sigstatusbar,   {.i = 1} }, | ||||||
|  | 	{ ClkStatusText,        0,              Button2,        sigstatusbar,   {.i = 2} }, | ||||||
|  | 	{ ClkStatusText,        0,              Button3,        sigstatusbar,   {.i = 3} }, | ||||||
| 	{ ClkClientWin,         MODKEY,         Button1,        movemouse,      {0} }, | 	{ ClkClientWin,         MODKEY,         Button1,        movemouse,      {0} }, | ||||||
| 	{ ClkClientWin,         MODKEY,         Button2,        togglefloating, {0} }, | 	{ ClkClientWin,         MODKEY,         Button2,        togglefloating, {0} }, | ||||||
| 	{ ClkClientWin,         MODKEY,         Button3,        resizemouse,    {0} }, | 	{ ClkClientWin,         MODKEY,         Button3,        resizemouse,    {0} }, | ||||||
|   | |||||||
							
								
								
									
										6
									
								
								config.h
									
									
									
									
									
								
							
							
						
						
									
										6
									
								
								config.h
									
									
									
									
									
								
							| @@ -59,6 +59,8 @@ static const Layout layouts[] = { | |||||||
| /* helper for spawning shell commands in the pre dwm-5.0 fashion */ | /* helper for spawning shell commands in the pre dwm-5.0 fashion */ | ||||||
| #define SHCMD(cmd) { .v = (const char*[]){ "/bin/sh", "-c", cmd, NULL } } | #define SHCMD(cmd) { .v = (const char*[]){ "/bin/sh", "-c", cmd, NULL } } | ||||||
|  |  | ||||||
|  | #define STATUSBAR "dwmblocks" | ||||||
|  |  | ||||||
| /* 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", col_gray1, "-nf", col_gray3, "-sb", col_cyan, "-sf", col_gray4, NULL }; | static const char *dmenucmd[] = { "dmenu_run", "-m", dmenumon, "-fn", dmenufont, "-nb", col_gray1, "-nf", col_gray3, "-sb", col_cyan, "-sf", col_gray4, NULL }; | ||||||
| @@ -108,7 +110,9 @@ static const Button buttons[] = { | |||||||
| 	{ ClkLtSymbol,          0,              Button1,        setlayout,      {0} }, | 	{ ClkLtSymbol,          0,              Button1,        setlayout,      {0} }, | ||||||
| 	{ ClkLtSymbol,          0,              Button3,        setlayout,      {.v = &layouts[2]} }, | 	{ ClkLtSymbol,          0,              Button3,        setlayout,      {.v = &layouts[2]} }, | ||||||
| 	{ ClkWinTitle,          0,              Button2,        zoom,           {0} }, | 	{ ClkWinTitle,          0,              Button2,        zoom,           {0} }, | ||||||
| 	{ ClkStatusText,        0,              Button2,        spawn,          {.v = termcmd } }, | 	{ ClkStatusText,        0,              Button1,        sigstatusbar,   {.i = 1} }, | ||||||
|  | 	{ ClkStatusText,        0,              Button2,        sigstatusbar,   {.i = 2} }, | ||||||
|  | 	{ ClkStatusText,        0,              Button3,        sigstatusbar,   {.i = 3} }, | ||||||
| 	{ ClkClientWin,         MODKEY,         Button1,        movemouse,      {0} }, | 	{ ClkClientWin,         MODKEY,         Button1,        movemouse,      {0} }, | ||||||
| 	{ ClkClientWin,         MODKEY,         Button2,        togglefloating, {0} }, | 	{ ClkClientWin,         MODKEY,         Button2,        togglefloating, {0} }, | ||||||
| 	{ ClkClientWin,         MODKEY,         Button3,        resizemouse,    {0} }, | 	{ ClkClientWin,         MODKEY,         Button3,        resizemouse,    {0} }, | ||||||
|   | |||||||
							
								
								
									
										104
									
								
								dwm.c
									
									
									
									
									
								
							
							
						
						
									
										104
									
								
								dwm.c
									
									
									
									
									
								
							| @@ -183,6 +183,7 @@ static void focusstack(const Arg *arg); | |||||||
| static Atom getatomprop(Client *c, Atom prop); | static Atom getatomprop(Client *c, Atom prop); | ||||||
| static int getrootptr(int *x, int *y); | static int getrootptr(int *x, int *y); | ||||||
| static long getstate(Window w); | static long getstate(Window w); | ||||||
|  | static pid_t getstatusbarpid(); | ||||||
| static int gettextprop(Window w, Atom atom, char *text, unsigned int size); | static int gettextprop(Window w, Atom atom, char *text, unsigned int size); | ||||||
| static void grabbuttons(Client *c, int focused); | static void grabbuttons(Client *c, int focused); | ||||||
| static void grabkeys(void); | static void grabkeys(void); | ||||||
| @@ -216,6 +217,7 @@ static void setmfact(const Arg *arg); | |||||||
| static void setup(void); | static void setup(void); | ||||||
| static void seturgent(Client *c, int urg); | static void seturgent(Client *c, int urg); | ||||||
| static void showhide(Client *c); | static void showhide(Client *c); | ||||||
|  | static void sigstatusbar(const Arg *arg); | ||||||
| static void spawn(const Arg *arg); | static void spawn(const Arg *arg); | ||||||
| static void tag(const Arg *arg); | static void tag(const Arg *arg); | ||||||
| static void tagmon(const Arg *arg); | static void tagmon(const Arg *arg); | ||||||
| @@ -254,6 +256,9 @@ static pid_t winpid(Window w); | |||||||
| /* variables */ | /* variables */ | ||||||
| static const char broken[] = "broken"; | static const char broken[] = "broken"; | ||||||
| static char stext[256]; | static char stext[256]; | ||||||
|  | static int statusw; | ||||||
|  | static int statussig; | ||||||
|  | static pid_t statuspid = -1; | ||||||
| static int screen; | static int screen; | ||||||
| static int sw, sh;           /* X display screen geometry width, height */ | static int sw, sh;           /* X display screen geometry width, height */ | ||||||
| static int bh;               /* bar height */ | static int bh;               /* bar height */ | ||||||
| @@ -500,6 +505,7 @@ buttonpress(XEvent *e) | |||||||
| 	Client *c; | 	Client *c; | ||||||
| 	Monitor *m; | 	Monitor *m; | ||||||
| 	XButtonPressedEvent *ev = &e->xbutton; | 	XButtonPressedEvent *ev = &e->xbutton; | ||||||
|  | 	char *text, *s, ch; | ||||||
|  |  | ||||||
| 	click = ClkRootWin; | 	click = ClkRootWin; | ||||||
| 	/* focus monitor if necessary */ | 	/* focus monitor if necessary */ | ||||||
| @@ -524,9 +530,27 @@ buttonpress(XEvent *e) | |||||||
| 			arg.ui = 1 << i; | 			arg.ui = 1 << i; | ||||||
| 		} else if (ev->x < x + TEXTW(selmon->ltsymbol)) | 		} else if (ev->x < x + TEXTW(selmon->ltsymbol)) | ||||||
| 			click = ClkLtSymbol; | 			click = ClkLtSymbol; | ||||||
| 		else if (ev->x > selmon->ww - (int)TEXTW(stext)) | 		else if (ev->x > selmon->ww - statusw) { | ||||||
|  | 			x = selmon->ww - statusw; | ||||||
| 			click = ClkStatusText; | 			click = ClkStatusText; | ||||||
| 		else | 			statussig = 0; | ||||||
|  | 			for (text = s = stext; *s && x <= ev->x; s++) { | ||||||
|  | 				if ((unsigned char)(*s) < ' ') { | ||||||
|  | 					ch = *s; | ||||||
|  | 					*s = '\0'; | ||||||
|  | 					x += TEXTW(text) - lrpad; | ||||||
|  | 					*s = ch; | ||||||
|  | 					text = s + 1; | ||||||
|  | 					if (x >= ev->x) | ||||||
|  | 						break; | ||||||
|  | 					/* reset on matching signal raw byte */ | ||||||
|  | 					if (ch == statussig) | ||||||
|  | 						statussig = 0; | ||||||
|  | 					else | ||||||
|  | 						statussig = ch; | ||||||
|  | 				} | ||||||
|  | 			} | ||||||
|  | 		} else | ||||||
| 			click = ClkWinTitle; | 			click = ClkWinTitle; | ||||||
| 	} else if ((c = wintoclient(ev->window))) { | 	} else if ((c = wintoclient(ev->window))) { | ||||||
| 		focus(c); | 		focus(c); | ||||||
| @@ -810,9 +834,24 @@ drawbar(Monitor *m) | |||||||
|  |  | ||||||
| 	/* draw status first so it can be overdrawn by tags later */ | 	/* draw status first so it can be overdrawn by tags later */ | ||||||
| 	if (m == selmon) { /* status is only drawn on selected monitor */ | 	if (m == selmon) { /* status is only drawn on selected monitor */ | ||||||
|  | 		char *text, *s, ch; | ||||||
| 		drw_setscheme(drw, scheme[SchemeNorm]); | 		drw_setscheme(drw, scheme[SchemeNorm]); | ||||||
| 		tw = TEXTW(stext) - lrpad + 2; /* 2px right padding */ |  | ||||||
| 		drw_text(drw, m->ww - tw, 0, tw, bh, 0, stext, 0); | 		x = 0; | ||||||
|  | 		for (text = s = stext; *s; s++) { | ||||||
|  | 			if ((unsigned char)(*s) < ' ') { | ||||||
|  | 				ch = *s; | ||||||
|  | 				*s = '\0'; | ||||||
|  | 				tw = TEXTW(text) - lrpad; | ||||||
|  | 				drw_text(drw, m->ww - statusw + x, 0, tw, bh, 0, text, 0); | ||||||
|  | 				x += tw; | ||||||
|  | 				*s = ch; | ||||||
|  | 				text = s + 1; | ||||||
|  | 			} | ||||||
|  | 		} | ||||||
|  | 		tw = TEXTW(text) - lrpad + 2; | ||||||
|  | 		drw_text(drw, m->ww - statusw + x, 0, tw, bh, 0, text, 0); | ||||||
|  | 		tw = statusw; | ||||||
| 	} | 	} | ||||||
|  |  | ||||||
| 	for (c = m->clients; c; c = c->next) { | 	for (c = m->clients; c; c = c->next) { | ||||||
| @@ -977,6 +1016,30 @@ getatomprop(Client *c, Atom prop) | |||||||
| 	return atom; | 	return atom; | ||||||
| } | } | ||||||
|  |  | ||||||
|  | pid_t | ||||||
|  | getstatusbarpid() | ||||||
|  | { | ||||||
|  | 	char buf[32], *str = buf, *c; | ||||||
|  | 	FILE *fp; | ||||||
|  |  | ||||||
|  | 	if (statuspid > 0) { | ||||||
|  | 		snprintf(buf, sizeof(buf), "/proc/%u/cmdline", statuspid); | ||||||
|  | 		if ((fp = fopen(buf, "r"))) { | ||||||
|  | 			fgets(buf, sizeof(buf), fp); | ||||||
|  | 			while ((c = strchr(str, '/'))) | ||||||
|  | 				str = c + 1; | ||||||
|  | 			fclose(fp); | ||||||
|  | 			if (!strcmp(str, STATUSBAR)) | ||||||
|  | 				return statuspid; | ||||||
|  | 		} | ||||||
|  | 	} | ||||||
|  | 	if (!(fp = popen("pidof -s "STATUSBAR, "r"))) | ||||||
|  | 		return -1; | ||||||
|  | 	fgets(buf, sizeof(buf), fp); | ||||||
|  | 	pclose(fp); | ||||||
|  | 	return strtol(buf, NULL, 10); | ||||||
|  | } | ||||||
|  |  | ||||||
| int | int | ||||||
| getrootptr(int *x, int *y) | getrootptr(int *x, int *y) | ||||||
| { | { | ||||||
| @@ -1748,6 +1811,20 @@ showhide(Client *c) | |||||||
| 	} | 	} | ||||||
| } | } | ||||||
|  |  | ||||||
|  | void | ||||||
|  | sigstatusbar(const Arg *arg) | ||||||
|  | { | ||||||
|  | 	union sigval sv; | ||||||
|  |  | ||||||
|  | 	if (!statussig) | ||||||
|  | 		return; | ||||||
|  | 	sv.sival_int = arg->i; | ||||||
|  | 	if ((statuspid = getstatusbarpid()) <= 0) | ||||||
|  | 		return; | ||||||
|  |  | ||||||
|  | 	sigqueue(statuspid, SIGRTMIN+statussig, sv); | ||||||
|  | } | ||||||
|  |  | ||||||
| void | void | ||||||
| spawn(const Arg *arg) | spawn(const Arg *arg) | ||||||
| { | { | ||||||
| @@ -2150,8 +2227,25 @@ updatesizehints(Client *c) | |||||||
| void | void | ||||||
| updatestatus(void) | updatestatus(void) | ||||||
| { | { | ||||||
| 	if (!gettextprop(root, XA_WM_NAME, stext, sizeof(stext))) | 	if (!gettextprop(root, XA_WM_NAME, stext, sizeof(stext))) { | ||||||
| 		strcpy(stext, "dwm-"VERSION); | 		strcpy(stext, "dwm-"VERSION); | ||||||
|  | 		statusw = TEXTW(stext) - lrpad + 2; | ||||||
|  | 	} else { | ||||||
|  | 		char *text, *s, ch; | ||||||
|  |  | ||||||
|  | 		statusw  = 0; | ||||||
|  | 		for (text = s = stext; *s; s++) { | ||||||
|  | 			if ((unsigned char)(*s) < ' ') { | ||||||
|  | 				ch = *s; | ||||||
|  | 				*s = '\0'; | ||||||
|  | 				statusw += TEXTW(text) - lrpad; | ||||||
|  | 				*s = ch; | ||||||
|  | 				text = s + 1; | ||||||
|  | 			} | ||||||
|  | 		} | ||||||
|  | 		statusw += TEXTW(text) - lrpad + 2; | ||||||
|  |  | ||||||
|  | 	} | ||||||
| 	drawbar(selmon); | 	drawbar(selmon); | ||||||
| } | } | ||||||
|  |  | ||||||
|   | |||||||
							
								
								
									
										220
									
								
								patches/dwm-statuscmd-20241009-8933ebc.diff
									
									
									
									
									
										Normal file
									
								
							
							
						
						
									
										220
									
								
								patches/dwm-statuscmd-20241009-8933ebc.diff
									
									
									
									
									
										Normal file
									
								
							| @@ -0,0 +1,220 @@ | |||||||
|  | From ca2a2e6386a746ebfc3480787e5d99da11e7abee Mon Sep 17 00:00:00 2001 | ||||||
|  | From: Justinas Grigas <dev@jstnas.com> | ||||||
|  | Date: Wed, 9 Oct 2024 01:00:20 +0100 | ||||||
|  | Subject: [PATCH] [dwm][statuscmd] better click regions | ||||||
|  |  | ||||||
|  | The main improvement of this patch over the previous version 20210405 is that | ||||||
|  | the click region now ends on a matching signal raw byte. | ||||||
|  |  | ||||||
|  | The matching byte is optional, and without it dwm will behave as before. | ||||||
|  |  | ||||||
|  | To take advantage of this feature, scripts need to be modified to print the raw | ||||||
|  | byte at the end as well. | ||||||
|  |  | ||||||
|  | In addition, this patch cleanly applies onto master branch. | ||||||
|  | --- | ||||||
|  |  config.def.h |   6 ++- | ||||||
|  |  dwm.c        | 104 ++++++++++++++++++++++++++++++++++++++++++++++++--- | ||||||
|  |  2 files changed, 104 insertions(+), 6 deletions(-) | ||||||
|  |  | ||||||
|  | diff --git a/config.def.h b/config.def.h | ||||||
|  | index 9efa774..d008275 100644 | ||||||
|  | --- a/config.def.h | ||||||
|  | +++ b/config.def.h | ||||||
|  | @@ -55,6 +55,8 @@ static const Layout layouts[] = { | ||||||
|  |  /* helper for spawning shell commands in the pre dwm-5.0 fashion */ | ||||||
|  |  #define SHCMD(cmd) { .v = (const char*[]){ "/bin/sh", "-c", cmd, NULL } } | ||||||
|  |   | ||||||
|  | +#define STATUSBAR "dwmblocks" | ||||||
|  | + | ||||||
|  |  /* commands */ | ||||||
|  |  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 }; | ||||||
|  | @@ -104,7 +106,9 @@ static const Button buttons[] = { | ||||||
|  |  	{ ClkLtSymbol,          0,              Button1,        setlayout,      {0} }, | ||||||
|  |  	{ ClkLtSymbol,          0,              Button3,        setlayout,      {.v = &layouts[2]} }, | ||||||
|  |  	{ ClkWinTitle,          0,              Button2,        zoom,           {0} }, | ||||||
|  | -	{ ClkStatusText,        0,              Button2,        spawn,          {.v = termcmd } }, | ||||||
|  | +	{ ClkStatusText,        0,              Button1,        sigstatusbar,   {.i = 1} }, | ||||||
|  | +	{ ClkStatusText,        0,              Button2,        sigstatusbar,   {.i = 2} }, | ||||||
|  | +	{ ClkStatusText,        0,              Button3,        sigstatusbar,   {.i = 3} }, | ||||||
|  |  	{ ClkClientWin,         MODKEY,         Button1,        movemouse,      {0} }, | ||||||
|  |  	{ ClkClientWin,         MODKEY,         Button2,        togglefloating, {0} }, | ||||||
|  |  	{ ClkClientWin,         MODKEY,         Button3,        resizemouse,    {0} }, | ||||||
|  | diff --git a/dwm.c b/dwm.c | ||||||
|  | index 1443802..94ee0c7 100644 | ||||||
|  | --- a/dwm.c | ||||||
|  | +++ b/dwm.c | ||||||
|  | @@ -171,6 +171,7 @@ static void focusstack(const Arg *arg); | ||||||
|  |  static Atom getatomprop(Client *c, Atom prop); | ||||||
|  |  static int getrootptr(int *x, int *y); | ||||||
|  |  static long getstate(Window w); | ||||||
|  | +static pid_t getstatusbarpid(); | ||||||
|  |  static int gettextprop(Window w, Atom atom, char *text, unsigned int size); | ||||||
|  |  static void grabbuttons(Client *c, int focused); | ||||||
|  |  static void grabkeys(void); | ||||||
|  | @@ -204,6 +205,7 @@ static void setmfact(const Arg *arg); | ||||||
|  |  static void setup(void); | ||||||
|  |  static void seturgent(Client *c, int urg); | ||||||
|  |  static void showhide(Client *c); | ||||||
|  | +static void sigstatusbar(const Arg *arg); | ||||||
|  |  static void spawn(const Arg *arg); | ||||||
|  |  static void tag(const Arg *arg); | ||||||
|  |  static void tagmon(const Arg *arg); | ||||||
|  | @@ -236,6 +238,9 @@ static void zoom(const Arg *arg); | ||||||
|  |  /* variables */ | ||||||
|  |  static const char broken[] = "broken"; | ||||||
|  |  static char stext[256]; | ||||||
|  | +static int statusw; | ||||||
|  | +static int statussig; | ||||||
|  | +static pid_t statuspid = -1; | ||||||
|  |  static int screen; | ||||||
|  |  static int sw, sh;           /* X display screen geometry width, height */ | ||||||
|  |  static int bh;               /* bar height */ | ||||||
|  | @@ -422,6 +427,7 @@ buttonpress(XEvent *e) | ||||||
|  |  	Client *c; | ||||||
|  |  	Monitor *m; | ||||||
|  |  	XButtonPressedEvent *ev = &e->xbutton; | ||||||
|  | +	char *text, *s, ch; | ||||||
|  |   | ||||||
|  |  	click = ClkRootWin; | ||||||
|  |  	/* focus monitor if necessary */ | ||||||
|  | @@ -440,9 +446,27 @@ buttonpress(XEvent *e) | ||||||
|  |  			arg.ui = 1 << i; | ||||||
|  |  		} else if (ev->x < x + TEXTW(selmon->ltsymbol)) | ||||||
|  |  			click = ClkLtSymbol; | ||||||
|  | -		else if (ev->x > selmon->ww - (int)TEXTW(stext)) | ||||||
|  | +		else if (ev->x > selmon->ww - statusw) { | ||||||
|  | +			x = selmon->ww - statusw; | ||||||
|  |  			click = ClkStatusText; | ||||||
|  | -		else | ||||||
|  | +			statussig = 0; | ||||||
|  | +			for (text = s = stext; *s && x <= ev->x; s++) { | ||||||
|  | +				if ((unsigned char)(*s) < ' ') { | ||||||
|  | +					ch = *s; | ||||||
|  | +					*s = '\0'; | ||||||
|  | +					x += TEXTW(text) - lrpad; | ||||||
|  | +					*s = ch; | ||||||
|  | +					text = s + 1; | ||||||
|  | +					if (x >= ev->x) | ||||||
|  | +						break; | ||||||
|  | +					/* reset on matching signal raw byte */ | ||||||
|  | +					if (ch == statussig) | ||||||
|  | +						statussig = 0; | ||||||
|  | +					else | ||||||
|  | +						statussig = ch; | ||||||
|  | +				} | ||||||
|  | +			} | ||||||
|  | +		} else | ||||||
|  |  			click = ClkWinTitle; | ||||||
|  |  	} else if ((c = wintoclient(ev->window))) { | ||||||
|  |  		focus(c); | ||||||
|  | @@ -708,9 +732,24 @@ drawbar(Monitor *m) | ||||||
|  |   | ||||||
|  |  	/* draw status first so it can be overdrawn by tags later */ | ||||||
|  |  	if (m == selmon) { /* status is only drawn on selected monitor */ | ||||||
|  | +		char *text, *s, ch; | ||||||
|  |  		drw_setscheme(drw, scheme[SchemeNorm]); | ||||||
|  | -		tw = TEXTW(stext) - lrpad + 2; /* 2px right padding */ | ||||||
|  | -		drw_text(drw, m->ww - tw, 0, tw, bh, 0, stext, 0); | ||||||
|  | + | ||||||
|  | +		x = 0; | ||||||
|  | +		for (text = s = stext; *s; s++) { | ||||||
|  | +			if ((unsigned char)(*s) < ' ') { | ||||||
|  | +				ch = *s; | ||||||
|  | +				*s = '\0'; | ||||||
|  | +				tw = TEXTW(text) - lrpad; | ||||||
|  | +				drw_text(drw, m->ww - statusw + x, 0, tw, bh, 0, text, 0); | ||||||
|  | +				x += tw; | ||||||
|  | +				*s = ch; | ||||||
|  | +				text = s + 1; | ||||||
|  | +			} | ||||||
|  | +		} | ||||||
|  | +		tw = TEXTW(text) - lrpad + 2; | ||||||
|  | +		drw_text(drw, m->ww - statusw + x, 0, tw, bh, 0, text, 0); | ||||||
|  | +		tw = statusw; | ||||||
|  |  	} | ||||||
|  |   | ||||||
|  |  	for (c = m->clients; c; c = c->next) { | ||||||
|  | @@ -876,6 +915,30 @@ getatomprop(Client *c, Atom prop) | ||||||
|  |  	return atom; | ||||||
|  |  } | ||||||
|  |   | ||||||
|  | +pid_t | ||||||
|  | +getstatusbarpid() | ||||||
|  | +{ | ||||||
|  | +	char buf[32], *str = buf, *c; | ||||||
|  | +	FILE *fp; | ||||||
|  | + | ||||||
|  | +	if (statuspid > 0) { | ||||||
|  | +		snprintf(buf, sizeof(buf), "/proc/%u/cmdline", statuspid); | ||||||
|  | +		if ((fp = fopen(buf, "r"))) { | ||||||
|  | +			fgets(buf, sizeof(buf), fp); | ||||||
|  | +			while ((c = strchr(str, '/'))) | ||||||
|  | +				str = c + 1; | ||||||
|  | +			fclose(fp); | ||||||
|  | +			if (!strcmp(str, STATUSBAR)) | ||||||
|  | +				return statuspid; | ||||||
|  | +		} | ||||||
|  | +	} | ||||||
|  | +	if (!(fp = popen("pidof -s "STATUSBAR, "r"))) | ||||||
|  | +		return -1; | ||||||
|  | +	fgets(buf, sizeof(buf), fp); | ||||||
|  | +	pclose(fp); | ||||||
|  | +	return strtol(buf, NULL, 10); | ||||||
|  | +} | ||||||
|  | + | ||||||
|  |  int | ||||||
|  |  getrootptr(int *x, int *y) | ||||||
|  |  { | ||||||
|  | @@ -1643,6 +1706,20 @@ showhide(Client *c) | ||||||
|  |  	} | ||||||
|  |  } | ||||||
|  |   | ||||||
|  | +void | ||||||
|  | +sigstatusbar(const Arg *arg) | ||||||
|  | +{ | ||||||
|  | +	union sigval sv; | ||||||
|  | + | ||||||
|  | +	if (!statussig) | ||||||
|  | +		return; | ||||||
|  | +	sv.sival_int = arg->i; | ||||||
|  | +	if ((statuspid = getstatusbarpid()) <= 0) | ||||||
|  | +		return; | ||||||
|  | + | ||||||
|  | +	sigqueue(statuspid, SIGRTMIN+statussig, sv); | ||||||
|  | +} | ||||||
|  | + | ||||||
|  |  void | ||||||
|  |  spawn(const Arg *arg) | ||||||
|  |  { | ||||||
|  | @@ -2004,8 +2081,25 @@ updatesizehints(Client *c) | ||||||
|  |  void | ||||||
|  |  updatestatus(void) | ||||||
|  |  { | ||||||
|  | -	if (!gettextprop(root, XA_WM_NAME, stext, sizeof(stext))) | ||||||
|  | +	if (!gettextprop(root, XA_WM_NAME, stext, sizeof(stext))) { | ||||||
|  |  		strcpy(stext, "dwm-"VERSION); | ||||||
|  | +		statusw = TEXTW(stext) - lrpad + 2; | ||||||
|  | +	} else { | ||||||
|  | +		char *text, *s, ch; | ||||||
|  | + | ||||||
|  | +		statusw  = 0; | ||||||
|  | +		for (text = s = stext; *s; s++) { | ||||||
|  | +			if ((unsigned char)(*s) < ' ') { | ||||||
|  | +				ch = *s; | ||||||
|  | +				*s = '\0'; | ||||||
|  | +				statusw += TEXTW(text) - lrpad; | ||||||
|  | +				*s = ch; | ||||||
|  | +				text = s + 1; | ||||||
|  | +			} | ||||||
|  | +		} | ||||||
|  | +		statusw += TEXTW(text) - lrpad + 2; | ||||||
|  | + | ||||||
|  | +	} | ||||||
|  |  	drawbar(selmon); | ||||||
|  |  } | ||||||
|  |   | ||||||
|  | --  | ||||||
|  | 2.46.2 | ||||||
|  |  | ||||||
| @@ -1,3 +1,4 @@ | |||||||
| dwm-swallow-6.3.diff | dwm-swallow-6.3.diff | ||||||
| dwm-hide_vacant_tags-6.4.diff | dwm-hide_vacant_tags-6.4.diff | ||||||
| dwm-pertag-20200914-61bb8b2.diff | dwm-pertag-20200914-61bb8b2.diff | ||||||
|  | dwm-statuscmd-20241009-8933ebc.diff | ||||||
|   | |||||||
		Reference in New Issue
	
	Block a user