aboutsummaryrefslogtreecommitdiffstats
path: root/shell/evolution-shell-component.c
diff options
context:
space:
mode:
Diffstat (limited to 'shell/evolution-shell-component.c')
-rw-r--r--shell/evolution-shell-component.c71
1 files changed, 69 insertions, 2 deletions
diff --git a/shell/evolution-shell-component.c b/shell/evolution-shell-component.c
index 63f5fb7254..0e28981ef6 100644
--- a/shell/evolution-shell-component.c
+++ b/shell/evolution-shell-component.c
@@ -61,6 +61,63 @@ enum {
static guint signals[LAST_SIGNAL] = { 0 };
+/* Helper functions. */
+
+/* Notice that, if passed a NULL pointer, this string will construct a
+ zero-element NULL-terminated string array instead of returning NULL itself
+ (i.e. it will return a pointer to a single g_malloc()ed NULL pointer). */
+static char **
+duplicate_null_terminated_string_array (char *array[])
+{
+ char **new;
+ int count;
+ int i;
+
+ if (array == NULL) {
+ count = 0;
+ } else {
+ for (count = 0; array[count] != NULL; count++)
+ ;
+ }
+
+ new = g_new (char *, count + 1);
+
+ for (i = 0; i < count; i++)
+ new[i] = g_strdup (array[i]);
+ new[count] = NULL;
+
+ return new;
+}
+
+/* The following will create a CORBA sequence of strings from the specified
+ * NULL-terminated array, without duplicating the strings. */
+static void
+fill_corba_sequence_from_null_terminated_string_array (CORBA_sequence_CORBA_string *corba_sequence,
+ char **array)
+{
+ int count;
+ int i;
+
+ g_assert (corba_sequence != NULL);
+ g_assert (array != NULL);
+
+ /* We won't be reallocating the strings, so we don't want them to be
+ freed when the sequence is freed. */
+ CORBA_sequence_set_release (corba_sequence, FALSE);
+
+ count = 0;
+ while (array[count] != NULL)
+ count++;
+
+ corba_sequence->_maximum = count;
+ corba_sequence->_length = count;
+ corba_sequence->_buffer = CORBA_sequence_CORBA_string_allocbuf (count);
+
+ for (i = 0; i < count; i++)
+ corba_sequence->_buffer[i] = (CORBA_char *) array[i];
+}
+
+
/* CORBA interface implementation. */
static GNOME_Evolution_FolderTypeList *
@@ -93,6 +150,11 @@ impl_ShellComponent__get_supported_types (PortableServer_Servant servant,
corba_folder_type = folder_type_list->_buffer + i;
corba_folder_type->name = CORBA_string_dup (folder_type->name);
corba_folder_type->icon_name = CORBA_string_dup (folder_type->icon_name);
+
+ fill_corba_sequence_from_null_terminated_string_array (& corba_folder_type->accepted_dnd_types,
+ folder_type->accepted_dnd_types);
+ fill_corba_sequence_from_null_terminated_string_array (& corba_folder_type->exported_dnd_types,
+ folder_type->exported_dnd_types);
}
return folder_type_list;
@@ -333,6 +395,9 @@ destroy (GtkObject *object)
g_free (folder_type->name);
g_free (folder_type->icon_name);
+ g_strfreev (folder_type->exported_dnd_types);
+ g_strfreev (folder_type->accepted_dnd_types);
+
g_free (folder_type);
}
g_list_free (priv->folder_types);
@@ -439,8 +504,10 @@ evolution_shell_component_construct (EvolutionShellComponent *shell_component,
continue;
new = g_new (EvolutionShellComponentFolderType, 1);
- new->name = g_strdup (folder_types[i].name);
- new->icon_name = g_strdup (folder_types[i].icon_name);
+ new->name = g_strdup (folder_types[i].name);
+ new->icon_name = g_strdup (folder_types[i].icon_name);
+ new->accepted_dnd_types = duplicate_null_terminated_string_array (folder_types[i].accepted_dnd_types);
+ new->exported_dnd_types = duplicate_null_terminated_string_array (folder_types[i].exported_dnd_types);
priv->folder_types = g_list_prepend (priv->folder_types, new);
}