mirror of
https://github.com/rkd77/elinks.git
synced 2025-01-03 14:57:44 -05:00
[colors] Unification
Still do not know why in 24bit are issues with menu.
This commit is contained in:
parent
085c2ebd95
commit
9e39ef5d1a
@ -96,8 +96,8 @@ get_bfu_color256_node(unsigned int node_number)
|
||||
return &entry->c256;
|
||||
}
|
||||
|
||||
unsigned char *
|
||||
get_bfu_background_color_true_node(unsigned int node_number)
|
||||
struct screen_char *
|
||||
get_bfu_true_color_node(unsigned int node_number)
|
||||
{
|
||||
struct bfu_color_entry *entry = node_entries[node_number];
|
||||
|
||||
@ -106,20 +106,7 @@ get_bfu_background_color_true_node(unsigned int node_number)
|
||||
entry->was_color24 = 1;
|
||||
}
|
||||
|
||||
return &entry->c24.c.color[3];
|
||||
}
|
||||
|
||||
unsigned char *
|
||||
get_bfu_foreground_color_true_node(unsigned int node_number)
|
||||
{
|
||||
struct bfu_color_entry *entry = node_entries[node_number];
|
||||
|
||||
if (!entry->was_color24) {
|
||||
set_term_color(&entry->c24, &entry->colors, 0, COLOR_MODE_TRUE_COLOR);
|
||||
entry->was_color24 = 1;
|
||||
}
|
||||
|
||||
return &entry->c24.c.color[0];
|
||||
return &entry->c24;
|
||||
}
|
||||
|
||||
|
||||
|
@ -32,8 +32,7 @@ struct screen_char *get_bfu_mono_node(unsigned int node_number);
|
||||
struct screen_char *get_bfu_color16_node(unsigned int node_number);
|
||||
struct screen_char *get_bfu_color88_node(unsigned int node_number);
|
||||
struct screen_char *get_bfu_color256_node(unsigned int node_number);
|
||||
unsigned char *get_bfu_background_color_true_node(unsigned int node_number);
|
||||
unsigned char *get_bfu_foreground_color_true_node(unsigned int node_number);
|
||||
struct screen_char *get_bfu_true_color_node(unsigned int node_number);
|
||||
|
||||
/** Cleanup after the BFU style cache
|
||||
*
|
||||
|
@ -445,6 +445,9 @@ static INIT_LIST_OF(struct screen_driver, active_screen_drivers);
|
||||
|
||||
static struct screen_char *get_mono_from_node(struct screen_char *ch);
|
||||
static struct screen_char *get_color16_from_node(struct screen_char *ch);
|
||||
static struct screen_char *get_color88_from_node(struct screen_char *ch);
|
||||
static struct screen_char *get_color256_from_node(struct screen_char *ch);
|
||||
static struct screen_char *get_true_color_from_node(struct screen_char *ch);
|
||||
|
||||
/** Set screen_driver.opt according to screen_driver.type and @a term_spec.
|
||||
* Other members of @a *driver need not have been initialized.
|
||||
@ -736,9 +739,9 @@ compare_fg_color_true(unsigned char *a, unsigned char *b)
|
||||
}
|
||||
|
||||
static inline void
|
||||
copy_color_true(unsigned char *a, unsigned char *b)
|
||||
copy_color_true(unsigned char *dest, unsigned char *src)
|
||||
{
|
||||
memcpy(a, b, 6);
|
||||
memcpy(dest, src, 6);
|
||||
}
|
||||
|
||||
static inline int
|
||||
@ -1273,56 +1276,23 @@ static const struct string color_true_seqs[] = {
|
||||
/* background: */ TERM_STRING("\033[48;2"),
|
||||
};
|
||||
|
||||
static unsigned char *
|
||||
get_true_background_color_from_node(struct screen_char *ch)
|
||||
static struct screen_char *
|
||||
get_true_color_from_node(struct screen_char *ch)
|
||||
{
|
||||
unsigned int node_number = ch->c.node_number;
|
||||
|
||||
if (node_number < 1024) {
|
||||
return get_bfu_background_color_true_node(node_number);
|
||||
return get_bfu_true_color_node(node_number);
|
||||
}
|
||||
|
||||
return &(ch)->c.color[3];
|
||||
return ch;
|
||||
}
|
||||
|
||||
static unsigned char *
|
||||
get_true_foreground_color_from_node(struct screen_char *ch)
|
||||
{
|
||||
unsigned int node_number = ch->c.node_number;
|
||||
|
||||
if (node_number < 1024) {
|
||||
return get_bfu_foreground_color_true_node(node_number);
|
||||
}
|
||||
|
||||
return &(ch)->c.color[0];
|
||||
}
|
||||
|
||||
static inline void add_char_true_color(struct string *screen, const struct string *seq, unsigned char *colors);
|
||||
|
||||
static inline void
|
||||
add_true_background_color(struct string *str, const struct string *seq, struct screen_char *ch)
|
||||
{
|
||||
if (ch->is_node) {
|
||||
add_char_true_color(str, &(seq)[1], get_true_background_color_from_node(ch));
|
||||
} else {
|
||||
add_char_true_color(str, &(seq)[1], &(ch)->c.color[3]);
|
||||
}
|
||||
}
|
||||
|
||||
static inline void
|
||||
add_true_foreground_color(struct string *str, const struct string *seq, struct screen_char *ch)
|
||||
{
|
||||
if (ch->is_node) {
|
||||
add_char_true_color(str, &(seq)[0], get_true_foreground_color_from_node(ch));
|
||||
} else {
|
||||
add_char_true_color(str, &(seq)[0], &(ch)->c.color[0]);
|
||||
}
|
||||
}
|
||||
|
||||
#if 0
|
||||
#define add_true_background_color(str, seq, chr) add_char_true_color(str, &(seq)[1], &(chr)->c.color[3])
|
||||
#define add_true_foreground_color(str, seq, chr) add_char_true_color(str, &(seq)[0], &(chr)->c.color[0])
|
||||
#endif
|
||||
|
||||
static inline void
|
||||
add_char_true_color(struct string *screen, const struct string *seq, unsigned char *colors)
|
||||
@ -1376,6 +1346,17 @@ static inline void
|
||||
add_char_true(struct string *screen, struct screen_driver *driver,
|
||||
struct screen_char *ch, struct screen_state *state)
|
||||
{
|
||||
struct screen_char copy;
|
||||
|
||||
if (ch->is_node) {
|
||||
struct screen_char *ch2 = get_true_color_from_node(ch);
|
||||
|
||||
copy = *ch;
|
||||
copy.is_node = 0;
|
||||
copy_color_true(copy.c.color, ch2->c.color);
|
||||
ch = ©
|
||||
}
|
||||
|
||||
unsigned char attr_delta = (ch->attr ^ state->attr);
|
||||
|
||||
if (
|
||||
|
Loading…
Reference in New Issue
Block a user