From 13d4fde316c8281e3100017b4b8eca4fc0dfc925 Mon Sep 17 00:00:00 2001 From: default Date: Thu, 19 Dec 2024 10:05:11 +0100 Subject: Avoid adding repeated attachments. --- format.c | 52 ++++++++++++++++++++++++++++++++++++++-------------- 1 file changed, 38 insertions(+), 14 deletions(-) (limited to 'format.c') diff --git a/format.c b/format.c index d0b535d..12783ae 100644 --- a/format.c +++ b/format.c @@ -163,14 +163,26 @@ static xs_str *format_line(const char *line, xs_list **attach) const char *mime = xs_mime_by_ext(img_url); if (attach != NULL && xs_startswith(mime, "image/")) { - xs *d = xs_dict_new(); - - d = xs_dict_append(d, "mediaType", mime); - d = xs_dict_append(d, "url", img_url); - d = xs_dict_append(d, "name", alt_text); - d = xs_dict_append(d, "type", "Image"); - - *attach = xs_list_append(*attach, d); + const xs_dict *ad; + int add = 1; + + xs_list_foreach(*attach, ad) { + if (strcmp(xs_dict_get_def(ad, "url", ""), img_url) == 0) { + add = 0; + break; + } + } + + if (add) { + xs *d = xs_dict_new(); + + d = xs_dict_append(d, "mediaType", mime); + d = xs_dict_append(d, "url", img_url); + d = xs_dict_append(d, "name", alt_text); + d = xs_dict_append(d, "type", "Image"); + + *attach = xs_list_append(*attach, d); + } } else { xs *link = xs_fmt("%s", img_url, alt_text); @@ -191,14 +203,26 @@ static xs_str *format_line(const char *line, xs_list **attach) if (attach != NULL && xs_startswith(mime, "image/")) { /* if it's a link to an image, insert it as an attachment */ - xs *d = xs_dict_new(); + const xs_dict *ad; + int add = 1; + + xs_list_foreach(*attach, ad) { + if (strcmp(xs_dict_get_def(ad, "url", ""), v2) == 0) { + add = 0; + break; + } + } - d = xs_dict_append(d, "mediaType", mime); - d = xs_dict_append(d, "url", v2); - d = xs_dict_append(d, "name", ""); - d = xs_dict_append(d, "type", "Image"); + if (add) { + xs *d = xs_dict_new(); + + d = xs_dict_append(d, "mediaType", mime); + d = xs_dict_append(d, "url", v2); + d = xs_dict_append(d, "name", ""); + d = xs_dict_append(d, "type", "Image"); - *attach = xs_list_append(*attach, d); + *attach = xs_list_append(*attach, d); + } } else { xs *s1 = xs_fmt("%s", v2, u); -- cgit v1.2.3