Applied Phil Endecott's patch, which adds support for additional SGR
[apps/madtty.git] / inject_csi.c
index 8d5ee9d..e7652aa 100644 (file)
@@ -48,11 +48,43 @@ static void interpret_csi_SGR(RoteTerm *rt, int param[], int pcount) {
    }
 
    for (i = 0; i < pcount; i++) {
+
+// From http://vt100.net/docs/vt510-rm/SGR table 5-16
+// 0   All attributes off
+// 1   Bold
+// 4   Underline
+// 5   Blinking
+// 7   Negative image
+// 8   Invisible image
+// 10  The ASCII character set is the current 7-bit
+//     display character set (default) - SCO Console only.
+// 11  Map Hex 00-7F of the PC character set codes
+//     to the current 7-bit display character set
+//     - SCO Console only.
+// 12  Map Hex 80-FF of the current character set to
+//     the current 7-bit display character set - SCO
+//     Console only.
+// 22  Bold off
+// 24  Underline off
+// 25  Blinking off
+// 27  Negative image off
+// 28  Invisible image off
+
       if (param[i] == 0) rt->curattr = 0x70;
       else if (param[i] == 1 || param[i] == 2 || param[i] == 4)  /* set bold */
-         rt->curattr |= 0x80;
-      else if (param[i] == 5) rt->curattr |= 0x08;  /* set blink */
+         ROTE_ATTR_MOD_BOLD(rt->curattr,1);
+      else if (param[i] == 5)  /* set blink */
+         ROTE_ATTR_MOD_BLINK(rt->curattr,1);
       else if (param[i] == 7) rt->curattr = 0x07;   /* reverse video */
+      else if (param[i] == 8) rt->curattr = 0x0;    /* invisible */
+      else if (param[i] == 22 || param[i] == 24) /* bold off */
+        ROTE_ATTR_MOD_BOLD(rt->curattr,0);
+      else if (param[i] == 25) /* blink off */
+        ROTE_ATTR_MOD_BLINK(rt->curattr,0);
+      else if (param[i] == 27) /* negative off */
+        rt->curattr = 0x70;
+      else if (param[i] == 28) /* invisible off */
+        rt->curattr = 0x70;
       else if (param[i] >= 30 && param[i] <= 37)    /* set fg */
          ROTE_ATTR_MOD_FG(rt->curattr, param[i] - 30);
       else if (param[i] >= 40 && param[i] <= 47)    /* set bg */