mirror of
https://github.com/SerenityOS/serenity.git
synced 2025-01-25 19:02:07 -05:00
99033876ec
Previously, we converted colors to their RGB values immediately when they were set. This meant that their semantic meaning was lost, we could not tell a precise RGB value apart from a named/indexed color. The new way of storing colors will allow us to retain this information, so we can change a color scheme on the fly, and previously emitted text will also be affected.
66 lines
1.8 KiB
C++
66 lines
1.8 KiB
C++
/*
|
|
* Copyright (c) 2018-2020, Andreas Kling <kling@serenityos.org>
|
|
*
|
|
* SPDX-License-Identifier: BSD-2-Clause
|
|
*/
|
|
|
|
#pragma once
|
|
|
|
#include <AK/Noncopyable.h>
|
|
#include <AK/String.h>
|
|
#include <AK/Vector.h>
|
|
#include <LibVT/Color.h>
|
|
#include <LibVT/XtermColors.h>
|
|
|
|
namespace VT {
|
|
|
|
struct Attribute {
|
|
Attribute() { reset(); }
|
|
|
|
static constexpr Color default_foreground_color = Color::named(Color::ANSIColor::DefaultForeground);
|
|
static constexpr Color default_background_color = Color::named(Color::ANSIColor::DefaultBackground);
|
|
|
|
void reset()
|
|
{
|
|
foreground_color = default_foreground_color;
|
|
background_color = default_background_color;
|
|
flags = Flags::NoAttributes;
|
|
}
|
|
Color foreground_color { default_foreground_color };
|
|
Color background_color { default_background_color };
|
|
|
|
Color effective_background_color() const { return flags & Negative ? foreground_color : background_color; }
|
|
Color effective_foreground_color() const { return flags & Negative ? background_color : foreground_color; }
|
|
|
|
#ifndef KERNEL
|
|
String href;
|
|
String href_id;
|
|
#endif
|
|
|
|
enum Flags : u8 {
|
|
NoAttributes = 0x00,
|
|
Bold = 0x01,
|
|
Italic = 0x02,
|
|
Underline = 0x04,
|
|
Negative = 0x08,
|
|
Blink = 0x10,
|
|
Touched = 0x20,
|
|
};
|
|
|
|
bool is_untouched() const { return !(flags & Touched); }
|
|
|
|
// TODO: it would be really nice if we had a helper for enums that
|
|
// exposed bit ops for class enums...
|
|
u8 flags = Flags::NoAttributes;
|
|
|
|
bool operator==(const Attribute& other) const
|
|
{
|
|
return foreground_color == other.foreground_color && background_color == other.background_color && flags == other.flags;
|
|
}
|
|
bool operator!=(const Attribute& other) const
|
|
{
|
|
return !(*this == other);
|
|
}
|
|
};
|
|
|
|
}
|