aboutsummaryrefslogtreecommitdiff
path: root/dwm.c
diff options
context:
space:
mode:
Diffstat (limited to 'dwm.c')
-rw-r--r--dwm.c23
1 files changed, 23 insertions, 0 deletions
diff --git a/dwm.c b/dwm.c
index ce81b45..f18658b 100644
--- a/dwm.c
+++ b/dwm.c
@@ -245,6 +245,7 @@ static int xerror(Display *dpy, XErrorEvent *ee);
static int xerrordummy(Display *dpy, XErrorEvent *ee);
static int xerrorstart(Display *dpy, XErrorEvent *ee);
static void zoom(const Arg *arg);
+static void setDmenuFlags();
/* variables */
static const char broken[] = "broken";
@@ -2421,6 +2422,27 @@ zoom(const Arg *arg)
pop(c);
}
+/* Make central configuration of dmenu appearance easy by sucking it out
+ * of our config.h
+ */
+void
+setDmenuFlags() {
+ const char *dmenu_flags[] = { DMENU_FLAGS, NULL };
+ char *dflags = ecalloc(1024, sizeof(char));
+ char *tmp = NULL;
+ for (int i = 0; i<sizeof(dmenu_flags)/sizeof(dmenu_flags[0]); i++) {
+ if (dmenu_flags[i] == NULL)
+ break;
+ tmp = strdup(dflags);
+ sprintf(dflags, "%s %s", tmp, dmenu_flags[i]);
+ free(tmp);
+ tmp = NULL;
+ }
+ setenv("DMENU_FLAGS", dflags, 1);
+ free(dflags);
+ dflags = NULL;
+}
+
int
main(int argc, char *argv[])
{
@@ -2433,6 +2455,7 @@ main(int argc, char *argv[])
if (!(dpy = XOpenDisplay(NULL)))
die("dwm: cannot open display");
checkotherwm();
+ setDmenuFlags();
setup();
#ifdef __OpenBSD__
if (pledge("stdio rpath proc exec", NULL) == -1)