-- Leo's gemini proxy

-- Connecting to git.thebackupbox.net:1965...

-- Connected

-- Sending request

-- Meta line: 20 text/gemini

repo: rxvt-unicode-sixel
action: commit
revision:
path_from:
revision_from: 57a4ac8cc48c16344bc334ed5ef4dd5aa3ba95f2:
path_to:
revision_to:

git.thebackupbox.net

rxvt-unicode-sixel

git://git.thebackupbox.net/rxvt-unicode-sixel

commit 57a4ac8cc48c16344bc334ed5ef4dd5aa3ba95f2
Author: Marc Lehmann <schmorp@schmorp.de>
Date:   Thu Apr 1 00:58:38 2010 +0000

    d'oh

diff --git a/src/rxvt.h b/src/rxvt.h

index 0d009ec768c8cea2e1551edbd5ad7cd4b6ecbe02..

index ..1173694b5a1bb23ff4960abde75637899d9bfd76 100644

--- a/src/rxvt.h
+++ b/src/rxvt.h
@@ -308,6 +308,7 @@ enum {

 #define RS_None                 0

+// GET_BGATTR depends on RS_fgShift > RS_bgShift
 #define RS_colorMask		((1UL << Color_Bits) - 1UL)
 #define RS_bgShift		0
 #define RS_fgShift		(RS_bgShift + Color_Bits)
@@ -318,6 +319,10 @@ enum {
 #define RS_Bold                 0x08000000UL    // value 1
 #define RS_Italic		0x10000000UL    // value 2

+#define RS_styleCount		4
+#define RS_styleMask		(RS_Bold | RS_Italic)
+#define RS_styleShift		27
+
 // fake styles
 #define RS_Blink                0x20000000UL    // blink
 #define RS_RVid                 0x40000000UL    // reverse video
@@ -336,10 +341,6 @@ enum {
 // toggle this to force redraw, must be != RS_Careful and otherwise "pretty neutral"
 #define RS_redraw		(2UL << RS_fontShift)

-#define RS_styleCount		4
-#define RS_styleMask		(RS_Bold | RS_Italic)
-#define RS_styleShift		27
-
 #define RS_baseattrMask         (RS_Italic | RS_Bold | RS_Blink | RS_RVid | RS_Uline)
 #define RS_attrMask             (RS_baseattrMask | RS_fontMask)

@@ -639,10 +640,13 @@ typedef struct _mwmhints
 #define SET_STYLE(x,style)	(((x) & ~RS_styleMask) | ((style) << RS_styleShift))

 #define GET_ATTR(x)             (((x) & RS_attrMask))
-#define GET_BGATTR(x)                                                   \
-    (((x) & RS_RVid) ? (((x) & (RS_attrMask & ~RS_RVid))                \
-                        | (((x) & RS_colorMask) << RS_bgShift))              \
-                     : ((x) & (RS_attrMask | RS_bgMask)))
+// return attributes defining the background, encoding doesn't matter
+// depends on RS_fgShift > RS_bgShift
+#define GET_BGATTR(x)                                      \
+  (expect_false ((x) & RS_RVid)                            \
+    ? (((x) & (RS_attrMask & ~RS_RVid))                    \
+      | (((x) & RS_fgMask) >> (RS_fgShift - RS_bgShift)))  \
+    : ((x) & (RS_attrMask | RS_bgMask)))
 #define SET_FGCOLOR(x,fg)       (((x) & ~RS_fgMask)   | ((fg) << RS_fgShift))
 #define SET_BGCOLOR(x,bg)       (((x) & ~RS_bgMask)   | ((bg) << RS_bgShift))
 #define SET_ATTR(x,a)           (((x) & ~RS_attrMask) | (a))
diff --git a/src/screen.C b/src/screen.C

index 8ccba89c1b51b8bd53bc8440a6e8844fd27f0253..

index ..eedfba0eba97d2bcb13e2741c7a6845f4978ffb3 100644

--- a/src/screen.C
+++ b/src/screen.C
@@ -2087,7 +2087,7 @@ rxvt_term::scr_refresh () NOTHROW
           ccol2 = Color_bg;
 #endif

-        if (showcursor && focus)
+        if (focus)
           {
             if (option (Opt_cursorUnderline))
               *crp ^= RS_Uline;

-----END OF PAGE-----

-- Response ended

-- Page fetched on Sun Jun 2 09:46:35 2024