1 #include "gmime-extra.h"
5 g_mime_stream_stdout_new()
7 GMimeStream *stream_stdout = NULL;
8 GMimeStream *stream_buffered = NULL;
10 stream_stdout = g_mime_stream_pipe_new (STDOUT_FILENO);
14 g_mime_stream_pipe_set_owner (GMIME_STREAM_PIPE (stream_stdout), FALSE);
16 stream_buffered = g_mime_stream_buffer_new (stream_stdout, GMIME_STREAM_BUFFER_BLOCK_WRITE);
18 g_object_unref (stream_stdout);
20 return stream_buffered;
24 * copy a glib string into a talloc context, and free it.
27 g_string_talloc_strdup (void *ctx, char *g_string)
29 char *new_str = talloc_strdup (ctx, g_string);
35 g_mime_certificate_get_valid_userid (GMimeCertificate *cert)
37 /* output user id only if validity is FULL or ULTIMATE. */
38 const char *uid = g_mime_certificate_get_user_id (cert);
41 GMimeValidity validity = g_mime_certificate_get_id_validity (cert);
42 if (validity == GMIME_VALIDITY_FULL || validity == GMIME_VALIDITY_ULTIMATE)
48 g_mime_certificate_get_fpr16 (GMimeCertificate *cert) {
49 const char *fpr = g_mime_certificate_get_fingerprint (cert);
50 if (!fpr || strlen (fpr) < 16)
53 return fpr + (strlen (fpr) - 16);
57 g_mime_message_get_address_string (GMimeMessage *message, GMimeAddressType type)
59 InternetAddressList *list = g_mime_message_get_addresses (message, type);
60 return internet_address_list_to_string (list, NULL, 0);
64 g_mime_message_get_date_string (void *ctx, GMimeMessage *message)
66 GDateTime* parsed_date = g_mime_message_get_date (message);
68 char *date = g_mime_utils_header_format_date (parsed_date);
69 return g_string_talloc_strdup (ctx, date);
71 return talloc_strdup(ctx, "Thu, 01 Jan 1970 00:00:00 +0000");
76 g_mime_message_get_reply_to_list(GMimeMessage *message)
78 return g_mime_message_get_reply_to (message);
82 g_mime_message_get_from_string (GMimeMessage *message)
84 return g_mime_object_get_header (GMIME_OBJECT (message), "From");
88 g_mime_message_get_reply_to_string (void *ctx, GMimeMessage *message)
90 InternetAddressList *list = g_mime_message_get_reply_to (message);
91 return g_string_talloc_strdup (ctx, internet_address_list_to_string (list, NULL, 0));
95 g_mime_parser_set_scan_from (GMimeParser *parser, gboolean flag)
97 g_mime_parser_set_format (parser, flag ? GMIME_FORMAT_MBOX : GMIME_FORMAT_MESSAGE);
100 /* In GMime 3.0, status GOOD and VALID both imply something about the
101 * validity of the UIDs attached to the signing key. This forces us to
102 * use following somewhat relaxed definition of a "good" signature to
103 * preserve current notmuch semantics.
107 g_mime_signature_status_good (GMimeSignatureStatus status) {
108 return ((status & (GMIME_SIGNATURE_STATUS_RED | GMIME_SIGNATURE_STATUS_ERROR_MASK)) == 0);
112 g_mime_signature_status_bad (GMimeSignatureStatus status) {
113 return (status & GMIME_SIGNATURE_STATUS_RED);
117 g_mime_signature_status_error (GMimeSignatureStatus status) {
118 return (status & GMIME_SIGNATURE_STATUS_ERROR_MASK);
122 g_mime_utils_header_decode_date_unix (const char *date) {
123 GDateTime* parsed_date = g_mime_utils_header_decode_date (date);
127 ret = g_date_time_to_unix (parsed_date);
128 g_date_time_unref (parsed_date);