msgbuf: don't append a ';' unless there are existing tags
When both account-tag and server-time are present but the client doesn't have the first (i == 0) of these enabled. They will get an erroneous ';' after the '@'. Track whether or not there are tags present, and use this to determine whether to add the ';' or not. Also remove the extra function that loops over all of the tags by using this flag to handle the case where there are no tags being written.
This commit is contained in:
parent
6396c5da07
commit
57dd2c6a89
1 changed files with 8 additions and 18 deletions
|
@ -115,33 +115,22 @@ msgbuf_parse(struct MsgBuf *msgbuf, char *line)
|
||||||
return 0;
|
return 0;
|
||||||
}
|
}
|
||||||
|
|
||||||
static int
|
|
||||||
msgbuf_has_matching_tags(struct MsgBuf *msgbuf, unsigned int capmask)
|
|
||||||
{
|
|
||||||
for (size_t i = 0; i < msgbuf->n_tags; i++)
|
|
||||||
{
|
|
||||||
if ((msgbuf->tags[i].capmask & capmask) != 0)
|
|
||||||
return 1;
|
|
||||||
}
|
|
||||||
|
|
||||||
return 0;
|
|
||||||
}
|
|
||||||
|
|
||||||
static void
|
static void
|
||||||
msgbuf_unparse_tags(char *buf, size_t buflen, struct MsgBuf *msgbuf, unsigned int capmask)
|
msgbuf_unparse_tags(char *buf, size_t buflen, struct MsgBuf *msgbuf, unsigned int capmask)
|
||||||
{
|
{
|
||||||
if (!msgbuf_has_matching_tags(msgbuf, capmask))
|
bool has_tags = false;
|
||||||
return;
|
|
||||||
|
|
||||||
*buf = '@';
|
|
||||||
|
|
||||||
for (size_t i = 0; i < msgbuf->n_tags; i++)
|
for (size_t i = 0; i < msgbuf->n_tags; i++)
|
||||||
{
|
{
|
||||||
if ((msgbuf->tags[i].capmask & capmask) == 0)
|
if ((msgbuf->tags[i].capmask & capmask) == 0)
|
||||||
continue;
|
continue;
|
||||||
|
|
||||||
if (i != 0)
|
if (has_tags) {
|
||||||
rb_strlcat(buf, ";", buflen);
|
rb_strlcat(buf, ";", buflen);
|
||||||
|
} else {
|
||||||
|
*buf = '@';
|
||||||
|
has_tags = true;
|
||||||
|
}
|
||||||
|
|
||||||
rb_strlcat(buf, msgbuf->tags[i].key, buflen);
|
rb_strlcat(buf, msgbuf->tags[i].key, buflen);
|
||||||
|
|
||||||
|
@ -153,7 +142,8 @@ msgbuf_unparse_tags(char *buf, size_t buflen, struct MsgBuf *msgbuf, unsigned in
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
rb_strlcat(buf, " ", buflen);
|
if (has_tags)
|
||||||
|
rb_strlcat(buf, " ", buflen);
|
||||||
}
|
}
|
||||||
|
|
||||||
void
|
void
|
||||||
|
|
Loading…
Reference in a new issue