]> git.armaanb.net Git - st.git/blobdiff - x.c
fix memory leak in xloadcols()
[st.git] / x.c
diff --git a/x.c b/x.c
index ffd005fae1523bca102905cc13d86cf8f380dd92..042242181ecb2ca3e8efb82be3f9dd94968d78aa 100644 (file)
--- a/x.c
+++ b/x.c
@@ -733,12 +733,12 @@ xloadcols(void)
        static int loaded;
        Color *cp;
 
-       dc.collen = MAX(LEN(colorname), 256);
-       dc.col = xmalloc(dc.collen * sizeof(Color));
-
        if (loaded) {
                for (cp = dc.col; cp < &dc.col[dc.collen]; ++cp)
                        XftColorFree(xw.dpy, xw.vis, xw.cmap, cp);
+       } else {
+               dc.collen = MAX(LEN(colorname), 256);
+               dc.col = xmalloc(dc.collen * sizeof(Color));
        }
 
        for (i = 0; i < dc.collen; i++)
@@ -1418,19 +1418,25 @@ xdrawcursor(int cx, int cy, Glyph g, int ox, int oy, Glyph og)
         */
        g.mode &= ATTR_BOLD|ATTR_ITALIC|ATTR_UNDERLINE|ATTR_STRUCK|ATTR_WIDE;
 
-       if (selected(cx, cy)) {
-               g.bg = defaultrcs;
-               g.fg = defaultfg;
-       } else {
-               g.bg = defaultcs;
-               g.fg = defaultbg;
-       }
-       drawcol = dc.col[g.bg];
-
        if (IS_SET(MODE_REVERSE)) {
-               drawcol.color.red = ~drawcol.color.red;
-               drawcol.color.green = ~drawcol.color.green;
-               drawcol.color.blue = ~drawcol.color.blue;
+               g.mode |= ATTR_REVERSE;
+               g.bg = defaultfg;
+               if (selected(cx, cy)) {
+                       drawcol = dc.col[defaultcs];
+                       g.fg = defaultrcs;
+               } else {
+                       drawcol = dc.col[defaultrcs];
+                       g.fg = defaultcs;
+               }
+       } else {
+               if (selected(cx, cy)) {
+                       g.fg = defaultfg;
+                       g.bg = defaultrcs;
+               } else {
+                       g.fg = defaultbg;
+                       g.bg = defaultcs;
+               }
+               drawcol = dc.col[g.bg];
        }
 
        /* draw the new one */