mirror of
https://github.com/tmux/tmux.git
synced 2025-12-13 00:56:03 +00:00
Improve code readability in colour_palette_get and colour_palette_set.
GitHub issue 4730 from Pavel Roskin.
This commit is contained in:
27
colour.c
27
colour.c
@@ -1082,22 +1082,22 @@ colour_palette_free(struct colour_palette *p)
|
||||
|
||||
/* Get a colour from a palette. */
|
||||
int
|
||||
colour_palette_get(struct colour_palette *p, int c)
|
||||
colour_palette_get(struct colour_palette *p, int n)
|
||||
{
|
||||
if (p == NULL)
|
||||
return (-1);
|
||||
|
||||
if (c >= 90 && c <= 97)
|
||||
c = 8 + c - 90;
|
||||
else if (c & COLOUR_FLAG_256)
|
||||
c &= ~COLOUR_FLAG_256;
|
||||
else if (c >= 8)
|
||||
if (n >= 90 && n <= 97)
|
||||
n = 8 + n - 90;
|
||||
else if (n & COLOUR_FLAG_256)
|
||||
n &= ~COLOUR_FLAG_256;
|
||||
else if (n >= 8)
|
||||
return (-1);
|
||||
|
||||
if (p->palette != NULL && p->palette[c] != -1)
|
||||
return (p->palette[c]);
|
||||
if (p->default_palette != NULL && p->default_palette[c] != -1)
|
||||
return (p->default_palette[c]);
|
||||
if (p->palette != NULL && p->palette[n] != -1)
|
||||
return (p->palette[n]);
|
||||
if (p->default_palette != NULL && p->default_palette[n] != -1)
|
||||
return (p->default_palette[n]);
|
||||
return (-1);
|
||||
}
|
||||
|
||||
@@ -1107,15 +1107,14 @@ colour_palette_set(struct colour_palette *p, int n, int c)
|
||||
{
|
||||
u_int i;
|
||||
|
||||
if (p == NULL || n > 255)
|
||||
if (p == NULL || n < 0 || n > 255)
|
||||
return (0);
|
||||
|
||||
if (c == -1 && p->palette == NULL)
|
||||
return (0);
|
||||
|
||||
if (c != -1 && p->palette == NULL) {
|
||||
if (p->palette == NULL)
|
||||
p->palette = xcalloc(256, sizeof *p->palette);
|
||||
if (p->palette == NULL) {
|
||||
p->palette = xcalloc(256, sizeof *p->palette);
|
||||
for (i = 0; i < 256; i++)
|
||||
p->palette[i] = -1;
|
||||
}
|
||||
|
||||
Reference in New Issue
Block a user