[hackers] [dmenu] cleanup schemes and colors || Hiltjo Posthuma
commit 77f96d704bd16b04fe731da815a4e76c4e62decb
Author: Hiltjo Posthuma <hiltjo_AT_codemadness.org>
AuthorDate: Sat Sep 27 12:10:37 2025 +0200
Commit: Hiltjo Posthuma <hiltjo_AT_codemadness.org>
CommitDate: Sat Sep 27 12:10:37 2025 +0200
cleanup schemes and colors
diff --git a/dmenu.c b/dmenu.c
index fd49549..9bad959 100644
--- a/dmenu.c
+++ b/dmenu.c
_AT_@ -101,8 +101,10 @@ cleanup(void)
size_t i;
XUngrabKeyboard(dpy, CurrentTime);
- for (i = 0; i < SchemeLast; i++)
+ for (i = 0; i < SchemeLast; i++) {
+ drw_scm_free(drw, scheme[i], 2);
free(scheme[i]);
+ }
for (i = 0; items && items[i].text; ++i)
free(items[i].text);
free(items);
diff --git a/drw.c b/drw.c
index c41e6af..98dbaa8 100644
--- a/drw.c
+++ b/drw.c
_AT_@ -178,8 +178,7 @@ drw_clr_create(Drw *drw, Clr *dest, const char *clrname)
die("error, cannot allocate color '%s'", clrname);
}
-/* Wrapper to create color schemes. The caller has to call free(3) on the
- * returned color scheme when done using it. */
+/* Create color schemes. */
Clr *
drw_scm_create(Drw *drw, const char *clrnames[], size_t clrcount)
{
_AT_@ -187,7 +186,7 @@ drw_scm_create(Drw *drw, const char *clrnames[], size_t clrcount)
Clr *ret;
/* need at least two colors for a scheme */
- if (!drw || !clrnames || clrcount < 2 || !(ret = ecalloc(clrcount, sizeof(XftColor))))
+ if (!drw || !clrnames || clrcount < 2 || !(ret = ecalloc(clrcount, sizeof(Clr))))
return NULL;
for (i = 0; i < clrcount; i++)
_AT_@ -195,6 +194,29 @@ drw_scm_create(Drw *drw, const char *clrnames[], size_t clrcount)
return ret;
}
+void
+drw_clr_free(Drw *drw, Clr *c)
+{
+ if (!drw || !c)
+ return;
+
+ /* c is typedef XftColor Clr */
+ XftColorFree(drw->dpy, DefaultVisual(drw->dpy, drw->screen),
+ DefaultColormap(drw->dpy, drw->screen), c);
+}
+
+void
+drw_scm_free(Drw *drw, Clr *scm, size_t clrcount)
+{
+ size_t i;
+
+ if (!drw || !scm)
+ return;
+
+ for (i = 0; i < clrcount; i++)
+ drw_clr_free(drw, &scm[i]);
+}
+
void
drw_setfontset(Drw *drw, Fnt *set)
{
diff --git a/drw.h b/drw.h
index fd7631b..2ed77be 100644
--- a/drw.h
+++ b/drw.h
_AT_@ -40,7 +40,9 @@ void drw_font_getexts(Fnt *font, const char *text, unsigned int len, unsigned in
/* Colorscheme abstraction */
void drw_clr_create(Drw *drw, Clr *dest, const char *clrname);
+void drw_clr_free(Drw *drw, Clr *c);
Clr *drw_scm_create(Drw *drw, const char *clrnames[], size_t clrcount);
+void drw_scm_free(Drw *drw, Clr *scm, size_t clrcount);
/* Cursor abstraction */
Cur *drw_cur_create(Drw *drw, int shape);
Received on Sat Sep 27 2025 - 12:11:00 CEST
This archive was generated by hypermail 2.3.0
: Sat Sep 27 2025 - 12:12:38 CEST