xresources: Questionable solution to allowing command line arguments to take precedence over xresources

This commit is contained in:
bakkeby 2021-10-20 17:41:28 +02:00
parent 328a60e0d3
commit 7fd7f72d5d

45
dmenu.c
View File

@ -1825,6 +1825,28 @@ main(int argc, char *argv[])
int fast = 0; int fast = 0;
#endif // NON_BLOCKING_STDIN_PATCH #endif // NON_BLOCKING_STDIN_PATCH
#if XRESOURCES_PATCH
if (!setlocale(LC_CTYPE, "") || !XSupportsLocale())
fputs("warning: no locale support\n", stderr);
if (!(dpy = XOpenDisplay(NULL)))
die("cannot open display");
screen = DefaultScreen(dpy);
root = RootWindow(dpy, screen);
if (!embed || !(parentwin = strtol(embed, NULL, 0)))
parentwin = root;
if (!XGetWindowAttributes(dpy, parentwin, &wa))
die("could not get embedding window attributes: 0x%lx",
parentwin);
#if ALPHA_PATCH
xinitvisual();
drw = drw_create(dpy, screen, root, wa.width, wa.height, visual, depth, cmap);
#else
drw = drw_create(dpy, screen, root, wa.width, wa.height);
#endif // ALPHA_PATCH
readxresources();
#endif // XRESOURCES_PATCH
for (i = 1; i < argc; i++) for (i = 1; i < argc; i++)
/* these options take no arguments */ /* these options take no arguments */
if (!strcmp(argv[i], "-v")) { /* prints version information */ if (!strcmp(argv[i], "-v")) { /* prints version information */
@ -1990,6 +2012,15 @@ main(int argc, char *argv[])
else else
usage(); usage();
#if XRESOURCES_PATCH
#if PANGO_PATCH
if (!drw_font_create(drw, font))
die("no fonts could be loaded.");
#else
if (!drw_fontset_create(drw, (const char**)fonts, LENGTH(fonts)))
die("no fonts could be loaded.");
#endif // PANGO_PATCH
#else // !XRESOURCES_PATCH
if (!setlocale(LC_CTYPE, "") || !XSupportsLocale()) if (!setlocale(LC_CTYPE, "") || !XSupportsLocale())
fputs("warning: no locale support\n", stderr); fputs("warning: no locale support\n", stderr);
if (!(dpy = XOpenDisplay(NULL))) if (!(dpy = XOpenDisplay(NULL)))
@ -2008,22 +2039,16 @@ main(int argc, char *argv[])
#else #else
drw = drw_create(dpy, screen, root, wa.width, wa.height); drw = drw_create(dpy, screen, root, wa.width, wa.height);
#endif // ALPHA_PATCH #endif // ALPHA_PATCH
#if XRESOURCES_PATCH
readxresources();
#if PANGO_PATCH #if PANGO_PATCH
if (!drw_font_create(drw, font)) if (!drw_font_create(drw, font))
die("no fonts could be loaded."); die("no fonts could be loaded.");
#else #else
if (!drw_fontset_create(drw, (const char**)fonts, LENGTH(fonts)))
die("no fonts could be loaded.");
#endif // PANGO_PATCH
#elif PANGO_PATCH
if (!drw_font_create(drw, font))
die("no fonts could be loaded.");
#else
if (!drw_fontset_create(drw, fonts, LENGTH(fonts))) if (!drw_fontset_create(drw, fonts, LENGTH(fonts)))
die("no fonts could be loaded."); die("no fonts could be loaded.");
#endif // XRESOURCES_PATCH | PANGO_PATCH #endif // PANGO_PATCH
#endif // XRESOURCES_PATCH
#if PANGO_PATCH #if PANGO_PATCH
lrpad = drw->font->h; lrpad = drw->font->h;
#else #else