diff options
author | June McEnroe <june@causal.agency> | 2019-02-25 16:12:41 -0500 |
---|---|---|
committer | June McEnroe <june@causal.agency> | 2019-02-25 16:12:41 -0500 |
commit | d85c1c3f9649608bc003d66a6e9d2c696188bf19 (patch) | |
tree | 76f5b3f4ee1a96030a9d5073b1922503b8c0d090 | |
parent | Add color to tags (diff) | |
download | catgirl-d85c1c3f9649608bc003d66a6e9d2c696188bf19.tar.gz catgirl-d85c1c3f9649608bc003d66a6e9d2c696188bf19.zip |
Update tag colors
This kind of incurs a lot of writes usually for no reason. The only place this matters is when cold-opening a /query. I wonder if there's a better way to do that.
-rw-r--r-- | tag.c | 8 | ||||
-rw-r--r-- | ui.c | 5 |
2 files changed, 10 insertions, 3 deletions
diff --git a/tag.c b/tag.c index 13f59d0..649ac49 100644 --- a/tag.c +++ b/tag.c @@ -45,11 +45,15 @@ struct Tag tagFind(const char *name) { struct Tag tagFor(const char *name, enum IRCColor color) { struct Tag tag = tagFind(name); - if (tag.id != TagNone.id) return tag; + if (tag.id != TagNone.id) { + tag.color = tags.color[tag.id] = color; + return tag; + } if (tags.len == TagsLen) return TagStatus; + size_t id = tags.len++; tags.name[id] = strdup(name); - if (!tags.name[id]) err(EX_OSERR, "strdup"); tags.color[id] = color; + if (!tags.name[id]) err(EX_OSERR, "strdup"); return (struct Tag) { id, tags.name[id], color }; } diff --git a/ui.c b/ui.c index ffb2916..7654e36 100644 --- a/ui.c +++ b/ui.c @@ -85,7 +85,10 @@ static void windowRemove(struct Window *win) { static struct Window *windowFor(struct Tag tag) { struct Window *win = windows.tag[tag.id]; - if (win) return win; + if (win) { + win->tag = tag; + return win; + } win = calloc(1, sizeof(*win)); if (!win) err(EX_OSERR, "calloc"); |