From b09318f2bbd4898494462aee9b47669b045dfde3 Mon Sep 17 00:00:00 2001 From: Jeffrey Stedfast Date: Mon, 26 Jan 2004 21:16:01 +0000 Subject: Set priv->drag_row. 2004-01-26 Jeffrey Stedfast * em-folder-tree.c (tree_drag_begin): Set priv->drag_row. svn path=/trunk/; revision=24447 --- mail/ChangeLog | 7 ++++++- mail/em-folder-tree-model.c | 21 ++++++++++++++++----- mail/em-folder-tree.c | 18 ++++++++++++++++-- 3 files changed, 38 insertions(+), 8 deletions(-) (limited to 'mail') diff --git a/mail/ChangeLog b/mail/ChangeLog index 41096cfe35..b5ca55109a 100644 --- a/mail/ChangeLog +++ b/mail/ChangeLog @@ -1,5 +1,10 @@ +2004-01-26 Jeffrey Stedfast + + * em-folder-tree.c (tree_drag_begin): Set priv->drag_row. + 2004-01-26 Aaron Weber - * mail/default/C/Inbox: edited default message + + * mail/default/C/Inbox: edited default message 2004-01-26 Jeffrey Stedfast diff --git a/mail/em-folder-tree-model.c b/mail/em-folder-tree-model.c index ae078cbb6f..5811cb09ef 100644 --- a/mail/em-folder-tree-model.c +++ b/mail/em-folder-tree-model.c @@ -87,6 +87,7 @@ static GtkTargetEntry drop_types[] = { { "text/uri-list", 0, DND_DROP_TYPE_TEXT_URI_LIST }, }; +static GdkAtom drag_atoms[NUM_DRAG_TYPES]; static GdkAtom drop_atoms[NUM_DROP_TYPES]; @@ -173,6 +174,9 @@ em_folder_tree_model_class_init (EMFolderTreeModelClass *klass) G_TYPE_POINTER, G_TYPE_POINTER); + for (i = 0; i < NUM_DRAG_TYPES; i++) + drag_atoms[i] = gdk_atom_intern (drag_types[i].target, FALSE); + for (i = 0; i < NUM_DROP_TYPES; i++) drop_atoms[i] = gdk_atom_intern (drop_types[i].target, FALSE); } @@ -1155,7 +1159,7 @@ em_folder_tree_model_drag_data_received (EMFolderTreeModel *model, GtkTreePath * /* copy or move (aka rename) a folder */ drop_folder (folder, selection, move, &ex); *moved = move; - d(printf ("\t* dropped a x-folder\n")); + d(printf ("\t* dropped a x-folder ('%s' into '%s')\n", selection->data, full_name)); break; case DND_DROP_TYPE_MESSAGE_RFC822: /* import a message/rfc822 stream */ @@ -1312,7 +1316,7 @@ drag_text_uri_list (CamelFolder *src, GtkSelectionData *selection, CamelExceptio /* replace "mbox:" with "file:" */ memcpy (url->str, "file", 4); g_string_append (url, "\r\n"); - gtk_selection_data_set (selection, selection->target, 8, url->str, url->len); + gtk_selection_data_set (selection, drag_atoms[DND_DRAG_TYPE_TEXT_URI_LIST], 8, url->str, url->len); } camel_folder_free_uids (src, uids); @@ -1331,8 +1335,10 @@ em_folder_tree_model_drag_data_get (EMFolderTreeModel *model, GtkTreePath *src_p GtkTreeIter iter; char *path, *uri; - if (!gtk_tree_model_get_iter ((GtkTreeModel *) model, &iter, src_path)) + if (!gtk_tree_model_get_iter ((GtkTreeModel *) model, &iter, src_path)) { + printf ("model_drag_data_get failed to get iter\n"); return FALSE; + } gtk_tree_model_get ((GtkTreeModel *) model, &iter, COL_POINTER_CAMEL_STORE, &store, @@ -1340,8 +1346,10 @@ em_folder_tree_model_drag_data_get (EMFolderTreeModel *model, GtkTreePath *src_p COL_STRING_URI, &uri, -1); /* make sure user isn't try to drag on a placeholder row */ - if (path == NULL) + if (path == NULL) { + printf ("model_drag_data_get failed to get path\n"); return FALSE; + } full_name = path[0] == '/' ? path + 1 : path; @@ -1350,11 +1358,13 @@ em_folder_tree_model_drag_data_get (EMFolderTreeModel *model, GtkTreePath *src_p switch (info) { case DND_DRAG_TYPE_FOLDER: /* dragging to a new location in the folder tree */ - gtk_selection_data_set (selection, selection->target, 8, uri, strlen (uri) + 1); + gtk_selection_data_set (selection, drag_atoms[info], 8, uri, strlen (uri) + 1); + printf ("model_drag_data_get setting x-folder data\n"); break; case DND_DRAG_TYPE_TEXT_URI_LIST: /* dragging to nautilus or something, probably */ if ((folder = camel_store_get_folder (store, full_name, 0, &ex))) { + printf ("model_drag_data_get setting text/uri-list data\n"); drag_text_uri_list (folder, selection, &ex); camel_object_unref (folder); } @@ -1364,6 +1374,7 @@ em_folder_tree_model_drag_data_get (EMFolderTreeModel *model, GtkTreePath *src_p } if (camel_exception_is_set (&ex)) { + printf ("model_drag_data_get failed: %s\n", ex.desc); camel_exception_clear (&ex); return FALSE; } diff --git a/mail/em-folder-tree.c b/mail/em-folder-tree.c index 0ffc95b561..62b3deba2a 100644 --- a/mail/em-folder-tree.c +++ b/mail/em-folder-tree.c @@ -512,8 +512,23 @@ em_folder_tree_new_with_model (EMFolderTreeModel *model) static void tree_drag_begin (GtkWidget *widget, GdkDragContext *context, EMFolderTree *emft) { - /* FIXME: set an icon? */ + struct _EMFolderTreePrivate *priv = emft->priv; + GtkTreeSelection *selection; + GtkTreeModel *model; + GtkTreePath *path; + GtkTreeIter iter; + printf ("::drag-begin called\n"); + + selection = gtk_tree_view_get_selection ((GtkTreeView *) widget); + if (!gtk_tree_selection_get_selected (selection, &model, &iter)) + return; + + path = gtk_tree_model_get_path (model, &iter); + priv->drag_row = gtk_tree_row_reference_new (model, path); + gtk_tree_path_free (path); + + /* FIXME: set a drag icon? */ } static void @@ -590,7 +605,6 @@ tree_drag_drop (GtkWidget *widget, GdkDragContext *context, int x, int y, guint } gtk_tree_path_free (path); - widget = gtk_drag_get_source_widget (context); gtk_drag_get_data (widget, context, target, time); return TRUE; -- cgit v1.2.3