mirror of
https://github.com/gwenhael-le-moine/sway-patched-tray-menu.git
synced 2025-01-15 15:40:58 +01:00
Support specifying fewer than 5 colors
This doesn't work, I'm not sure why. The color structs definitely get changed but if you specify fewer than 5, it renders with the defaults.
This commit is contained in:
parent
1376de4f46
commit
02812a2e4d
2 changed files with 12 additions and 12 deletions
|
@ -250,7 +250,7 @@ static struct cmd_handler bar_handlers[] = {
|
|||
*/
|
||||
struct cmd_results *add_color(const char *name, char *buffer, const char *color) {
|
||||
int len = strlen(color);
|
||||
if (len != 7 && len != 9 ) {
|
||||
if (len != 7 && len != 9) {
|
||||
return cmd_results_new(CMD_INVALID, name, "Invalid color definition %s", color);
|
||||
}
|
||||
|
||||
|
|
|
@ -4,27 +4,27 @@
|
|||
|
||||
static struct cmd_results *parse_border_color(struct border_colors *border_colors, const char *cmd_name, int argc, char **argv) {
|
||||
struct cmd_results *error = NULL;
|
||||
if (argc != 5) {
|
||||
return cmd_results_new(CMD_INVALID, cmd_name, "Requires exactly five color values");
|
||||
if (argc < 3 || argc > 5) {
|
||||
return cmd_results_new(CMD_INVALID, cmd_name, "Requires between three and five color values");
|
||||
}
|
||||
|
||||
uint32_t colors[5];
|
||||
uint32_t *colors[5] = {
|
||||
&border_colors->border,
|
||||
&border_colors->background,
|
||||
&border_colors->text,
|
||||
&border_colors->indicator,
|
||||
&border_colors->child_border
|
||||
};
|
||||
int i;
|
||||
for (i = 0; i < 5; i++) {
|
||||
for (i = 0; i < argc; i++) {
|
||||
char buffer[10];
|
||||
error = add_color(cmd_name, buffer, argv[i]);
|
||||
if (error) {
|
||||
return error;
|
||||
}
|
||||
colors[i] = strtoul(buffer+1, NULL, 16);
|
||||
*colors[i] = strtoul(buffer + 1, NULL, 16);
|
||||
}
|
||||
|
||||
border_colors->border = colors[0];
|
||||
border_colors->background = colors[1];
|
||||
border_colors->text = colors[2];
|
||||
border_colors->indicator = colors[3];
|
||||
border_colors->child_border = colors[4];
|
||||
|
||||
return cmd_results_new(CMD_SUCCESS, NULL, NULL);
|
||||
}
|
||||
|
||||
|
|
Loading…
Reference in a new issue