aboutsummaryrefslogtreecommitdiffstats
path: root/composer/e-msg-composer.c
diff options
context:
space:
mode:
Diffstat (limited to 'composer/e-msg-composer.c')
-rw-r--r--composer/e-msg-composer.c45
1 files changed, 25 insertions, 20 deletions
diff --git a/composer/e-msg-composer.c b/composer/e-msg-composer.c
index 03c3a752f7..ee61dd1357 100644
--- a/composer/e-msg-composer.c
+++ b/composer/e-msg-composer.c
@@ -2983,24 +2983,21 @@ e_msg_composer_new_from_url (const char *url_in)
EDestination **tov, **ccv, **bccv;
char *subject = NULL, *body = NULL;
const char *p, *header;
+ char *content;
int len, clen;
- char *url, *content;
-
g_return_val_if_fail (g_strncasecmp (url_in, "mailto:", 7) == 0, NULL);
composer = e_msg_composer_new ();
if (!composer)
return NULL;
-
- url = g_strdup (url_in);
- camel_url_decode (url);
-
- /* Parse recipients (everything after ':' until '?' or eos. */
- p = url + 7;
+
+ /* Parse recipients (everything after ':' until '?' or eos). */
+ p = url_in + 7;
len = strcspn (p, "?");
if (len) {
content = g_strndup (p, len);
+ camel_url_decode (content);
to = add_recipients (to, content, FALSE);
g_free (content);
}
@@ -3020,21 +3017,29 @@ e_msg_composer_new_from_url (const char *url_in)
p += len + 1;
clen = strcspn (p, "&");
+
content = g_strndup (p, clen);
camel_url_decode (content);
-
- if (!g_strncasecmp (header, "to", len))
+
+ if (!g_strncasecmp (header, "to", len)) {
to = add_recipients (to, content, FALSE);
- else if (!g_strncasecmp (header, "cc", len))
+ } else if (!g_strncasecmp (header, "cc", len)) {
cc = add_recipients (cc, content, FALSE);
- else if (!g_strncasecmp (header, "bcc", len))
+ } else if (!g_strncasecmp (header, "bcc", len)) {
bcc = add_recipients (bcc, content, FALSE);
- else if (!g_strncasecmp (header, "subject", len))
+ } else if (!g_strncasecmp (header, "subject", len)) {
+ g_free (subject);
subject = g_strdup (content);
- else if (!g_strncasecmp (header, "body", len))
+ } else if (!g_strncasecmp (header, "body", len)) {
+ g_free (body);
body = g_strdup (content);
+ } else {
+ /* add an arbitrary header */
+ e_msg_composer_add_header (composer, header, content);
+ }
g_free (content);
+
p += clen;
if (*p == '&') {
p++;
@@ -3043,25 +3048,25 @@ e_msg_composer_new_from_url (const char *url_in)
}
}
}
-
+
tov = e_destination_list_to_vector (to);
ccv = e_destination_list_to_vector (cc);
bccv = e_destination_list_to_vector (bcc);
-
+
g_list_free (to);
g_list_free (cc);
g_list_free (bcc);
-
+
hdrs = E_MSG_COMPOSER_HDRS (composer->hdrs);
-
+
e_msg_composer_hdrs_set_to (hdrs, tov);
e_msg_composer_hdrs_set_cc (hdrs, ccv);
e_msg_composer_hdrs_set_bcc (hdrs, bccv);
-
+
e_destination_freev (tov);
e_destination_freev (ccv);
e_destination_freev (bccv);
-
+
if (subject) {
e_msg_composer_hdrs_set_subject (hdrs, subject);
g_free (subject);