1 #include "gmime-extra.h"
4 g_mime_stream_stdout_new()
6 GMimeStream *stream_stdout = NULL;
7 GMimeStream *stream_buffered = NULL;
9 stream_stdout = g_mime_stream_pipe_new (STDOUT_FILENO);
13 g_mime_stream_pipe_set_owner (GMIME_STREAM_PIPE (stream_stdout), FALSE);
15 stream_buffered = g_mime_stream_buffer_new (stream_stdout, GMIME_STREAM_BUFFER_BLOCK_WRITE);
17 g_object_unref (stream_stdout);
19 return stream_buffered;
23 * copy a glib string into a talloc context, and free it.
26 g_string_talloc_strdup (void *ctx, char *g_string)
28 char *new_str = talloc_strdup (ctx, g_string);
33 #if (GMIME_MAJOR_VERSION < 3)
36 g_mime_message_get_address_string (GMimeMessage *message, GMimeRecipientType type)
38 InternetAddressList *list = g_mime_message_get_recipients (message, type);
39 return internet_address_list_to_string (list, 0);
42 inline InternetAddressList *
43 g_mime_message_get_addresses (GMimeMessage *message, GMimeRecipientType type)
45 return g_mime_message_get_recipients (message, type);
49 g_mime_message_get_date_string (void *ctx, GMimeMessage *message)
51 char *date = g_mime_message_get_date_as_string (message);
52 return g_string_talloc_strdup (ctx, date);
56 g_mime_message_get_from (GMimeMessage *message)
58 return internet_address_list_parse_string (g_mime_message_get_sender (message));
62 g_mime_message_get_from_string (GMimeMessage *message) {
63 return g_mime_message_get_sender (message);
67 g_mime_message_get_reply_to_list (GMimeMessage *message)
71 reply_to = g_mime_message_get_reply_to (message);
72 if (reply_to && *reply_to)
73 return internet_address_list_parse_string (reply_to);
79 * return talloc allocated reply-to string
82 g_mime_message_get_reply_to_string (void *ctx, GMimeMessage *message)
84 return talloc_strdup(ctx, g_mime_message_get_reply_to (message));
88 g_mime_signature_status_good (GMimeSignatureStatus status) {
89 return (status == GMIME_SIGNATURE_STATUS_GOOD);
93 g_mime_signature_status_bad (GMimeSignatureStatus status) {
94 return (status == GMIME_SIGNATURE_STATUS_BAD);
98 g_mime_signature_status_error (GMimeSignatureError error) {
99 return (error != GMIME_SIGNATURE_ERROR_NONE);
102 #else /* GMime >= 3.0 */
105 g_mime_message_get_address_string (GMimeMessage *message, GMimeAddressType type)
107 InternetAddressList *list = g_mime_message_get_addresses (message, type);
108 return internet_address_list_to_string (list, NULL, 0);
112 g_mime_message_get_date_string (void *ctx, GMimeMessage *message)
114 GDateTime* parsed_date = g_mime_message_get_date (message);
116 char *date = g_mime_utils_header_format_date (parsed_date);
117 return g_string_talloc_strdup (ctx, date);
119 return talloc_strdup(ctx, "Thu, 01 Jan 1970 00:00:00 +0000");
123 InternetAddressList *
124 g_mime_message_get_reply_to_list(GMimeMessage *message)
126 return g_mime_message_get_reply_to (message);
130 g_mime_message_get_from_string (GMimeMessage *message)
132 return g_mime_object_get_header (GMIME_OBJECT (message), "From");
136 g_mime_message_get_reply_to_string (void *ctx, GMimeMessage *message)
138 InternetAddressList *list = g_mime_message_get_reply_to (message);
139 return g_string_talloc_strdup (ctx, internet_address_list_to_string (list, NULL, 0));
143 g_mime_parser_set_scan_from (GMimeParser *parser, gboolean flag)
145 g_mime_parser_set_format (parser, flag ? GMIME_FORMAT_MBOX : GMIME_FORMAT_MESSAGE);
148 /* In GMime 3.0, status GOOD and VALID both imply something about the
149 * validity of the UIDs attached to the signing key. This forces us to
150 * use following somewhat relaxed definition of a "good" signature to
151 * preserve current notmuch semantics.
155 g_mime_signature_status_good (GMimeSignatureStatus status) {
156 return ((status & (GMIME_SIGNATURE_STATUS_RED | GMIME_SIGNATURE_STATUS_ERROR_MASK)) == 0);
160 g_mime_signature_status_bad (GMimeSignatureStatus status) {
161 return (status & GMIME_SIGNATURE_STATUS_RED);
165 g_mime_signature_status_error (GMimeSignatureStatus status) {
166 return (status & GMIME_SIGNATURE_STATUS_ERROR_MASK);