Renamed from create_shortcuts_model(). (struct _GtkFileChooserDefault):

2004-02-24  Federico Mena Quintero  <federico@ximian.com>

	* gtk/gtkfilechooserdefault.c (shortcuts_model_create): Renamed
	from create_shortcuts_model().
	(struct _GtkFileChooserDefault): Renamed the shortcuts_tree field
	to shortcuts_list.
	(shortcuts_list_create): Renamed from shortcuts_tree_create().
	(create_file_list): Enable the tree view as a model drag source.
	(create_folder_tree): Likewise.

	* gtk/gtkfilesystemmodel.c (_gtk_file_system_model_get_type):
	Register the drag source interface.
	(drag_source_iface_init): New function.
	(drag_source_row_draggable): New function.
	(drag_source_drag_data_get): New function.
This commit is contained in:
Federico Mena Quintero 2004-02-25 03:03:11 +00:00 committed by Federico Mena Quintero
parent e16a042908
commit 903e2de0c3
7 changed files with 194 additions and 21 deletions

View File

@ -1,3 +1,19 @@
2004-02-24 Federico Mena Quintero <federico@ximian.com>
* gtk/gtkfilechooserdefault.c (shortcuts_model_create): Renamed
from create_shortcuts_model().
(struct _GtkFileChooserDefault): Renamed the shortcuts_tree field
to shortcuts_list.
(shortcuts_list_create): Renamed from shortcuts_tree_create().
(create_file_list): Enable the tree view as a model drag source.
(create_folder_tree): Likewise.
* gtk/gtkfilesystemmodel.c (_gtk_file_system_model_get_type):
Register the drag source interface.
(drag_source_iface_init): New function.
(drag_source_row_draggable): New function.
(drag_source_drag_data_get): New function.
Tue Feb 24 19:12:07 2004 Owen Taylor <otaylor@redhat.com> Tue Feb 24 19:12:07 2004 Owen Taylor <otaylor@redhat.com>
* === Released 2.3.4 === * === Released 2.3.4 ===

View File

@ -1,3 +1,19 @@
2004-02-24 Federico Mena Quintero <federico@ximian.com>
* gtk/gtkfilechooserdefault.c (shortcuts_model_create): Renamed
from create_shortcuts_model().
(struct _GtkFileChooserDefault): Renamed the shortcuts_tree field
to shortcuts_list.
(shortcuts_list_create): Renamed from shortcuts_tree_create().
(create_file_list): Enable the tree view as a model drag source.
(create_folder_tree): Likewise.
* gtk/gtkfilesystemmodel.c (_gtk_file_system_model_get_type):
Register the drag source interface.
(drag_source_iface_init): New function.
(drag_source_row_draggable): New function.
(drag_source_drag_data_get): New function.
Tue Feb 24 19:12:07 2004 Owen Taylor <otaylor@redhat.com> Tue Feb 24 19:12:07 2004 Owen Taylor <otaylor@redhat.com>
* === Released 2.3.4 === * === Released 2.3.4 ===

View File

@ -1,3 +1,19 @@
2004-02-24 Federico Mena Quintero <federico@ximian.com>
* gtk/gtkfilechooserdefault.c (shortcuts_model_create): Renamed
from create_shortcuts_model().
(struct _GtkFileChooserDefault): Renamed the shortcuts_tree field
to shortcuts_list.
(shortcuts_list_create): Renamed from shortcuts_tree_create().
(create_file_list): Enable the tree view as a model drag source.
(create_folder_tree): Likewise.
* gtk/gtkfilesystemmodel.c (_gtk_file_system_model_get_type):
Register the drag source interface.
(drag_source_iface_init): New function.
(drag_source_row_draggable): New function.
(drag_source_drag_data_get): New function.
Tue Feb 24 19:12:07 2004 Owen Taylor <otaylor@redhat.com> Tue Feb 24 19:12:07 2004 Owen Taylor <otaylor@redhat.com>
* === Released 2.3.4 === * === Released 2.3.4 ===

View File

@ -1,3 +1,19 @@
2004-02-24 Federico Mena Quintero <federico@ximian.com>
* gtk/gtkfilechooserdefault.c (shortcuts_model_create): Renamed
from create_shortcuts_model().
(struct _GtkFileChooserDefault): Renamed the shortcuts_tree field
to shortcuts_list.
(shortcuts_list_create): Renamed from shortcuts_tree_create().
(create_file_list): Enable the tree view as a model drag source.
(create_folder_tree): Likewise.
* gtk/gtkfilesystemmodel.c (_gtk_file_system_model_get_type):
Register the drag source interface.
(drag_source_iface_init): New function.
(drag_source_row_draggable): New function.
(drag_source_drag_data_get): New function.
Tue Feb 24 19:12:07 2004 Owen Taylor <otaylor@redhat.com> Tue Feb 24 19:12:07 2004 Owen Taylor <otaylor@redhat.com>
* === Released 2.3.4 === * === Released 2.3.4 ===

View File

@ -1,3 +1,19 @@
2004-02-24 Federico Mena Quintero <federico@ximian.com>
* gtk/gtkfilechooserdefault.c (shortcuts_model_create): Renamed
from create_shortcuts_model().
(struct _GtkFileChooserDefault): Renamed the shortcuts_tree field
to shortcuts_list.
(shortcuts_list_create): Renamed from shortcuts_tree_create().
(create_file_list): Enable the tree view as a model drag source.
(create_folder_tree): Likewise.
* gtk/gtkfilesystemmodel.c (_gtk_file_system_model_get_type):
Register the drag source interface.
(drag_source_iface_init): New function.
(drag_source_row_draggable): New function.
(drag_source_drag_data_get): New function.
Tue Feb 24 19:12:07 2004 Owen Taylor <otaylor@redhat.com> Tue Feb 24 19:12:07 2004 Owen Taylor <otaylor@redhat.com>
* === Released 2.3.4 === * === Released 2.3.4 ===

View File

@ -118,7 +118,7 @@ struct _GtkFileChooserDefault
GtkWidget *tree_scrollwin; GtkWidget *tree_scrollwin;
GtkWidget *tree; GtkWidget *tree;
GtkWidget *shortcuts_scrollwin; GtkWidget *shortcuts_scrollwin;
GtkWidget *shortcuts_tree; GtkWidget *shortcuts_list;
GtkWidget *add_bookmark_button; GtkWidget *add_bookmark_button;
GtkWidget *remove_bookmark_button; GtkWidget *remove_bookmark_button;
GtkWidget *list_scrollwin; GtkWidget *list_scrollwin;
@ -159,7 +159,7 @@ enum {
static guint signals[LAST_SIGNAL] = { 0 }; static guint signals[LAST_SIGNAL] = { 0 };
/* Column numbers for the shortcuts tree. Keep these in sync with create_shortcuts_model() */ /* Column numbers for the shortcuts tree. Keep these in sync with shortcuts_model_create() */
enum { enum {
SHORTCUTS_COL_PIXBUF, SHORTCUTS_COL_PIXBUF,
SHORTCUTS_COL_NAME, SHORTCUTS_COL_NAME,
@ -620,7 +620,7 @@ shortcuts_unselect_all (GtkFileChooserDefault *impl)
{ {
GtkTreeSelection *selection; GtkTreeSelection *selection;
selection = gtk_tree_view_get_selection (GTK_TREE_VIEW (impl->shortcuts_tree)); selection = gtk_tree_view_get_selection (GTK_TREE_VIEW (impl->shortcuts_list));
gtk_tree_selection_unselect_all (selection); gtk_tree_selection_unselect_all (selection);
} }
@ -958,7 +958,7 @@ shortcuts_add_bookmarks (GtkFileChooserDefault *impl)
} }
static void static void
create_shortcuts_model (GtkFileChooserDefault *impl) shortcuts_model_create (GtkFileChooserDefault *impl)
{ {
if (impl->shortcuts_model) if (impl->shortcuts_model)
g_object_unref (impl->shortcuts_model); g_object_unref (impl->shortcuts_model);
@ -979,7 +979,7 @@ create_shortcuts_model (GtkFileChooserDefault *impl)
shortcuts_add_bookmarks (impl); shortcuts_add_bookmarks (impl);
} }
gtk_tree_view_set_model (GTK_TREE_VIEW (impl->shortcuts_tree), GTK_TREE_MODEL (impl->shortcuts_model)); gtk_tree_view_set_model (GTK_TREE_VIEW (impl->shortcuts_list), GTK_TREE_MODEL (impl->shortcuts_model));
} }
/* Callback used when the "New Folder" toolbar button is clicked */ /* Callback used when the "New Folder" toolbar button is clicked */
@ -1115,6 +1115,12 @@ create_folder_tree (GtkFileChooserDefault *impl)
impl->tree = gtk_tree_view_new (); impl->tree = gtk_tree_view_new ();
gtk_tree_view_set_headers_visible (GTK_TREE_VIEW (impl->tree), FALSE); gtk_tree_view_set_headers_visible (GTK_TREE_VIEW (impl->tree), FALSE);
gtk_tree_view_enable_model_drag_source (GTK_TREE_VIEW (impl->tree),
GDK_BUTTON1_MASK,
shortcuts_targets,
num_shortcuts_targets,
GDK_ACTION_COPY);
selection = gtk_tree_view_get_selection (GTK_TREE_VIEW (impl->tree)); selection = gtk_tree_view_get_selection (GTK_TREE_VIEW (impl->tree));
g_signal_connect (selection, "changed", g_signal_connect (selection, "changed",
G_CALLBACK (tree_selection_changed), impl); G_CALLBACK (tree_selection_changed), impl);
@ -1292,7 +1298,7 @@ remove_bookmark_button_clicked_cb (GtkButton *button,
gboolean removable; gboolean removable;
GError *error; GError *error;
selection = gtk_tree_view_get_selection (GTK_TREE_VIEW (impl->shortcuts_tree)); selection = gtk_tree_view_get_selection (GTK_TREE_VIEW (impl->shortcuts_list));
if (gtk_tree_selection_get_selected (selection, NULL, &iter)) if (gtk_tree_selection_get_selected (selection, NULL, &iter))
{ {
@ -1396,7 +1402,7 @@ bookmarks_check_remove_sensitivity (GtkFileChooserDefault *impl)
GtkTreeIter iter; GtkTreeIter iter;
gboolean removable = FALSE; gboolean removable = FALSE;
selection = gtk_tree_view_get_selection (GTK_TREE_VIEW (impl->shortcuts_tree)); selection = gtk_tree_view_get_selection (GTK_TREE_VIEW (impl->shortcuts_list));
if (gtk_tree_selection_get_selected (selection, NULL, &iter)) if (gtk_tree_selection_get_selected (selection, NULL, &iter))
gtk_tree_model_get (GTK_TREE_MODEL (impl->shortcuts_model), &iter, gtk_tree_model_get (GTK_TREE_MODEL (impl->shortcuts_model), &iter,
@ -1492,7 +1498,7 @@ shortcuts_selection_changed_cb (GtkTreeSelection *selection,
/* Creates the widgets for the shortcuts and bookmarks tree */ /* Creates the widgets for the shortcuts and bookmarks tree */
static GtkWidget * static GtkWidget *
shortcuts_tree_create (GtkFileChooserDefault *impl) shortcuts_list_create (GtkFileChooserDefault *impl)
{ {
GtkTreeSelection *selection; GtkTreeSelection *selection;
GtkTreeViewColumn *column; GtkTreeViewColumn *column;
@ -1509,16 +1515,16 @@ shortcuts_tree_create (GtkFileChooserDefault *impl)
/* Tree */ /* Tree */
impl->shortcuts_tree = gtk_tree_view_new (); impl->shortcuts_list = gtk_tree_view_new ();
gtk_tree_view_set_headers_visible (GTK_TREE_VIEW (impl->shortcuts_tree), FALSE); gtk_tree_view_set_headers_visible (GTK_TREE_VIEW (impl->shortcuts_list), FALSE);
gtk_drag_dest_set (impl->shortcuts_tree, gtk_drag_dest_set (impl->shortcuts_list,
GTK_DEST_DEFAULT_ALL, GTK_DEST_DEFAULT_ALL,
shortcuts_targets, shortcuts_targets,
num_shortcuts_targets, num_shortcuts_targets,
GDK_ACTION_COPY); GDK_ACTION_COPY);
selection = gtk_tree_view_get_selection (GTK_TREE_VIEW (impl->shortcuts_tree)); selection = gtk_tree_view_get_selection (GTK_TREE_VIEW (impl->shortcuts_list));
gtk_tree_selection_set_mode (selection, GTK_SELECTION_BROWSE); gtk_tree_selection_set_mode (selection, GTK_SELECTION_BROWSE);
gtk_tree_selection_set_select_function (selection, gtk_tree_selection_set_select_function (selection,
shortcuts_select_func, shortcuts_select_func,
@ -1527,18 +1533,18 @@ shortcuts_tree_create (GtkFileChooserDefault *impl)
g_signal_connect (selection, "changed", g_signal_connect (selection, "changed",
G_CALLBACK (shortcuts_selection_changed_cb), impl); G_CALLBACK (shortcuts_selection_changed_cb), impl);
g_signal_connect (impl->shortcuts_tree, "row-activated", g_signal_connect (impl->shortcuts_list, "row-activated",
G_CALLBACK (shortcuts_row_activated_cb), impl); G_CALLBACK (shortcuts_row_activated_cb), impl);
g_signal_connect (impl->shortcuts_tree, "drag-data-received", g_signal_connect (impl->shortcuts_list, "drag-data-received",
G_CALLBACK (shortcuts_drag_data_received_cb), impl); G_CALLBACK (shortcuts_drag_data_received_cb), impl);
gtk_container_add (GTK_CONTAINER (impl->shortcuts_scrollwin), impl->shortcuts_tree); gtk_container_add (GTK_CONTAINER (impl->shortcuts_scrollwin), impl->shortcuts_list);
gtk_widget_show (impl->shortcuts_tree); gtk_widget_show (impl->shortcuts_list);
/* Model */ /* Model */
create_shortcuts_model (impl); shortcuts_model_create (impl);
/* Column */ /* Column */
@ -1558,7 +1564,7 @@ shortcuts_tree_create (GtkFileChooserDefault *impl)
"text", SHORTCUTS_COL_NAME, "text", SHORTCUTS_COL_NAME,
NULL); NULL);
gtk_tree_view_append_column (GTK_TREE_VIEW (impl->shortcuts_tree), column); gtk_tree_view_append_column (GTK_TREE_VIEW (impl->shortcuts_list), column);
return impl->shortcuts_scrollwin; return impl->shortcuts_scrollwin;
} }
@ -1577,7 +1583,7 @@ shortcuts_pane_create (GtkFileChooserDefault *impl,
/* Shortcuts tree */ /* Shortcuts tree */
widget = shortcuts_tree_create (impl); widget = shortcuts_list_create (impl);
gtk_box_pack_start (GTK_BOX (vbox), widget, TRUE, TRUE, 0); gtk_box_pack_start (GTK_BOX (vbox), widget, TRUE, TRUE, 0);
/* Box for buttons */ /* Box for buttons */
@ -1637,6 +1643,12 @@ create_file_list (GtkFileChooserDefault *impl)
G_CALLBACK (list_row_activated), impl); G_CALLBACK (list_row_activated), impl);
gtk_widget_show (impl->list); gtk_widget_show (impl->list);
gtk_tree_view_enable_model_drag_source (GTK_TREE_VIEW (impl->list),
GDK_BUTTON1_MASK,
shortcuts_targets,
num_shortcuts_targets,
GDK_ACTION_COPY);
selection = gtk_tree_view_get_selection (GTK_TREE_VIEW (impl->list)); selection = gtk_tree_view_get_selection (GTK_TREE_VIEW (impl->list));
g_signal_connect (selection, "changed", g_signal_connect (selection, "changed",
G_CALLBACK (list_selection_changed), impl); G_CALLBACK (list_selection_changed), impl);

View File

@ -23,6 +23,7 @@
#include "gtkfilesystemmodel.h" #include "gtkfilesystemmodel.h"
#include "gtkfilesystem.h" #include "gtkfilesystem.h"
#include "gtkintl.h" #include "gtkintl.h"
#include "gtktreednd.h"
#include "gtktreemodel.h" #include "gtktreemodel.h"
typedef struct _GtkFileSystemModelClass GtkFileSystemModelClass; typedef struct _GtkFileSystemModelClass GtkFileSystemModelClass;
@ -91,6 +92,8 @@ static void gtk_file_system_model_iface_init (GtkTreeModelIface *iface);
static void gtk_file_system_model_init (GtkFileSystemModel *model); static void gtk_file_system_model_init (GtkFileSystemModel *model);
static void gtk_file_system_model_finalize (GObject *object); static void gtk_file_system_model_finalize (GObject *object);
static void drag_source_iface_init (GtkTreeDragSourceIface *iface);
static GtkTreeModelFlags gtk_file_system_model_get_flags (GtkTreeModel *tree_model); static GtkTreeModelFlags gtk_file_system_model_get_flags (GtkTreeModel *tree_model);
static gint gtk_file_system_model_get_n_columns (GtkTreeModel *tree_model); static gint gtk_file_system_model_get_n_columns (GtkTreeModel *tree_model);
static GType gtk_file_system_model_get_column_type (GtkTreeModel *tree_model, static GType gtk_file_system_model_get_column_type (GtkTreeModel *tree_model,
@ -125,6 +128,12 @@ static void gtk_file_system_model_ref_node (GtkTreeModel *tr
static void gtk_file_system_model_unref_node (GtkTreeModel *tree_model, static void gtk_file_system_model_unref_node (GtkTreeModel *tree_model,
GtkTreeIter *iter); GtkTreeIter *iter);
static gboolean drag_source_row_draggable (GtkTreeDragSource *drag_source,
GtkTreePath *path);
static gboolean drag_source_drag_data_get (GtkTreeDragSource *drag_source,
GtkTreePath *path,
GtkSelectionData *selection_data);
static FileModelNode *file_model_node_new (GtkFileSystemModel *model, static FileModelNode *file_model_node_new (GtkFileSystemModel *model,
const GtkFilePath *path); const GtkFilePath *path);
static void file_model_node_free (FileModelNode *node); static void file_model_node_free (FileModelNode *node);
@ -199,8 +208,15 @@ _gtk_file_system_model_get_type (void)
static const GInterfaceInfo file_system_info = static const GInterfaceInfo file_system_info =
{ {
(GInterfaceInitFunc) gtk_file_system_model_iface_init, /* interface_init */ (GInterfaceInitFunc) gtk_file_system_model_iface_init, /* interface_init */
NULL, /* interface_finalize */ NULL, /* interface_finalize */
NULL /* interface_data */ NULL /* interface_data */
};
static const GInterfaceInfo drag_source_info =
{
(GInterfaceInitFunc) drag_source_iface_init, /* interface_init */
NULL, /* interface_finalize */
NULL /* interface_data */
}; };
file_system_model_type = g_type_register_static (G_TYPE_OBJECT, file_system_model_type = g_type_register_static (G_TYPE_OBJECT,
@ -209,6 +225,9 @@ _gtk_file_system_model_get_type (void)
g_type_add_interface_static (file_system_model_type, g_type_add_interface_static (file_system_model_type,
GTK_TYPE_TREE_MODEL, GTK_TYPE_TREE_MODEL,
&file_system_info); &file_system_info);
g_type_add_interface_static (file_system_model_type,
GTK_TYPE_TREE_DRAG_SOURCE,
&drag_source_info);
} }
return file_system_model_type; return file_system_model_type;
@ -277,6 +296,14 @@ gtk_file_system_model_finalize (GObject *object)
G_OBJECT_CLASS (parent_class)->finalize (object); G_OBJECT_CLASS (parent_class)->finalize (object);
} }
static void
drag_source_iface_init (GtkTreeDragSourceIface *iface)
{
iface->row_draggable = drag_source_row_draggable;
iface->drag_data_get = drag_source_drag_data_get;
iface->drag_data_delete = NULL;
}
/* /*
* ******************** GtkTreeModel methods ******************** * ******************** GtkTreeModel methods ********************
*/ */
@ -565,6 +592,60 @@ gtk_file_system_model_unref_node (GtkTreeModel *tree_model,
iter->user_data); iter->user_data);
} }
static gboolean
drag_source_row_draggable (GtkTreeDragSource *drag_source,
GtkTreePath *path)
{
GtkFileSystemModel *model;
GtkTreeIter iter;
FileModelNode *node;
model = GTK_FILE_SYSTEM_MODEL (drag_source);
if (!gtk_file_system_model_get_iter (GTK_TREE_MODEL (model), &iter, path))
return FALSE;
if (!model->has_editable)
return TRUE;
node = iter.user_data;
return (node != model->roots);
}
static gboolean
drag_source_drag_data_get (GtkTreeDragSource *drag_source,
GtkTreePath *path,
GtkSelectionData *selection_data)
{
GtkFileSystemModel *model;
GtkTreeIter iter;
const GtkFilePath *file_path;
char *uri;
char *uris;
model = GTK_FILE_SYSTEM_MODEL (drag_source);
if (!gtk_file_system_model_get_iter (GTK_TREE_MODEL (model), &iter, path))
return FALSE;
file_path = _gtk_file_system_model_get_path (model, &iter);
g_assert (file_path != NULL);
uri = gtk_file_system_path_to_uri (model->file_system, file_path);
uris = g_strconcat (uri, "\r\n", NULL);
gtk_selection_data_set (selection_data,
gdk_atom_intern ("text/uri-list", FALSE),
8,
uris,
strlen (uris) + 1);
g_free (uri);
g_free (uris);
return TRUE;
}
/** /**
* _gtk_file_system_model_new: * _gtk_file_system_model_new:
* @file_system: an object implementing #GtkFileSystem * @file_system: an object implementing #GtkFileSystem