« get me outta code hell

Interpret 'off' SGR commands in ANSI interpreter - tui-lib - Pure Node.js library for making visual command-line programs (ala vim, ncdu)
about summary refs log tree commit diff
diff options
context:
space:
mode:
authorFlorrie <towerofnix@gmail.com>2017-12-10 00:22:41 -0400
committerFlorrie <towerofnix@gmail.com>2017-12-10 00:22:41 -0400
commit3334442bbc7520bf091ed37e28a1898685691582 (patch)
treedf0928f70266693ea5aca2728acc001631db81eb
parenta0c864e531cc793855f0d3462d9f9ef2aca7affa (diff)
Interpret 'off' SGR commands in ANSI interpreter
-rw-r--r--util/ansi.js40
1 files changed, 38 insertions, 2 deletions
diff --git a/util/ansi.js b/util/ansi.js
index f3f4cbe..c796a2e 100644
--- a/util/ansi.js
+++ b/util/ansi.js
@@ -137,6 +137,12 @@ const ansi = {
 
     for (let charI = 0; charI < text.length; charI++) {
       if (text[charI] === ESC) {
+        if (false) {
+          chars[getCursorIndex()] = {char: '%', attributes: []}
+          cursorCol++
+          continue
+        }
+
         charI++
 
         if (text[charI] !== '[') {
@@ -213,9 +219,39 @@ const ansi = {
 
         // SGR - Select Graphic Rendition
         if (text[charI] === 'm') {
-          for (let arg of args) {
+          const removeAttribute = attr => {
+            if (attributes.includes(attr)) {
+              attributes.splice(attributes.indexOf(attr), 1)
+            }
+          }
+
+          for (const arg of args) {
             if (arg === '0') {
               attributes.splice(0, attributes.length)
+            } else if (arg === '22') { // Neither bold nor faint
+              removeAttribute('1')
+              removeAttribute('2')
+            } else if (arg === '23') { // Neither italic nor Fraktur
+              removeAttribute('3')
+              removeAttribute('20')
+            } else if (arg === '24') { // Not underlined
+              removeAttribute('4')
+            } else if (arg === '25') { // Blink off
+              removeAttribute('5')
+            } else if (arg === '27') { // Inverse off
+              removeAttribute('7')
+            } else if (arg === '28') { // Conceal off
+              removeAttribute('8')
+            } else if (arg === '29') { // Not crossed out
+              removeAttribute('9')
+            } else if (arg === '39') { // Default foreground
+              for (let i = 0; i < 10; i++) {
+                removeAttribute('3' + i)
+              }
+            } else if (arg === '49') { // Default background
+              for (let i = 0; i < 10; i++) {
+                removeAttribute('4' + i)
+              }
             } else {
               attributes.push(arg)
             }
@@ -261,7 +297,7 @@ const ansi = {
 
     //let n = 1 // debug
 
-    for (let char of chars) {
+    for (const char of chars) {
       const newAttributes = (
         char.attributes.filter(attr => !(lastChar.attributes.includes(attr)))
       )