#define SENT_STRING _("Sent:")
#define TO_STRING _("To:")
#define SUBJECT_STRING _("Subject:")
+#define EMPTY_STRING ""
/*
* we need these regexps to find URLs in plain text e-mails
g_return_val_if_fail (text, NULL);
g_return_val_if_fail (content_type, NULL);
- g_return_val_if_fail (from, NULL);
cited = cite (sent_date, from);
g_return_val_if_fail (text, NULL);
g_return_val_if_fail (content_type, NULL);
- g_return_val_if_fail (from, NULL);
tmp = cite (sent_date, from);
retval = g_strdup_printf ("%s%s\n", tmp, text);
g_return_val_if_fail (text, NULL);
g_return_val_if_fail (content_type, NULL);
- g_return_val_if_fail (from, NULL);
g_return_val_if_fail (text, NULL);
- g_return_val_if_fail (to, NULL);
modest_text_utils_strftime (sent_str, 100, "%c", sent_date);
return g_strdup_printf (format,
FORWARD_STRING,
- FROM_STRING, from,
+ FROM_STRING, (from) ? from : EMPTY_STRING,
SENT_STRING, sent_str,
- TO_STRING, to,
- SUBJECT_STRING, subject,
+ TO_STRING, (to) ? to : EMPTY_STRING,
+ SUBJECT_STRING, (subject) ? subject : EMPTY_STRING,
text);
}
gsize
modest_text_utils_strftime(char *s, gsize max, const char *fmt, time_t timet)
{
- /* only since Gtk 2.10
- *
- *static GDate date;
- *g_date_set_time_t (&date, timet);
- *return g_date_strftime (s, max, fmt, (const GDate*) &date);
- */
-
- struct tm *time_tm;
- time_tm = localtime (&timet);
-
- return strftime (s, max, fmt, time_tm);
+ static GDate date;
+
+#if MODEST_PLATFORM_ID==1 /* gtk */
+ g_date_set_time_t (&date, timet);
+#elif MODEST_PLATFORM_ID==2 /* hildon (maemo) */
+ g_date_set_time (&date, (GTime) timet);
+#endif
+ return g_date_strftime (s, max, fmt, (const GDate*) &date);
}
gchar *
return g_string_free (html, FALSE);
}
+GSList *
+modest_text_utils_split_addresses_list (const gchar *addresses)
+{
+ gchar *current, *start, *last_blank;
+ GSList *result = NULL;
+
+ start = (gchar *) addresses;
+ current = start;
+ last_blank = start;
+
+ while (*current != '\0') {
+ if ((start == current)&&((*current == ' ')||(*current == ','))) {
+ start++;
+ last_blank = current;
+ } else if (*current == ',') {
+ gchar *new_address = NULL;
+ new_address = g_strndup (start, current - last_blank);
+ result = g_slist_prepend (result, new_address);
+ start = current + 1;
+ last_blank = start;
+ } else if (*current == '\"') {
+ if (current == start) {
+ current++;
+ start++;
+ }
+ while ((*current != '\"')&&(*current != '\0'))
+ current++;
+ }
+
+ current++;
+ }
+
+ if (start != current) {
+ gchar *new_address = NULL;
+ new_address = g_strndup (start, current - last_blank);
+ result = g_slist_prepend (result, new_address);
+ }
+
+ result = g_slist_reverse (result);
+ return result;
+
+}
+
+
/* ******************************************************************* */
/* ************************* UTILIY FUNCTIONS ************************ */
/* ******************************************************************* */
/* format sent_date */
modest_text_utils_strftime (sent_str, 100, "%c", sent_date);
- return g_strdup_printf (N_("On %s, %s wrote:\n"), sent_str, from);
+ return g_strdup_printf (N_("On %s, %s wrote:\n"),
+ sent_str,
+ (from) ? from : EMPTY_STRING);
}
/* the prefix is NULL: use the one that is already there */
repl = g_strdup_printf ("<a href=\"%s%s\">%s</a>",
- match->prefix ? match->prefix : "", url, url);
+ match->prefix ? match->prefix : EMPTY_STRING,
+ url, url);
/* replace the old thing with our hyperlink
* replacement thing */
modest_text_utils_validate_email_address (const gchar *email_address)
{
int count = 0;
- const gchar *c, *domain;
+ const gchar *c = NULL, *domain = NULL;
static gchar *rfc822_specials = "()<>@,;:\\\"[]";
/* first we validate the name portion (name@domain) */