From 8050e311c1eb5e79da7bc1e4000e893cf2629991 Mon Sep 17 00:00:00 2001 From: Bertrand Guiheneuf Date: Mon, 14 Jun 1999 12:50:58 +0000 Subject: tmp sync. Does ot even compile svn path=/trunk/; revision=978 --- camel/camel-data-wrapper.h | 12 +++++------- camel/gmime-utils.c | 40 +++++++++++++++++++++++++++------------- camel/gmime-utils.h | 7 +++---- 3 files changed, 35 insertions(+), 24 deletions(-) diff --git a/camel/camel-data-wrapper.h b/camel/camel-data-wrapper.h index 7dc4be2cea..61a37d8444 100644 --- a/camel/camel-data-wrapper.h +++ b/camel/camel-data-wrapper.h @@ -57,9 +57,7 @@ typedef struct { GtkObjectClass parent_class; /* Virtual methods */ - void (*write_to_buffer) (CamelDataWrapper *data_wrapper, gchar *buffer); - void (*write_to_file) (CamelDataWrapper *data_wrapper, FILE *file); - void (*construct_from_buffer) (CamelDataWrapper *data_wrapper, gchar *buffer, guint size); + void (*write_to_stream) (CamelDataWrapper *data_wrapper, CamelStream stream); void (*construct_from_file) (CamelDataWrapper *data_wrapper, FILE *file, guint size); } CamelDataWrapperClass; @@ -71,10 +69,10 @@ GtkType camel_data_wrapper_get_type (void); /* public methods */ -void camel_data_wrapper_write_to_buffer(CamelDataWrapper *data_wrapper, gchar *buffer); -void camel_data_wrapper_write_to_file(CamelDataWrapper *data_wrapper, FILE *file); -void camel_data_wrapper_construct_from_buffer(CamelDataWrapper *data_wrapper, gchar *buffer, guint size); -void camel_data_wrapper_construct_from_file (CamelDataWrapper *data_wrapper, FILE *file, guint size); +void camel_data_wrapper_write_to_buffer (CamelDataWrapper *data_wrapper, gchar *buffer); +void camel_data_wrapper_write_to_stream (CamelDataWrapper *data_wrapper, CamelStream *stream); +void camel_data_wrapper_construct_from_buffer (CamelDataWrapper *data_wrapper, gchar *buffer, guint size); +void camel_data_wrapper_construct_from_file (CamelDataWrapper *data_wrapper, CamelStream *stream, guint size); #ifdef __cplusplus } diff --git a/camel/gmime-utils.c b/camel/gmime-utils.c index 591706adc6..ce605ade05 100644 --- a/camel/gmime-utils.c +++ b/camel/gmime-utils.c @@ -26,40 +26,52 @@ #include "gmime-utils.h" #include "gstring-util.h" #include "camel-log.h" +#include "camel-stream.h" void -gmime_write_header_pair_to_file (FILE* file, gchar* name, GString *value) +gmime_write_header_pair_to_stream (CamelStream *stream, gchar* name, GString *value) { g_assert(name); + g_assert(value); + g_assert(value->str); - if ((value) && (value->str)) - fprintf(file, "%s: %s\n", name, value->str); + GString *strtmp; + guint len; + + len = strlen (name) + strlen (value->str) +3; + /* 3 is for ": " and "\n" */ + strtmp = g_string_sized_new (len); + + sprintf(strtmp->str, "%s: %s\n", name, value->str); + camel_stream_write (stream, strtmp->str, len); + + g_string_free (strtmp, FALSE); } static void -_write_one_header_to_file (gpointer key, gpointer value, gpointer user_data) +_write_one_header_to_stream (gpointer key, gpointer value, gpointer user_data) { GString *header_name = (GString *)key; GString *header_value = (GString *)value; - FILE *file = (FILE *)user_data; + CamelStream *stream = (CamelStream *)user_data; if ( (header_name) && (header_name->str) && (header_value) && (header_value->str) ) - fprintf(file, "%s: %s\n", header_name->str, header_value->str); + gmime_write_header_pair_to_stream (stream, header_name->str, header_value); } void -write_header_table_to_file (FILE *file, GHashTable *header_table) +write_header_table_to_stream (CamelStream *stream, GHashTable *header_table) { g_hash_table_foreach (header_table, - _write_one_header_to_file, - (gpointer)file); + _write_one_header_to_stream, + (gpointer)stream); } void -write_header_with_glist_to_file (FILE *file, gchar *header_name, GList *header_values) +write_header_with_glist_to_stream (CamelStream *stream, gchar *header_name, GList *header_values) { GString *current; @@ -69,17 +81,19 @@ write_header_with_glist_to_file (FILE *file, gchar *header_name, GList *header_v gboolean first; fprintf(file, "%s: ", header_name); + camel_stream_write (stream, header_name, strlen (header_name) ); + camel_stream_write (stream, ": ", 2); first = TRUE; while (header_values) { current = (GString *)header_values->data; if ( (current) && (current->str) ) { - if (!first) fprintf(file, ", "); + if (!first) camel_stream_write (stream, ", ", 2); else first = FALSE; - fprintf(file, "%s", current->str); + camel_stream_write (stream, current->str, strlen (current->str)); } header_values = g_list_next(header_values); } - fprintf(file, "\n"); + camel_stream_write (stream, "\n", 1); } } diff --git a/camel/gmime-utils.h b/camel/gmime-utils.h index 428bb8afee..6ed47b816c 100644 --- a/camel/gmime-utils.h +++ b/camel/gmime-utils.h @@ -35,11 +35,10 @@ extern "C" { #include #include -void gmime_write_header_pair_to_file (FILE* file, gchar* name, GString *value); -void write_header_table_to_file (FILE *file, GHashTable *header_table); -void write_header_with_glist_to_file (FILE *file, gchar *header_name, GList *header_values); +void gmime_write_header_pair_to_stream (CamelStream *stream, gchar* name, GString *value); +void write_header_table_to_stream (CamelStream *stream, GHashTable *header_table); +void write_header_with_glist_to_stream (CamelStream *stream, gchar *header_name, GList *header_values); -GHashTable *get_header_table_from_file (FILE *file); GHashTable *get_header_table_from_stream (CamelStream *stream); -- cgit v1.2.3