aboutsummaryrefslogtreecommitdiffstats
path: root/camel/gmime-content-field.c
diff options
context:
space:
mode:
Diffstat (limited to 'camel/gmime-content-field.c')
-rw-r--r--camel/gmime-content-field.c84
1 files changed, 60 insertions, 24 deletions
diff --git a/camel/gmime-content-field.c b/camel/gmime-content-field.c
index a86c7047ad..e37c319b55 100644
--- a/camel/gmime-content-field.c
+++ b/camel/gmime-content-field.c
@@ -23,44 +23,80 @@
#include <config.h>
#include "gmime-content-field.h"
-#include "gstring-util.h"
+/* #include "-util.h" */
#include "camel-log.h"
+/
-GMimeContentField *
-gmime_content_field_new (GString *type, GString *subtype)
+/**
+ * gmime_content_field_new: Creates a new GMimeContentField object
+ * @type: mime type
+ * @subtype: mime subtype
+ *
+ * Creates a GMimeContentField object and initialize it with
+ * a mime type and a mime subtype. For example,
+ * gmime_content_field_new ("application", "postcript");
+ * will create a content field with complete mime type
+ * "application/postscript"
+ *
+ * Return value: The newly created GMimeContentField object
+ **/
+void
+gmime_content_field_new (const gchar *type, const gchar *subtype)
{
GMimeContentField *ctf;
- ctf = g_new (GMimeContentField,1);
+ ctf = g_new (GMimeContentField, 1);
ctf->type = type;
ctf->subtype = subtype;
- ctf->parameters = g_hash_table_new(g_string_hash, g_string_equal_for_hash);
+ ctf->parameters = g_hash_table_new (g_str_hash, g_str_equal);
return ctf;
}
+/**
+ * gmime_content_field_set_parameter: set a parameter for a GMimeContentField object
+ * @content_field: content field
+ * @attribute: parameter name
+ * @value: paramteter value
+ *
+ * set a parameter (called attribute in RFC 2045) of a content field. Meaningfull
+ * or valid parameters name depend on the content type object. For example,
+ * gmime_content_field_set_parameter (cf, "charset", "us-ascii");
+ * will make sense for a "text/plain" content field but not for a
+ * "image/gif". This routine does not check parameter validuty.
+ **/
void
-gmime_content_field_set_parameter (GMimeContentField *content_field, GString *attribute, GString *value)
+gmime_content_field_set_parameter (GMimeContentField *content_field, const gchar *attribute, const gchar *value)
{
gboolean attribute_exists;
- GString *old_attribute;
- GString *old_value;
+ gchar *old_attribute;
+ gchar *old_value;
attribute_exists = g_hash_table_lookup_extended (content_field->parameters,
attribute,
(gpointer *) &old_attribute,
(gpointer *) &old_value);
+ /** CHECK THAT **/
if (attribute_exists) {
- g_string_assign(old_value, value->str);
- g_string_free (value, TRUE);
- g_string_free (attribute, TRUE);
- } else
- g_hash_table_insert (content_field->parameters, attribute, value);
+ g_string_free (old_value, TRUE);
+ g_string_free (old_attribute, TRUE);
+ }
+
+ g_hash_table_insert (content_field->parameters, attribute, value);
}
+/**
+ * _print_parameter: print a parameter/value pair to a stream as
+ * described in RFC 2045
+ * @name: name of the parameter
+ * @value: value of the parameter
+ * @user_data: CamelStream object to write the text to.
+ *
+ *
+ **/
static void
_print_parameter (gpointer name, gpointer value, gpointer user_data)
{
@@ -68,9 +104,9 @@ _print_parameter (gpointer name, gpointer value, gpointer user_data)
camel_stream_write_strings (stream,
"; \n ",
- ((GString *)name)->str,
+ (gchar *)name,
"=",
- ((GString *)value)->str,
+ (gchar *)value,
NULL);
}
@@ -87,9 +123,9 @@ gmime_content_field_write_to_stream (GMimeContentField *content_field, CamelStre
{
if (!content_field) return;
if ((content_field->type) && ((content_field->type)->str)) {
- camel_stream_write_strings (stream, "Content-Type: ", content_field->type->str, NULL);
- if ((content_field->subtype) && ((content_field->subtype)->str)) {
- camel_stream_write_strings (stream, "/", content_field->subtype->str, NULL);
+ camel_stream_write_strings (stream, "Content-Type: ", content_field->type, NULL);
+ if (content_field->subtype) {
+ camel_stream_write_strings (stream, "/", content_field->subtype, NULL);
}
/* print all parameters */
g_hash_table_foreach (content_field->parameters, _print_parameter, stream);
@@ -97,13 +133,13 @@ gmime_content_field_write_to_stream (GMimeContentField *content_field, CamelStre
}
}
-GString *
+gchar *
gmime_content_field_get_mime_type (GMimeContentField *content_field)
{
- GString *mime_type;
+ gchar *mime_type;
if (!content_field->type) return NULL;
- mime_type = g_string_clone (content_field->type);
+ mime_type = g_strdup (content_field->type);
if (content_field->subtype) {
g_string_append_c (mime_type, '/');
g_string_append_g_string (mime_type, content_field->subtype);
@@ -113,13 +149,13 @@ gmime_content_field_get_mime_type (GMimeContentField *content_field)
void
-gmime_content_field_construct_from_string (GMimeContentField *content_field, GString *string)
+gmime_content_field_construct_from_string (GMimeContentField *content_field, gchar *string)
{
gint first, len;
gchar *str;
gint i=0;
- GString *type, *subtype;
- GString *param_name, *param_value;
+ gchar *type, *subtype;
+ gchar *param_name, *param_value;
gboolean param_end;
CAMEL_LOG (TRACE, "Entering gmime_content_field_construct_from_string\n");