Revert "Simplify cursor color handling"
authorHiltjo Posthuma <hiltjo@codemadness.org>
Tue, 17 Jul 2018 18:01:58 +0000 (20:01 +0200)
committerHiltjo Posthuma <hiltjo@codemadness.org>
Tue, 17 Jul 2018 18:01:58 +0000 (20:01 +0200)
This reverts commit 1911c9274d9b03f3d7999c6ce26e2d5169642d26.

x.c

diff --git a/x.c b/x.c
index ffd005f..00cb6b1 100644 (file)
--- a/x.c
+++ b/x.c
@@ -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 */