}
if (account->gen_msgid) {
- generate_msgid(buf, sizeof(buf));
+ gchar *addr = NULL;
+ if (account->msgid_with_addr) {
+ addr = account->address;
+ }
+ generate_msgid(buf, sizeof(buf), addr);
if (fprintf(fp, "Message-ID: <%s>\n", buf) < 0) {
fclose(fp);
}
}
done:
+ /* plugins may hook in here to work with the message view */
+ hooks_invoke(MESSAGE_VIEW_SHOW_DONE_HOOKLIST, messageview);
+
g_free(file);
return 0;
{
GSList *cur = msgview->mimeview->textview->uri_list;
GSList *newlist = NULL;
- GHashTable *uri_hashtable = g_hash_table_new(g_str_hash, g_str_equal);
+ GHashTable *uri_hashtable;
+ gchar *tmp;
+
+ uri_hashtable = g_hash_table_new_full(g_str_hash, g_str_equal,
+ (GDestroyNotify) g_free, NULL);
+
for (; cur; cur = cur->next) {
ClickableText *uri = (ClickableText *)cur->data;
if (uri->uri &&
!g_ascii_strncasecmp(uri->uri, "http:", 5) ||
!g_ascii_strncasecmp(uri->uri, "https:", 6)))
{
- if(g_hash_table_lookup(uri_hashtable, uri->uri))
+ tmp = g_utf8_strdown(uri->uri, -1);
+
+ if (g_hash_table_lookup(uri_hashtable, tmp)) {
+ g_free(tmp);
continue;
+ }
newlist = g_slist_prepend(newlist, uri);
- g_hash_table_insert(uri_hashtable, uri->uri,
- GUINT_TO_POINTER(g_str_hash(uri->uri)));
+ g_hash_table_insert(uri_hashtable, tmp,
+ GUINT_TO_POINTER(g_str_hash(tmp)));
}
}
newlist = g_slist_reverse(newlist);