diff --git a/src/terminal/terminalframebuffer.cc b/src/terminal/terminalframebuffer.cc index 2751f3b7d..344b8749f 100644 --- a/src/terminal/terminalframebuffer.cc +++ b/src/terminal/terminalframebuffer.cc @@ -489,14 +489,20 @@ void Renditions::set_rendition( color_type num ) return; } - bool value = num < 9; + bool value = num < 10; switch ( num ) { - case 1: case 22: set_attribute(bold, value); break; + case 1: set_attribute(bold, value); break; + case 2: set_attribute(faint, value); break; + case 22: + set_attribute(bold, value); + set_attribute(faint, value); + break; case 3: case 23: set_attribute(italic, value); break; case 4: case 24: set_attribute(underlined, value); break; case 5: case 25: set_attribute(blink, value); break; case 7: case 27: set_attribute(inverse, value); break; case 8: case 28: set_attribute(invisible, value); break; + case 9: case 29: set_attribute(strikethrough, value); break; default: break; /* ignore unknown rendition */ } } @@ -526,11 +532,13 @@ std::string Renditions::sgr( void ) const ret.append( "\033[0" ); if ( get_attribute( bold ) ) ret.append( ";1" ); + if ( get_attribute( faint ) ) ret.append( ";2" ); if ( get_attribute( italic ) ) ret.append( ";3" ); if ( get_attribute( underlined ) ) ret.append( ";4" ); if ( get_attribute( blink ) ) ret.append( ";5" ); if ( get_attribute( inverse ) ) ret.append( ";7" ); if ( get_attribute( invisible ) ) ret.append( ";8" ); + if ( get_attribute( strikethrough ) ) ret.append( ";9" ); if ( foreground_color ) { if ( is_true_color( foreground_color ) ) { diff --git a/src/terminal/terminalframebuffer.h b/src/terminal/terminalframebuffer.h index de9386977..3ecd1e80a 100644 --- a/src/terminal/terminalframebuffer.h +++ b/src/terminal/terminalframebuffer.h @@ -53,7 +53,7 @@ namespace Terminal { class Renditions { public: - typedef enum { bold, faint, italic, underlined, blink, inverse, invisible, SIZE } attribute_type; + typedef enum { bold, faint, italic, underlined, blink, inverse, invisible, strikethrough, SIZE } attribute_type; private: static const uint64_t true_color_mask = 0x1000000; diff --git a/src/tests/emulation-attributes.test b/src/tests/emulation-attributes.test index e4ba2f3fe..c2e716ef1 100755 --- a/src/tests/emulation-attributes.test +++ b/src/tests/emulation-attributes.test @@ -110,6 +110,8 @@ baseline() test_true_color echo "Bold:" test_true_color 1 + echo "Faint:" + test_true_color 2 echo "Italic:" test_true_color 3 echo "Underline:" @@ -120,6 +122,8 @@ baseline() test_true_color 7 echo "Invisible:" test_true_color 8 + echo "Strikethrough:" + test_true_color 9 echo "Bold, italic and underline:" test_true_color 1 3 4 ;;