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