diff options
| -rw-r--r-- | patches/dmenu-caseinsensitive-5.0.diff | 53 | ||||
| -rw-r--r-- | patches/dmenu-fuzzyhighlight-4.9.diff | 152 | ||||
| -rw-r--r-- | patches/dmenu-fuzzymatch-4.9.diff | 163 | ||||
| -rw-r--r-- | patches/dmenu-incremental-20160702-3c91eed.diff | 82 | ||||
| -rw-r--r-- | patches/dmenu-numbers-4.9.diff | 81 | ||||
| -rw-r--r-- | patches/dmenu-password-5.0.diff | 103 | ||||
| -rw-r--r-- | todo.org | 10 | 
7 files changed, 0 insertions, 644 deletions
| diff --git a/patches/dmenu-caseinsensitive-5.0.diff b/patches/dmenu-caseinsensitive-5.0.diff deleted file mode 100644 index f476bc9..0000000 --- a/patches/dmenu-caseinsensitive-5.0.diff +++ /dev/null @@ -1,53 +0,0 @@ -diff --git a/dmenu.1 b/dmenu.1 -index 323f93c..3e3b31b 100644 ---- a/dmenu.1 -+++ b/dmenu.1 -@@ -3,7 +3,7 @@ - dmenu \- dynamic menu - .SH SYNOPSIS - .B dmenu --.RB [ \-bfiv ] -+.RB [ \-bfsv ] - .RB [ \-l - .IR lines ] - .RB [ \-m -@@ -44,8 +44,8 @@ dmenu appears at the bottom of the screen. - dmenu grabs the keyboard before reading stdin if not reading from a tty. This - is faster, but will lock up X until stdin reaches end\-of\-file. - .TP --.B \-i --dmenu matches menu items case insensitively. -+.B \-s -+dmenu matches menu items case sensitively. - .TP - .BI \-l " lines" - dmenu lists items vertically, with the given number of lines. -diff --git a/dmenu.c b/dmenu.c -index 65f25ce..855df59 100644 ---- a/dmenu.c -+++ b/dmenu.c -@@ -55,8 +55,9 @@ static Clr *scheme[SchemeLast]; -  - #include "config.h" -  --static int (*fstrncmp)(const char *, const char *, size_t) = strncmp; --static char *(*fstrstr)(const char *, const char *) = strstr; -+static char * cistrstr(const char *s, const char *sub); -+static int (*fstrncmp)(const char *, const char *, size_t) = strncasecmp; -+static char *(*fstrstr)(const char *, const char *) = cistrstr; -  - static void - appenditem(struct item *item, struct item **list, struct item **last) -@@ -709,9 +710,9 @@ main(int argc, char *argv[]) - 			topbar = 0; - 		else if (!strcmp(argv[i], "-f"))   /* grabs keyboard before reading stdin */ - 			fast = 1; --		else if (!strcmp(argv[i], "-i")) { /* case-insensitive item matching */ --			fstrncmp = strncasecmp; --			fstrstr = cistrstr; -+		else if (!strcmp(argv[i], "-s")) { /* case-sensitive item matching */ -+			fstrncmp = strncmp; -+			fstrstr = strstr; - 		} else if (i + 1 == argc) - 			usage(); - 		/* these options take one argument */ diff --git a/patches/dmenu-fuzzyhighlight-4.9.diff b/patches/dmenu-fuzzyhighlight-4.9.diff deleted file mode 100644 index 58d5c6f..0000000 --- a/patches/dmenu-fuzzyhighlight-4.9.diff +++ /dev/null @@ -1,152 +0,0 @@ -Author: Chris Noxz <chris@noxz.tech> -note: This patch is meant to be used together with fuzzymatch - -diff -upN dmenu-4.9/config.def.h dmenu-4.9-fuzzyhighlight/config.def.h ---- dmenu-4.9/config.def.h	2019-02-02 13:55:02.000000000 +0100 -+++ dmenu-4.9-fuzzyhighlight/config.def.h	2020-04-04 10:26:36.990890854 +0200 -@@ -11,6 +11,8 @@ static const char *colors[SchemeLast][2] - 	/*     fg         bg       */ - 	[SchemeNorm] = { "#bbbbbb", "#222222" }, - 	[SchemeSel] = { "#eeeeee", "#005577" }, -+	[SchemeSelHighlight] = { "#ffc978", "#005577" }, -+	[SchemeNormHighlight] = { "#ffc978", "#222222" }, - 	[SchemeOut] = { "#000000", "#00ffff" }, - }; - /* -l option; if nonzero, dmenu uses vertical list with given number of lines */ -diff -upN dmenu-4.9/dmenu.1 dmenu-4.9-fuzzyhighlight/dmenu.1 ---- dmenu-4.9/dmenu.1	2019-02-02 13:55:02.000000000 +0100 -+++ dmenu-4.9-fuzzyhighlight/dmenu.1	2020-04-04 10:30:16.430054933 +0200 -@@ -20,6 +20,14 @@ dmenu \- dynamic menu - .IR color ] - .RB [ \-sf - .IR color ] -+.RB [ \-nhb -+.IR color ] -+.RB [ \-nhf -+.IR color ] -+.RB [ \-shb -+.IR color ] -+.RB [ \-shf -+.IR color ] - .RB [ \-w - .IR windowid ] - .P -@@ -75,6 +83,18 @@ defines the selected background color. - .BI \-sf " color" - defines the selected foreground color. - .TP -+.BI \-nhb " color" -+defines the normal highlight background color. -+.TP -+.BI \-nhf " color" -+defines the normal highlight foreground color. -+.TP -+.BI \-shb " color" -+defines the selected highlight background color. -+.TP -+.BI \-shf " color" -+defines the selected highlight foreground color. -+.TP - .B \-v - prints version information to stdout, then exits. - .TP -diff -upN dmenu-4.9/dmenu.c dmenu-4.9-fuzzyhighlight/dmenu.c ---- dmenu-4.9/dmenu.c	2019-02-02 13:55:02.000000000 +0100 -+++ dmenu-4.9-fuzzyhighlight/dmenu.c	2020-04-04 10:27:43.888026309 +0200 -@@ -26,7 +26,9 @@ - #define TEXTW(X)              (drw_fontset_getwidth(drw, (X)) + lrpad) -  - /* enums */ --enum { SchemeNorm, SchemeSel, SchemeOut, SchemeLast }; /* color schemes */ -+enum { SchemeNorm, SchemeSel, SchemeNormHighlight, SchemeSelHighlight, -+       SchemeOut, SchemeLast }; /* color schemes */ -+ -  - struct item { - 	char *text; -@@ -113,9 +115,49 @@ cistrstr(const char *s, const char *sub) - 	return NULL; - } -  -+static void -+drawhighlights(struct item *item, int x, int y, int maxw) -+{ -+	int i, indent; -+	char *highlight; -+	char c; -+ -+	if (!(strlen(item->text) && strlen(text))) -+		return; -+ -+	drw_setscheme(drw, scheme[item == sel -+	                   ? SchemeSelHighlight -+	                   : SchemeNormHighlight]); -+	for (i = 0, highlight = item->text; *highlight && text[i];) { -+		if (*highlight == text[i]) { -+			/* get indentation */ -+			c = *highlight; -+			*highlight = '\0'; -+			indent = TEXTW(item->text); -+			*highlight = c; -+ -+			/* highlight character */ -+			c = highlight[1]; -+			highlight[1] = '\0'; -+			drw_text( -+				drw, -+				x + indent - (lrpad / 2), -+				y, -+				MIN(maxw - indent, TEXTW(highlight) - lrpad), -+				bh, 0, highlight, 0 -+			); -+			highlight[1] = c; -+			i++; -+		} -+		highlight++; -+	} -+} -+ -+ - static int - drawitem(struct item *item, int x, int y, int w) - { -+	int r; - 	if (item == sel) - 		drw_setscheme(drw, scheme[SchemeSel]); - 	else if (item->out) -@@ -123,7 +165,9 @@ drawitem(struct item *item, int x, int y - 	else - 		drw_setscheme(drw, scheme[SchemeNorm]); -  --	return drw_text(drw, x, y, w, bh, lrpad / 2, item->text, 0); -+	r = drw_text(drw, x, y, w, bh, lrpad / 2, item->text, 0); -+	drawhighlights(item, x, y, w); -+	return r; - } -  - static void -@@ -683,7 +727,8 @@ static void - usage(void) - { - 	fputs("usage: dmenu [-bfiv] [-l lines] [-p prompt] [-fn font] [-m monitor]\n" --	      "             [-nb color] [-nf color] [-sb color] [-sf color] [-w windowid]\n", stderr); -+	      "             [-nb color] [-nf color] [-sb color] [-sf color]\n" -+	      "             [-nhb color] [-nhf color] [-shb color] [-shf color] [-w windowid]\n", stderr); - 	exit(1); - } -  -@@ -724,6 +769,14 @@ main(int argc, char *argv[]) - 			colors[SchemeSel][ColBg] = argv[++i]; - 		else if (!strcmp(argv[i], "-sf"))  /* selected foreground color */ - 			colors[SchemeSel][ColFg] = argv[++i]; -+		else if (!strcmp(argv[i], "-nhb")) /* normal hi background color */ -+			colors[SchemeNormHighlight][ColBg] = argv[++i]; -+		else if (!strcmp(argv[i], "-nhf")) /* normal hi foreground color */ -+			colors[SchemeNormHighlight][ColFg] = argv[++i]; -+		else if (!strcmp(argv[i], "-shb")) /* selected hi background color */ -+			colors[SchemeSelHighlight][ColBg] = argv[++i]; -+		else if (!strcmp(argv[i], "-shf")) /* selected hi foreground color */ -+			colors[SchemeSelHighlight][ColFg] = argv[++i]; - 		else if (!strcmp(argv[i], "-w"))   /* embedding window id */ - 			embed = argv[++i]; - 		else diff --git a/patches/dmenu-fuzzymatch-4.9.diff b/patches/dmenu-fuzzymatch-4.9.diff deleted file mode 100644 index 9fd206d..0000000 --- a/patches/dmenu-fuzzymatch-4.9.diff +++ /dev/null @@ -1,163 +0,0 @@ -From 94353eb52055927d9079f3d9e33da1c954abf386 Mon Sep 17 00:00:00 2001 -From: aleks <aleks.stier@icloud.com> -Date: Wed, 26 Jun 2019 13:25:10 +0200 -Subject: [PATCH] Add support for fuzzy-matching - ---- - config.def.h |  1 + - config.mk    |  2 +- - dmenu.c      | 89 ++++++++++++++++++++++++++++++++++++++++++++++++++++ - 3 files changed, 91 insertions(+), 1 deletion(-) - -diff --git a/config.def.h b/config.def.h -index 1edb647..51612b9 100644 ---- a/config.def.h -+++ b/config.def.h -@@ -2,6 +2,7 @@ - /* Default settings; can be overriden by command line. */ -  - static int topbar = 1;                      /* -b  option; if 0, dmenu appears at bottom     */ -+static int fuzzy = 1;                      /* -F  option; if 0, dmenu doesn't use fuzzy matching     */ - /* -fn option overrides fonts[0]; default X11 font or font set */ - static const char *fonts[] = { - 	"monospace:size=10" -diff --git a/config.mk b/config.mk -index 0929b4a..d14309a 100644 ---- a/config.mk -+++ b/config.mk -@@ -20,7 +20,7 @@ FREETYPEINC = /usr/include/freetype2 -  - # includes and libs - INCS = -I$(X11INC) -I$(FREETYPEINC) --LIBS = -L$(X11LIB) -lX11 $(XINERAMALIBS) $(FREETYPELIBS) -+LIBS = -L$(X11LIB) -lX11 $(XINERAMALIBS) $(FREETYPELIBS) -lm -  - # flags - CPPFLAGS = -D_DEFAULT_SOURCE -D_BSD_SOURCE -D_XOPEN_SOURCE=700 -D_POSIX_C_SOURCE=200809L -DVERSION=\"$(VERSION)\" $(XINERAMAFLAGS) -diff --git a/dmenu.c b/dmenu.c -index 6b8f51b..96ddc98 100644 ---- a/dmenu.c -+++ b/dmenu.c -@@ -1,6 +1,7 @@ - /* See LICENSE file for copyright and license details. */ - #include <ctype.h> - #include <locale.h> -+#include <math.h> - #include <stdio.h> - #include <stdlib.h> - #include <string.h> -@@ -32,6 +33,7 @@ struct item { - 	char *text; - 	struct item *left, *right; - 	int out; -+	double distance; - }; -  - static char text[BUFSIZ] = ""; -@@ -210,9 +212,94 @@ grabkeyboard(void) - 	die("cannot grab keyboard"); - } -  -+int -+compare_distance(const void *a, const void *b) -+{ -+	struct item *da = *(struct item **) a; -+	struct item *db = *(struct item **) b; -+ -+	if (!db) -+		return 1; -+	if (!da) -+		return -1; -+ -+	return da->distance == db->distance ? 0 : da->distance < db->distance ? -1 : 1; -+} -+ -+void -+fuzzymatch(void) -+{ -+	/* bang - we have so much memory */ -+	struct item *it; -+	struct item **fuzzymatches = NULL; -+	char c; -+	int number_of_matches = 0, i, pidx, sidx, eidx; -+	int text_len = strlen(text), itext_len; -+ -+	matches = matchend = NULL; -+ -+	/* walk through all items */ -+	for (it = items; it && it->text; it++) { -+		if (text_len) { -+			itext_len = strlen(it->text); -+			pidx = 0; /* pointer */ -+			sidx = eidx = -1; /* start of match, end of match */ -+			/* walk through item text */ -+			for (i = 0; i < itext_len && (c = it->text[i]); i++) { -+				/* fuzzy match pattern */ -+				if (!fstrncmp(&text[pidx], &c, 1)) { -+					if(sidx == -1) -+						sidx = i; -+					pidx++; -+					if (pidx == text_len) { -+						eidx = i; -+						break; -+					} -+				} -+			} -+			/* build list of matches */ -+			if (eidx != -1) { -+				/* compute distance */ -+				/* add penalty if match starts late (log(sidx+2)) -+				 * add penalty for long a match without many matching characters */ -+				it->distance = log(sidx + 2) + (double)(eidx - sidx - text_len); -+				/* fprintf(stderr, "distance %s %f\n", it->text, it->distance); */ -+				appenditem(it, &matches, &matchend); -+				number_of_matches++; -+			} -+		} else { -+			appenditem(it, &matches, &matchend); -+		} -+	} -+ -+	if (number_of_matches) { -+		/* initialize array with matches */ -+		if (!(fuzzymatches = realloc(fuzzymatches, number_of_matches * sizeof(struct item*)))) -+			die("cannot realloc %u bytes:", number_of_matches * sizeof(struct item*)); -+		for (i = 0, it = matches; it && i < number_of_matches; i++, it = it->right) { -+			fuzzymatches[i] = it; -+		} -+		/* sort matches according to distance */ -+		qsort(fuzzymatches, number_of_matches, sizeof(struct item*), compare_distance); -+		/* rebuild list of matches */ -+		matches = matchend = NULL; -+		for (i = 0, it = fuzzymatches[i];  i < number_of_matches && it && \ -+				it->text; i++, it = fuzzymatches[i]) { -+			appenditem(it, &matches, &matchend); -+		} -+		free(fuzzymatches); -+	} -+	curr = sel = matches; -+	calcoffsets(); -+} -+ - static void - match(void) - { -+	if (fuzzy) { -+		fuzzymatch(); -+		return; -+	} - 	static char **tokv = NULL; - 	static int tokn = 0; -  -@@ -702,6 +789,8 @@ main(int argc, char *argv[]) - 			topbar = 0; - 		else if (!strcmp(argv[i], "-f"))   /* grabs keyboard before reading stdin */ - 			fast = 1; -+		else if (!strcmp(argv[i], "-F"))   /* grabs keyboard before reading stdin */ -+			fuzzy = 0; - 		else if (!strcmp(argv[i], "-i")) { /* case-insensitive item matching */ - 			fstrncmp = strncasecmp; - 			fstrstr = cistrstr; ---  -2.22.0 - diff --git a/patches/dmenu-incremental-20160702-3c91eed.diff b/patches/dmenu-incremental-20160702-3c91eed.diff deleted file mode 100644 index 0499f8c..0000000 --- a/patches/dmenu-incremental-20160702-3c91eed.diff +++ /dev/null @@ -1,82 +0,0 @@ -From 38914e7a39b12ba1001b5464e6d96d1d15e73634 Mon Sep 17 00:00:00 2001 -From: Hiltjo Posthuma <hiltjo@codemadness.org> -Date: Fri, 17 Jun 2016 15:33:50 +0200 -Subject: [PATCH] incremental mode: dmenu outputs text each time a key is - pressed. - ---- - config.def.h | 1 + - dmenu.1      | 4 ++++ - dmenu.c      | 8 +++++++- - 3 files changed, 12 insertions(+), 1 deletion(-) - -diff --git a/config.def.h b/config.def.h -index dcffd38..994f3a5 100644 ---- a/config.def.h -+++ b/config.def.h -@@ -2,6 +2,7 @@ - /* Default settings; can be overriden by command line. */ -  - static int topbar = 1;                      /* -b  option; if 0, dmenu appears at bottom     */ -+static int incremental = 0;                 /* -r  option; if 1, outputs text each time a key is pressed */ - /* -fn option overrides fonts[0]; default X11 font or font set */ - static const char *fonts[] = { - 	"monospace:size=10" -diff --git a/dmenu.1 b/dmenu.1 -index d3ab805..e5bf42f 100644 ---- a/dmenu.1 -+++ b/dmenu.1 -@@ -18,6 +18,7 @@ dmenu \- dynamic menu - .IR color ] - .RB [ \-nf - .IR color ] -+.RB [ \-r ] - .RB [ \-sb - .IR color ] - .RB [ \-sf -@@ -58,6 +59,9 @@ from 0. - .BI \-p " prompt" - defines the prompt to be displayed to the left of the input field. - .TP -+.B \-r -+dmenu outputs text each time a key is pressed. -+.TP - .BI \-fn " font" - defines the font or font set used. - .TP -diff --git a/dmenu.c b/dmenu.c -index e0c2f80..7f1be56 100644 ---- a/dmenu.c -+++ b/dmenu.c -@@ -447,6 +447,10 @@ keypress(XKeyEvent *ev) - 		match(); - 		break; - 	} -+	if (incremental) { -+		puts(text); -+		fflush(stdout); -+	} - 	drawmenu(); - } -  -@@ -611,7 +615,7 @@ static void - usage(void) - { - 	fputs("usage: dmenu [-b] [-f] [-i] [-l lines] [-p prompt] [-fn font] [-m monitor]\n" --	      "             [-nb color] [-nf color] [-sb color] [-sf color] [-v]\n", stderr); -+	      "             [-nb color] [-nf color] [-r] [-sb color] [-sf color] [-v]\n", stderr); - 	exit(1); - } -  -@@ -629,6 +633,8 @@ main(int argc, char *argv[]) - 			topbar = 0; - 		else if (!strcmp(argv[i], "-f"))   /* grabs keyboard before reading stdin */ - 			fast = 1; -+		else if (!strcmp(argv[i], "-r"))   /* incremental */ -+			incremental = 1; - 		else if (!strcmp(argv[i], "-i")) { /* case-insensitive item matching */ - 			fstrncmp = strncasecmp; - 			fstrstr = cistrstr; ---  -2.8.3 - diff --git a/patches/dmenu-numbers-4.9.diff b/patches/dmenu-numbers-4.9.diff deleted file mode 100644 index 113be80..0000000 --- a/patches/dmenu-numbers-4.9.diff +++ /dev/null @@ -1,81 +0,0 @@ -From 61abc60dbfaa8ec63fcd176307308aee88a19e32 Mon Sep 17 00:00:00 2001 -From: Miles Alan <m@milesalan.com> -Date: Sat, 10 Aug 2019 17:20:08 -0500 -Subject: [PATCH] Display number of matched and total items in top right corner - ---- - dmenu.c | 25 +++++++++++++++++++++++-- - 1 file changed, 23 insertions(+), 2 deletions(-) - -diff --git a/dmenu.c b/dmenu.c -index 6b8f51b..98c5810 100644 ---- a/dmenu.c -+++ b/dmenu.c -@@ -24,6 +24,8 @@ -                              * MAX(0, MIN((y)+(h),(r).y_org+(r).height) - MAX((y),(r).y_org))) - #define LENGTH(X)             (sizeof X / sizeof X[0]) - #define TEXTW(X)              (drw_fontset_getwidth(drw, (X)) + lrpad) -+#define NUMBERSMAXDIGITS      100 -+#define NUMBERSBUFSIZE        (NUMBERSMAXDIGITS * 2) + 1 -  - /* enums */ - enum { SchemeNorm, SchemeSel, SchemeOut, SchemeLast }; /* color schemes */ -@@ -34,6 +36,7 @@ struct item { - 	int out; - }; -  -+static char numbers[NUMBERSBUFSIZE] = ""; - static char text[BUFSIZ] = ""; - static char *embed; - static int bh, mw, mh; -@@ -126,6 +129,21 @@ drawitem(struct item *item, int x, int y, int w) - 	return drw_text(drw, x, y, w, bh, lrpad / 2, item->text, 0); - } -  -+static void -+recalculatenumbers() -+{ -+	unsigned int numer = 0, denom = 0; -+	struct item *item; -+	if (matchend) { -+		numer++; -+		for (item = matchend; item && item->left; item = item->left) -+			numer++; -+	} -+	for (item = items; item && item->text; item++) -+		denom++; -+	snprintf(numbers, NUMBERSBUFSIZE, "%d/%d", numer, denom); -+} -+ - static void - drawmenu(void) - { -@@ -151,6 +169,7 @@ drawmenu(void) - 		drw_rect(drw, x + curpos, 2, 2, bh - 4, 1, 0); - 	} -  -+	recalculatenumbers(); - 	if (lines > 0) { - 		/* draw vertical list */ - 		for (item = curr; item != next; item = item->right) -@@ -165,13 +184,15 @@ drawmenu(void) - 		} - 		x += w; - 		for (item = curr; item != next; item = item->right) --			x = drawitem(item, x, 0, MIN(TEXTW(item->text), mw - x - TEXTW(">"))); -+			x = drawitem(item, x, 0, MIN(TEXTW(item->text), mw - x - TEXTW(">") - TEXTW(numbers))); - 		if (next) { - 			w = TEXTW(">"); - 			drw_setscheme(drw, scheme[SchemeNorm]); --			drw_text(drw, mw - w, 0, w, bh, lrpad / 2, ">", 0); -+			drw_text(drw, mw - w - TEXTW(numbers), 0, w, bh, lrpad / 2, ">", 0); - 		} - 	} -+	drw_setscheme(drw, scheme[SchemeNorm]); -+	drw_text(drw, mw - TEXTW(numbers), 0, TEXTW(numbers), bh, lrpad / 2, numbers, 0); - 	drw_map(drw, win, 0, 0, mw, mh); - } -  ---  -2.19.2 - diff --git a/patches/dmenu-password-5.0.diff b/patches/dmenu-password-5.0.diff deleted file mode 100644 index 7a187b9..0000000 --- a/patches/dmenu-password-5.0.diff +++ /dev/null @@ -1,103 +0,0 @@ -From c4de1032bd4c247bc20b6ab92a10a8d778966679 Mon Sep 17 00:00:00 2001 -From: Mehrad Mahmoudian <m.mahmoudian@gmail.com> -Date: Tue, 4 May 2021 12:05:09 +0300 -Subject: [PATCH] patched with password patch - ---- - dmenu.1 |  5 ++++- - dmenu.c | 21 +++++++++++++++++---- - 2 files changed, 21 insertions(+), 5 deletions(-) - -diff --git a/dmenu.1 b/dmenu.1 -index 323f93c..762f707 100644 ---- a/dmenu.1 -+++ b/dmenu.1 -@@ -3,7 +3,7 @@ - dmenu \- dynamic menu - .SH SYNOPSIS - .B dmenu --.RB [ \-bfiv ] -+.RB [ \-bfivP ] - .RB [ \-l - .IR lines ] - .RB [ \-m -@@ -47,6 +47,9 @@ is faster, but will lock up X until stdin reaches end\-of\-file. - .B \-i - dmenu matches menu items case insensitively. - .TP -+.B \-P -+dmenu will not directly display the keyboard input, but instead replace it with dots. All data from stdin will be ignored. -+.TP - .BI \-l " lines" - dmenu lists items vertically, with the given number of lines. - .TP -diff --git a/dmenu.c b/dmenu.c -index 65f25ce..ad8f63b 100644 ---- a/dmenu.c -+++ b/dmenu.c -@@ -37,7 +37,7 @@ struct item { - static char text[BUFSIZ] = ""; - static char *embed; - static int bh, mw, mh; --static int inputw = 0, promptw; -+static int inputw = 0, promptw, passwd = 0; - static int lrpad; /* sum of left and right padding */ - static size_t cursor; - static struct item *items = NULL; -@@ -132,6 +132,7 @@ drawmenu(void) - 	unsigned int curpos; - 	struct item *item; - 	int x = 0, y = 0, w; -+	char *censort; -  - 	drw_setscheme(drw, scheme[SchemeNorm]); - 	drw_rect(drw, 0, 0, mw, mh, 1, 1); -@@ -143,7 +144,12 @@ drawmenu(void) - 	/* draw input field */ - 	w = (lines > 0 || !matches) ? mw - x : inputw; - 	drw_setscheme(drw, scheme[SchemeNorm]); --	drw_text(drw, x, 0, w, bh, lrpad / 2, text, 0); -+	if (passwd) { -+	        censort = ecalloc(1, sizeof(text)); -+		memset(censort, '.', strlen(text)); -+		drw_text(drw, x, 0, w, bh, lrpad / 2, censort, 0); -+		free(censort); -+	} else drw_text(drw, x, 0, w, bh, lrpad / 2, text, 0); -  - 	curpos = TEXTW(text) - TEXTW(&text[cursor]); - 	if ((curpos += lrpad / 2 - 1) < w) { -@@ -524,6 +530,11 @@ readstdin(void) - 	char buf[sizeof text], *p; - 	size_t i, imax = 0, size = 0; - 	unsigned int tmpmax = 0; -+	if(passwd){ -+    	inputw = lines = 0; -+    	return; -+  	} -+ -  - 	/* read each line from stdin and add it to the item list */ - 	for (i = 0; fgets(buf, sizeof buf, stdin); i++) { -@@ -689,7 +700,7 @@ setup(void) - static void - usage(void) - { --	fputs("usage: dmenu [-bfiv] [-l lines] [-p prompt] [-fn font] [-m monitor]\n" -+	fputs("usage: dmenu [-bfivP] [-l lines] [-p prompt] [-fn font] [-m monitor]\n" - 	      "             [-nb color] [-nf color] [-sb color] [-sf color] [-w windowid]\n", stderr); - 	exit(1); - } -@@ -712,7 +723,9 @@ main(int argc, char *argv[]) - 		else if (!strcmp(argv[i], "-i")) { /* case-insensitive item matching */ - 			fstrncmp = strncasecmp; - 			fstrstr = cistrstr; --		} else if (i + 1 == argc) -+		} else if (!strcmp(argv[i], "-P"))   /* is the input a password */ -+			passwd = 1; -+		else if (i + 1 == argc) - 			usage(); - 		/* these options take one argument */ - 		else if (!strcmp(argv[i], "-l"))   /* number of lines in vertical list */ ---  -2.31.1 - diff --git a/todo.org b/todo.org deleted file mode 100644 index 9cfc933..0000000 --- a/todo.org +++ /dev/null @@ -1,10 +0,0 @@ -* Open Work -** TODO [#B] Add password patch so this can be used alongside pinentry-dmenu -Current version of Dmenu is 5.2. -The patch is for 5.0, but may apply just fine. -*** 2023-07-14 @ 12:04:16 -0500 Diffing my version with vanilla 5.2 -I believe I'm using vanilla Dmenu, so the patch should be straightforward, but I'd like to check this assumption. -*** Reference -Dmenu: https://tools.suckless.org/dmenu/ -* Resolved -* References | 
