aboutsummaryrefslogtreecommitdiffstats
diff options
context:
space:
mode:
-rw-r--r--mail/ChangeLog21
-rw-r--r--mail/em-folder-tree.c214
2 files changed, 145 insertions, 90 deletions
diff --git a/mail/ChangeLog b/mail/ChangeLog
index 230bbd67b4..e0678b7c31 100644
--- a/mail/ChangeLog
+++ b/mail/ChangeLog
@@ -1,3 +1,24 @@
+2004-06-22 Jeffrey Stedfast <fejj@novell.com>
+
+ * em-folder-tree.c (emft_maybe_expand_row): As toshok discovered,
+ gtk_tree_model_get() strdup's string arguments, *sigh*, so we need
+ to free them.
+ (tree_drag_data_delete): Same.
+ (tree_drag_data_get): Same.
+ (tree_drag_data_received): Same.
+ (emft_drop_target): Same
+ (em_folder_tree_get_selected_uris): Same.
+ (get_selected_uris_path_iterate): Same.
+ (emft_update_model_expanded_state): Same.
+ (emft_tree_row_expanded): Same.
+ (emft_tree_row_activated): Same.
+ (emft_popup_delete_response): Same.
+ (emft_popup_delete_folder): Same.
+ (emft_popup_rename_folder): Same.
+ (emft_popup_properties): Same.
+ (emft_tree_button_press): Same.
+ (emft_tree_selection_changed): Same.
+
2004-06-22 Chris Toshok <toshok@ximian.com>
* em-folder-tree.c (render_pixbuf): gtk_tree_model_get on a string
diff --git a/mail/em-folder-tree.c b/mail/em-folder-tree.c
index f1d5ea59ed..73b36104d4 100644
--- a/mail/em-folder-tree.c
+++ b/mail/em-folder-tree.c
@@ -263,7 +263,7 @@ render_pixbuf (GtkTreeViewColumn *column, GtkCellRenderer *renderer,
static gboolean initialised = FALSE;
GdkPixbuf *pixbuf = NULL;
gboolean is_store;
- char *path;
+ char *full_name;
if (!initialised) {
folder_icons[FOLDER_ICON_NORMAL] = e_icon_factory_get_icon ("stock_folder", E_ICON_SIZE_MENU);
@@ -274,24 +274,24 @@ render_pixbuf (GtkTreeViewColumn *column, GtkCellRenderer *renderer,
initialised = TRUE;
}
- gtk_tree_model_get (model, iter, COL_STRING_FULL_NAME, &path,
+ gtk_tree_model_get (model, iter, COL_STRING_FULL_NAME, &full_name,
COL_BOOL_IS_STORE, &is_store, -1);
- if (!is_store && path != NULL) {
- if (!g_ascii_strcasecmp (path, "Inbox"))
+ if (!is_store && full_name != NULL) {
+ if (!g_ascii_strcasecmp (full_name, "Inbox"))
pixbuf = folder_icons[FOLDER_ICON_INBOX];
- else if (!g_ascii_strcasecmp (path, "Outbox"))
+ else if (!g_ascii_strcasecmp (full_name, "Outbox"))
pixbuf = folder_icons[FOLDER_ICON_OUTBOX];
- else if (!strcmp (path, CAMEL_VTRASH_NAME))
+ else if (!strcmp (full_name, CAMEL_VTRASH_NAME))
pixbuf = folder_icons[FOLDER_ICON_TRASH];
- else if (!strcmp(path, CAMEL_VJUNK_NAME))
+ else if (!strcmp (full_name, CAMEL_VJUNK_NAME))
pixbuf = folder_icons[FOLDER_ICON_JUNK];
else
pixbuf = folder_icons[FOLDER_ICON_NORMAL];
}
g_object_set (renderer, "pixbuf", pixbuf, "visible", !is_store, NULL);
- g_free (path);
+ g_free (full_name);
}
static void
@@ -312,17 +312,17 @@ render_display_name (GtkTreeViewColumn *column, GtkCellRenderer *renderer,
bold = subdirs_contain_unread (model, iter);
}
- if (!is_store && unread)
+ if (!is_store && unread) {
display = g_strdup_printf ("%s (%u)", name, unread);
- else
- display = g_strdup (name);
+ g_free (name);
+ } else
+ display = name;
g_object_set (renderer, "text", display,
"weight", bold ? PANGO_WEIGHT_BOLD : PANGO_WEIGHT_NORMAL,
NULL);
g_free (display);
- g_free (name);
}
static gboolean
@@ -568,26 +568,24 @@ emft_maybe_expand_row (EMFolderTreeModel *model, GtkTreePath *tree_path, GtkTree
gboolean is_store;
CamelStore *store;
EAccount *account;
- char *path, *key;
+ char *full_name;
+ char *key;
gtk_tree_model_get ((GtkTreeModel *) model, iter,
- COL_STRING_FULL_NAME, &path,
+ COL_STRING_FULL_NAME, &full_name,
COL_POINTER_CAMEL_STORE, &store,
COL_BOOL_IS_STORE, &is_store,
-1);
- if (is_store)
- path = "";
-
si = g_hash_table_lookup (model->store_hash, store);
if ((account = mail_config_get_account_by_name (si->display_name))) {
- key = g_strdup_printf ("%s/%s", account->uid, path);
+ key = g_strdup_printf ("%s/%s", account->uid, full_name ? full_name : "");
} else if (CAMEL_IS_VEE_STORE (store)) {
/* vfolder store */
- key = g_strdup_printf ("vfolder/%s", path);
+ key = g_strdup_printf ("vfolder/%s", full_name ? full_name : "");
} else {
/* local store */
- key = g_strdup_printf ("local/%s", path);
+ key = g_strdup_printf ("local/%s", full_name ? full_name : "");
}
if (em_folder_tree_model_get_expanded (model, key)) {
@@ -595,6 +593,7 @@ emft_maybe_expand_row (EMFolderTreeModel *model, GtkTreePath *tree_path, GtkTree
gtk_tree_view_expand_row (emft->priv->treeview, tree_path, FALSE);
}
+ g_free (full_name);
g_free (key);
}
@@ -639,12 +638,12 @@ static void
tree_drag_data_delete(GtkWidget *widget, GdkDragContext *context, EMFolderTree *emft)
{
struct _EMFolderTreePrivate *priv = emft->priv;
+ char *full_name = NULL;
GtkTreePath *src_path;
gboolean is_store;
CamelStore *store;
CamelException ex;
GtkTreeIter iter;
- char *full_name;
if (!priv->drag_row || (src_path = gtk_tree_row_reference_get_path (priv->drag_row)))
return;
@@ -666,18 +665,19 @@ tree_drag_data_delete(GtkWidget *widget, GdkDragContext *context, EMFolderTree *
camel_exception_clear(&ex);
fail:
gtk_tree_path_free(src_path);
+ g_free (full_name);
}
static void
tree_drag_data_get(GtkWidget *widget, GdkDragContext *context, GtkSelectionData *selection, guint info, guint time, EMFolderTree *emft)
{
struct _EMFolderTreePrivate *priv = emft->priv;
+ char *full_name = NULL, *uri = NULL;
GtkTreePath *src_path;
CamelFolder *folder;
CamelStore *store;
CamelException ex;
GtkTreeIter iter;
- char *full_name, *uri;
if (!priv->drag_row || !(src_path = gtk_tree_row_reference_get_path(priv->drag_row)))
return;
@@ -705,7 +705,7 @@ tree_drag_data_get(GtkWidget *widget, GdkDragContext *context, GtkSelectionData
/* dragging to nautilus or something, probably */
if ((folder = camel_store_get_folder(store, full_name, 0, &ex))) {
GPtrArray *uids = camel_folder_get_uids(folder);
-
+
em_utils_selection_set_urilist(selection, folder, uids);
camel_folder_free_uids(folder, uids);
camel_object_unref(folder);
@@ -719,6 +719,8 @@ tree_drag_data_get(GtkWidget *widget, GdkDragContext *context, GtkSelectionData
camel_exception_clear(&ex);
fail:
gtk_tree_path_free(src_path);
+ g_free (full_name);
+ g_free (uri);
}
/* TODO: Merge the drop handling code/menu's into one spot using a popup target for details */
@@ -1007,7 +1009,7 @@ tree_drag_data_received(GtkWidget *widget, GdkDragContext *context, int x, int y
g_object_ref(context);
m->store = store;
camel_object_ref(store);
- m->full_name = g_strdup (full_name);
+ m->full_name = full_name;
m->action = context->action;
m->info = info;
@@ -1055,8 +1057,9 @@ static GdkAtom
emft_drop_target(EMFolderTree *emft, GdkDragContext *context, GtkTreePath *path)
{
struct _EMFolderTreePrivate *p = emft->priv;
- char *uri, *folder_path, *src_uri = NULL;
+ char *full_name = NULL, *uri = NULL, *src_uri = NULL;
CamelStore *local, *sstore, *dstore;
+ GdkAtom atom = GDK_NONE;
gboolean is_store;
GtkTreeIter iter;
GList *targets;
@@ -1067,7 +1070,7 @@ emft_drop_target(EMFolderTree *emft, GdkDragContext *context, GtkTreePath *path)
return GDK_NONE;
gtk_tree_model_get((GtkTreeModel *)p->model, &iter, COL_BOOL_IS_STORE, &is_store,
- COL_STRING_FULL_NAME, &folder_path,
+ COL_STRING_FULL_NAME, &full_name,
COL_POINTER_CAMEL_STORE, &dstore,
COL_STRING_URI, &uri, -1);
@@ -1076,32 +1079,34 @@ emft_drop_target(EMFolderTree *emft, GdkDragContext *context, GtkTreePath *path)
targets = context->targets;
/* Check for special destinations */
- if (uri && folder_path) {
+ if (uri && full_name) {
#if 0
/* only allow copying/moving folders (not messages) into the local Outbox */
- if (dstore == local && !strcmp (folder_path, "Outbox")) {
+ if (dstore == local && !strcmp (full_name, "Outbox")) {
GdkAtom xfolder;
xfolder = drop_atoms[DND_DROP_TYPE_FOLDER];
while (targets != NULL) {
- if (targets->data == (gpointer) xfolder)
- return xfolder;
+ if (targets->data == (gpointer) xfolder) {
+ atom = xfolder;
+ goto done;
+ }
targets = targets->next;
}
- return GDK_NONE;
+ goto done;
}
#endif
/* don't allow copying/moving into the UNMATCHED vfolder */
- if (!strncmp (uri, "vfolder:", 8) && !strcmp (folder_path, CAMEL_UNMATCHED_NAME))
- return GDK_NONE;
+ if (!strncmp (uri, "vfolder:", 8) && !strcmp (full_name, CAMEL_UNMATCHED_NAME))
+ goto done;
/* don't allow copying/moving into a vTrash/vJunk folder */
- if (!strcmp (folder_path, CAMEL_VTRASH_NAME)
- || !strcmp (folder_path, CAMEL_VJUNK_NAME))
- return GDK_NONE;
+ if (!strcmp (full_name, CAMEL_VTRASH_NAME)
+ || !strcmp (full_name, CAMEL_VJUNK_NAME))
+ goto done;
}
if (p->drag_row) {
@@ -1120,7 +1125,7 @@ emft_drop_target(EMFolderTree *emft, GdkDragContext *context, GtkTreePath *path)
|| (gtk_tree_path_is_ancestor(path, src_path)
&& gtk_tree_path_get_depth(path) == gtk_tree_path_get_depth(src_path)-1)) {
gtk_tree_path_free(src_path);
- return GDK_NONE;
+ goto done;
}
gtk_tree_path_free(src_path);
@@ -1147,19 +1152,21 @@ emft_drop_target(EMFolderTree *emft, GdkDragContext *context, GtkTreePath *path)
context->suggested_action = GDK_ACTION_COPY;
xfolder = drop_atoms[DND_DROP_TYPE_FOLDER];
while (targets != NULL) {
- if (targets->data == (gpointer) xfolder)
- return xfolder;
+ if (targets->data == (gpointer) xfolder) {
+ atom = xfolder;
+ goto done;
+ }
targets = targets->next;
}
- return GDK_NONE;
+ goto done;
}
/* don't allow copying/moving of the UNMATCHED vfolder */
if (!strcmp (url->protocol, "vfolder") && !strcmp (path, CAMEL_UNMATCHED_NAME)) {
camel_url_free (url);
- return GDK_NONE;
+ goto done;
}
/* don't allow copying/moving of any vTrash/vJunk folder nor maildir 'inbox' */
@@ -1168,7 +1175,7 @@ emft_drop_target(EMFolderTree *emft, GdkDragContext *context, GtkTreePath *path)
/* Dont allow drag from maildir 'inbox' */
|| strcmp(path, ".") == 0) {
camel_url_free(url);
- return GDK_NONE;
+ goto done;
}
}
camel_url_free(url);
@@ -1183,20 +1190,22 @@ emft_drop_target(EMFolderTree *emft, GdkDragContext *context, GtkTreePath *path)
xfolder = drop_atoms[DND_DROP_TYPE_FOLDER];
while (targets != NULL) {
- if (targets->data == (gpointer) xfolder)
- return xfolder;
+ if (targets->data == (gpointer) xfolder) {
+ atom = xfolder;
+ goto done;
+ }
targets = targets->next;
}
}
-
- return GDK_NONE;
+
+ goto done;
}
}
/* can't drag anything but a vfolder into a vfolder */
if (uri && strncmp(uri, "vfolder:", 8) == 0)
- return GDK_NONE;
+ goto done;
/* Now we either have a store or a normal folder */
@@ -1205,25 +1214,34 @@ emft_drop_target(EMFolderTree *emft, GdkDragContext *context, GtkTreePath *path)
xfolder = drop_atoms[DND_DROP_TYPE_FOLDER];
while (targets != NULL) {
- if (targets->data == (gpointer) xfolder)
- return xfolder;
+ if (targets->data == (gpointer) xfolder) {
+ atom = xfolder;
+ goto done;
+ }
targets = targets->next;
}
} else {
int i;
-
+
while (targets != NULL) {
for (i = 0; i < NUM_DROP_TYPES; i++) {
- if (targets->data == (gpointer) drop_atoms[i])
- return drop_atoms[i];
+ if (targets->data == (gpointer) drop_atoms[i]) {
+ atom = drop_atoms[i];
+ goto done;
+ }
}
targets = targets->next;
}
}
- return GDK_NONE;
+ done:
+
+ g_free (full_name);
+ g_free (uri);
+
+ return atom;
}
static gboolean
@@ -1484,25 +1502,25 @@ em_folder_tree_get_selected_uris (EMFolderTree *emft)
if (gtk_tree_model_get_iter(model, &iter, path)) {
char *uri;
-
+
gtk_tree_model_get(model, &iter, COL_STRING_URI, &uri, -1);
- list = g_list_append(list, g_strdup(uri));
+ list = g_list_prepend (list, uri);
}
gtk_tree_path_free(path);
}
g_list_free(rows);
-
- return list;
+
+ return g_list_reverse (list);
}
static void
get_selected_uris_path_iterate (GtkTreeModel *model, GtkTreePath *treepath, GtkTreeIter *iter, gpointer data)
{
GList **list = (GList **) data;
- char *path;
+ char *full_name;
- gtk_tree_model_get (model, iter, COL_STRING_FULL_NAME, &path, -1);
- *list = g_list_append (*list, g_strdup (path));
+ gtk_tree_model_get (model, iter, COL_STRING_FULL_NAME, &full_name, -1);
+ *list = g_list_append (*list, full_name);
}
GList *
@@ -1706,29 +1724,28 @@ emft_update_model_expanded_state (struct _EMFolderTreePrivate *priv, GtkTreeIter
gboolean is_store;
CamelStore *store;
EAccount *account;
- char *path, *key;
+ char *full_name;
+ char *key;
gtk_tree_model_get ((GtkTreeModel *) priv->model, iter,
- COL_STRING_FULL_NAME, &path,
+ COL_STRING_FULL_NAME, &full_name,
COL_POINTER_CAMEL_STORE, &store,
COL_BOOL_IS_STORE, &is_store,
-1);
- if (is_store && path == NULL)
- path = "";
-
si = g_hash_table_lookup (priv->model->store_hash, store);
if ((account = mail_config_get_account_by_name (si->display_name))) {
- key = g_strdup_printf ("%s/%s", account->uid, path);
+ key = g_strdup_printf ("%s/%s", account->uid, full_name ? full_name : "");
} else if (CAMEL_IS_VEE_STORE (store)) {
/* vfolder store */
- key = g_strdup_printf ("vfolder/%s", path);
+ key = g_strdup_printf ("vfolder/%s", full_name ? full_name : "");
} else {
/* local store */
- key = g_strdup_printf ("local/%s", path);
+ key = g_strdup_printf ("local/%s", full_name ? full_name : "");
}
em_folder_tree_model_set_expanded (priv->model, key, expanded);
+ g_free (full_name);
g_free (key);
}
@@ -1739,13 +1756,13 @@ emft_tree_row_expanded (GtkTreeView *treeview, GtkTreeIter *root, GtkTreePath *t
struct _EMFolderTreeGetFolderInfo *m;
GtkTreeModel *model;
CamelStore *store;
+ char *full_name;
gboolean load;
- char *path;
model = gtk_tree_view_get_model (treeview);
gtk_tree_model_get (model, root,
- COL_STRING_FULL_NAME, &path,
+ COL_STRING_FULL_NAME, &full_name,
COL_POINTER_CAMEL_STORE, &store,
COL_BOOL_LOAD_SUBDIRS, &load,
-1);
@@ -1754,6 +1771,7 @@ emft_tree_row_expanded (GtkTreeView *treeview, GtkTreeIter *root, GtkTreePath *t
if (!load) {
emft_queue_save_state (emft);
+ g_free (full_name);
return;
}
@@ -1763,7 +1781,7 @@ emft_tree_row_expanded (GtkTreeView *treeview, GtkTreeIter *root, GtkTreePath *t
m->store = store;
m->emft = emft;
g_object_ref(emft);
- m->top = g_strdup (path);
+ m->top = full_name;
m->flags = CAMEL_STORE_FOLDER_INFO_RECURSIVE;
m->select_uri = NULL;
@@ -1795,8 +1813,8 @@ emft_tree_row_activated (GtkTreeView *treeview, GtkTreePath *tree_path, GtkTreeV
{
struct _EMFolderTreePrivate *priv = emft->priv;
GtkTreeModel *model = (GtkTreeModel *) priv->model;
+ char *full_name, *uri;
GtkTreeIter iter;
- char *path, *uri;
guint32 flags;
if (!emft_select_func(NULL, model, tree_path, FALSE, emft))
@@ -1805,20 +1823,20 @@ emft_tree_row_activated (GtkTreeView *treeview, GtkTreePath *tree_path, GtkTreeV
if (!gtk_tree_model_get_iter (model, &iter, tree_path))
return;
- gtk_tree_model_get (model, &iter, COL_STRING_FULL_NAME, &path,
+ gtk_tree_model_get (model, &iter, COL_STRING_FULL_NAME, &full_name,
COL_STRING_URI, &uri, COL_UINT_FLAGS, &flags, -1);
g_free (priv->select_uri);
priv->select_uri = NULL;
g_free (priv->selected_uri);
- priv->selected_uri = g_strdup (uri);
+ priv->selected_uri = uri;
g_free (priv->selected_path);
- priv->selected_path = g_strdup (path);
+ priv->selected_path = full_name;
- g_signal_emit (emft, signals[FOLDER_SELECTED], 0, path, uri, flags);
- g_signal_emit (emft, signals[FOLDER_ACTIVATED], 0, path, uri);
+ g_signal_emit (emft, signals[FOLDER_SELECTED], 0, full_name, uri, flags);
+ g_signal_emit (emft, signals[FOLDER_ACTIVATED], 0, full_name, uri);
}
#if 0
@@ -2410,7 +2428,7 @@ emft_popup_delete_response (GtkWidget *dialog, guint response, EMFolderTree *emf
CamelStore *store;
CamelException ex;
GtkTreeIter iter;
- char *path;
+ char *full_name;
gtk_widget_destroy (dialog);
if (response != GTK_RESPONSE_OK)
@@ -2420,16 +2438,18 @@ emft_popup_delete_response (GtkWidget *dialog, guint response, EMFolderTree *emf
if (!emft_selection_get_selected (selection, &model, &iter))
return;
- gtk_tree_model_get (model, &iter, COL_STRING_FULL_NAME, &path,
+ gtk_tree_model_get (model, &iter, COL_STRING_FULL_NAME, &full_name,
COL_POINTER_CAMEL_STORE, &store, -1);
camel_exception_init (&ex);
- emft_popup_delete_folders (store, path, &ex);
+ emft_popup_delete_folders (store, full_name, &ex);
if (camel_exception_is_set (&ex)) {
e_error_run((GtkWindow *)gtk_widget_get_toplevel((GtkWidget *)emft),
- "mail:no-delete-folder", path, ex.desc, NULL);
+ "mail:no-delete-folder", full_name, ex.desc, NULL);
camel_exception_clear (&ex);
}
+
+ g_free (full_name);
}
static void
@@ -2447,7 +2467,8 @@ emft_popup_delete_folder (GtkWidget *item, EMFolderTree *emft)
if (!emft_selection_get_selected (selection, &model, &iter))
return;
- gtk_tree_model_get (model, &iter, COL_POINTER_CAMEL_STORE, &store, COL_STRING_FULL_NAME, &full_name, -1);
+ gtk_tree_model_get (model, &iter, COL_POINTER_CAMEL_STORE, &store,
+ COL_STRING_FULL_NAME, &full_name, -1);
local = mail_component_peek_local_store (NULL);
@@ -2460,6 +2481,7 @@ emft_popup_delete_folder (GtkWidget *item, EMFolderTree *emft)
"mail:ask-delete-folder", full_name, NULL);
g_signal_connect (dialog, "response", G_CALLBACK (emft_popup_delete_response), emft);
gtk_widget_show (dialog);
+ g_free (full_name);
}
static void
@@ -2490,6 +2512,9 @@ emft_popup_rename_folder (GtkWidget *item, EMFolderTree *emft)
if (store == local && is_special_local_folder (full_name)) {
e_error_run((GtkWindow *)gtk_widget_get_toplevel((GtkWidget *)emft),
"mail:no-rename-spethal-folder", full_name, NULL);
+ g_free (full_name);
+ g_free (name);
+ g_free (uri);
return;
}
@@ -2548,6 +2573,10 @@ emft_popup_rename_folder (GtkWidget *item, EMFolderTree *emft)
g_free (new_name);
}
+
+ g_free (full_name);
+ g_free (name);
+ g_free (uri);
}
@@ -2565,8 +2594,8 @@ emft_popup_properties (GtkWidget *item, EMFolderTree *emft)
return;
gtk_tree_model_get (model, &iter, COL_STRING_URI, &uri, -1);
-
- em_folder_properties_show(NULL, NULL, uri);
+ em_folder_properties_show (NULL, NULL, uri);
+ g_free (uri);
}
static EMPopupItem emft_popup_menu[] = {
@@ -2636,8 +2665,10 @@ emft_tree_button_press (GtkTreeView *treeview, GdkEventButton *event, EMFolderTr
/* Stores have full_name == NULL, otherwise its just a placeholder */
/* NB: This is kind of messy */
- if (!isstore && full_name == NULL)
+ if (!isstore && full_name == NULL) {
+ g_free (uri);
return FALSE;
+ }
/* TODO: em_popup_target_folder_new? */
if (isstore) {
@@ -2680,6 +2711,9 @@ emft_tree_button_press (GtkTreeView *treeview, GdkEventButton *event, EMFolderTr
gtk_menu_popup (menu, NULL, NULL, NULL, NULL, event->button, event->time);
}
+ g_free (full_name);
+ g_free (uri);
+
return TRUE;
}
@@ -2688,27 +2722,27 @@ static void
emft_tree_selection_changed (GtkTreeSelection *selection, EMFolderTree *emft)
{
struct _EMFolderTreePrivate *priv = emft->priv;
+ char *full_name, *uri;
GtkTreeModel *model;
GtkTreeIter iter;
- char *path, *uri;
guint32 flags;
if (!emft_selection_get_selected (selection, &model, &iter))
return;
- gtk_tree_model_get (model, &iter, COL_STRING_FULL_NAME, &path,
+ gtk_tree_model_get (model, &iter, COL_STRING_FULL_NAME, &full_name,
COL_STRING_URI, &uri, COL_UINT_FLAGS, &flags, -1);
g_free (priv->select_uri);
priv->select_uri = NULL;
g_free (priv->selected_uri);
- priv->selected_uri = g_strdup (uri);
+ priv->selected_uri = uri;
g_free (priv->selected_path);
- priv->selected_path = g_strdup (path);
+ priv->selected_path = full_name;
- g_signal_emit (emft, signals[FOLDER_SELECTED], 0, path, uri, flags);
+ g_signal_emit (emft, signals[FOLDER_SELECTED], 0, full_name, uri, flags);
}