summaryrefslogtreecommitdiff
path: root/Libraries/LibLine
diff options
context:
space:
mode:
authorAnotherTest <ali.mpfard@gmail.com>2020-05-10 12:27:36 +0430
committerAndreas Kling <kling@serenityos.org>2020-05-10 10:23:05 +0200
commitc40fd3a902e238a4d6e2920ff874927b08ee1628 (patch)
tree1e203895c787411248a17840b4e7d37daa2b4fa7 /Libraries/LibLine
parent8487806ec01cd44e808cfc18ca7ee51aaecae533 (diff)
downloadserenity-c40fd3a902e238a4d6e2920ff874927b08ee1628.zip
LibLine: Support RGB colors
This also patches Userland/js.
Diffstat (limited to 'Libraries/LibLine')
-rw-r--r--Libraries/LibLine/Editor.cpp26
-rw-r--r--Libraries/LibLine/Style.h72
2 files changed, 68 insertions, 30 deletions
diff --git a/Libraries/LibLine/Editor.cpp b/Libraries/LibLine/Editor.cpp
index 438bca11a7..1e101acc97 100644
--- a/Libraries/LibLine/Editor.cpp
+++ b/Libraries/LibLine/Editor.cpp
@@ -545,7 +545,7 @@ String Editor::get_line(const String& prompt)
// only apply colour to the selection if something is *actually* added to the buffer
if (m_last_shown_suggestion_was_complete && index == current_suggestion_index) {
- vt_apply_style({ Style::Foreground(Style::Color::Blue) });
+ vt_apply_style({ Style::Foreground(Style::XtermColor::Blue) });
fflush(stdout);
}
@@ -973,15 +973,33 @@ Style Editor::find_applicable_style(size_t offset) const
return {};
}
+String Style::Background::to_vt_escape() const
+{
+ if (m_is_rgb) {
+ return String::format("\033[48;2;%d;%d;%dm", m_rgb_color[0], m_rgb_color[1], m_rgb_color[2]);
+ } else {
+ return String::format("\033[%dm", (u8)m_xterm_color + 40);
+ }
+}
+
+String Style::Foreground::to_vt_escape() const
+{
+ if (m_is_rgb) {
+ return String::format("\033[38;2;%d;%d;%dm", m_rgb_color[0], m_rgb_color[1], m_rgb_color[2]);
+ } else {
+ return String::format("\033[%dm", (u8)m_xterm_color + 30);
+ }
+}
+
void Editor::vt_apply_style(const Style& style)
{
printf(
- "\033[%d;%d;%d;%d;%dm",
+ "\033[%d;%d;%dm%s%s",
style.bold() ? 1 : 22,
style.underline() ? 4 : 24,
style.italic() ? 3 : 23,
- (int)style.foreground() + 30,
- (int)style.background() + 40);
+ style.background().to_vt_escape().characters(),
+ style.foreground().to_vt_escape().characters());
}
void Editor::vt_clear_lines(size_t count_above, size_t count_below)
diff --git a/Libraries/LibLine/Style.h b/Libraries/LibLine/Style.h
index cbd43f814b..f18f727f78 100644
--- a/Libraries/LibLine/Style.h
+++ b/Libraries/LibLine/Style.h
@@ -25,13 +25,15 @@
*/
#pragma once
+#include <AK/Types.h>
+#include <AK/Vector.h>
#include <stdlib.h>
namespace Line {
class Style {
public:
- enum class Color : int {
+ enum class XtermColor : int {
Default = 9,
Black = 0,
Red,
@@ -41,15 +43,6 @@ public:
Magenta,
Cyan,
White,
- // TODO: it appears that we do not support these SGR options
- BrightBlack = 60,
- BrightRed,
- BrightGreen,
- BrightYellow,
- BrightBlue,
- BrightMagenta,
- BrightCyan,
- BrightWhite,
};
struct UnderlineTag {
@@ -58,19 +51,46 @@ public:
};
struct ItalicTag {
};
- struct Background {
- explicit Background(Color color)
- : m_color(color)
+ struct Color {
+ explicit Color(XtermColor color)
+ : m_xterm_color(color)
+ , m_is_rgb(false)
{
}
- Color m_color;
+ Color(u8 r, u8 g, u8 b)
+ : m_rgb_color({ r, g, b })
+ , m_is_rgb(true)
+ {
+ }
+
+ XtermColor m_xterm_color { XtermColor::Default };
+ Vector<u8, 3> m_rgb_color;
+ bool m_is_rgb { false };
};
- struct Foreground {
- explicit Foreground(Color color)
- : m_color(color)
+
+ struct Background : public Color {
+ explicit Background(XtermColor color)
+ : Color(color)
{
}
- Color m_color;
+ Background(u8 r, u8 g, u8 b)
+ : Color(r, g, b)
+ {
+ }
+ String to_vt_escape() const;
+ };
+
+ struct Foreground : public Color {
+ explicit Foreground(XtermColor color)
+ : Color(color)
+ {
+ }
+ Foreground(u8 r, u8 g, u8 b)
+ : Color(r, g, b)
+ {
+ }
+
+ String to_vt_escape() const;
};
static constexpr UnderlineTag Underline {};
@@ -78,31 +98,31 @@ public:
static constexpr ItalicTag Italic {};
// prepare for the horror of templates
- template <typename T, typename... Rest>
+ template<typename T, typename... Rest>
Style(const T& style_arg, Rest... rest)
: Style(rest...)
{
set(style_arg);
}
- Style() {}
+ Style() { }
bool underline() const { return m_underline; }
bool bold() const { return m_bold; }
bool italic() const { return m_italic; }
- Color background() const { return m_background; }
- Color foreground() const { return m_foreground; }
+ Background background() const { return m_background; }
+ Foreground foreground() const { return m_foreground; }
void set(const ItalicTag&) { m_italic = true; }
void set(const BoldTag&) { m_bold = true; }
void set(const UnderlineTag&) { m_underline = true; }
- void set(const Background& bg) { m_background = bg.m_color; }
- void set(const Foreground& fg) { m_foreground = fg.m_color; }
+ void set(const Background& bg) { m_background = bg; }
+ void set(const Foreground& fg) { m_foreground = fg; }
private:
bool m_underline { false };
bool m_bold { false };
bool m_italic { false };
- Color m_background { Color::Default };
- Color m_foreground { Color::Default };
+ Background m_background { XtermColor::Default };
+ Foreground m_foreground { XtermColor::Default };
};
}