156 lines
		
	
	
		
			6.0 KiB
		
	
	
	
		
			C
		
	
	
	
	
	
			
		
		
	
	
			156 lines
		
	
	
		
			6.0 KiB
		
	
	
	
		
			C
		
	
	
	
	
	
| /* gtktreednd.h
 | |
|  * Copyright (C) 2001  Red Hat, Inc.
 | |
|  *
 | |
|  * This library is free software; you can redistribute it and/or
 | |
|  * modify it under the terms of the GNU Library General Public
 | |
|  * License as published by the Free Software Foundation; either
 | |
|  * version 2 of the License, or (at your option) any later version.
 | |
|  *
 | |
|  * This library is distributed in the hope that it will be useful,
 | |
|  * but WITHOUT ANY WARRANTY; without even the implied warranty of
 | |
|  * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.  See the GNU
 | |
|  * Library General Public License for more details.
 | |
|  *
 | |
|  * You should have received a copy of the GNU Library General Public
 | |
|  * License along with this library. If not, see <http://www.gnu.org/licenses/>.
 | |
|  */
 | |
| 
 | |
| #ifndef __GTK_TREE_DND_H__
 | |
| #define __GTK_TREE_DND_H__
 | |
| 
 | |
| #if !defined (__GTK_H_INSIDE__) && !defined (GTK_COMPILATION)
 | |
| #error "Only <gtk/gtk.h> can be included directly."
 | |
| #endif
 | |
| 
 | |
| #include <gtk/gtktreemodel.h>
 | |
| #include <gtk/gtkdnd.h>
 | |
| 
 | |
| G_BEGIN_DECLS
 | |
| 
 | |
| #define GTK_TYPE_TREE_DRAG_SOURCE            (gtk_tree_drag_source_get_type ())
 | |
| #define GTK_TREE_DRAG_SOURCE(obj)            (G_TYPE_CHECK_INSTANCE_CAST ((obj), GTK_TYPE_TREE_DRAG_SOURCE, GtkTreeDragSource))
 | |
| #define GTK_IS_TREE_DRAG_SOURCE(obj)         (G_TYPE_CHECK_INSTANCE_TYPE ((obj), GTK_TYPE_TREE_DRAG_SOURCE))
 | |
| #define GTK_TREE_DRAG_SOURCE_GET_IFACE(obj)  (G_TYPE_INSTANCE_GET_INTERFACE ((obj), GTK_TYPE_TREE_DRAG_SOURCE, GtkTreeDragSourceIface))
 | |
| 
 | |
| typedef struct _GtkTreeDragSource      GtkTreeDragSource; /* Dummy typedef */
 | |
| typedef struct _GtkTreeDragSourceIface GtkTreeDragSourceIface;
 | |
| 
 | |
| /**
 | |
|  * GtkTreeDragSourceIface:
 | |
|  * @row_draggable: Asks the #GtkTreeDragSource whether a particular
 | |
|  *    row can be used as the source of a DND operation.
 | |
|  * @drag_data_get: Asks the #GtkTreeDragSource to fill in
 | |
|  *    selection_data with a representation of the row at path.
 | |
|  * @drag_data_delete: Asks the #GtkTreeDragSource to delete the row at
 | |
|  *    path, because it was moved somewhere else via drag-and-drop.
 | |
|  */
 | |
| struct _GtkTreeDragSourceIface
 | |
| {
 | |
|   /*< private >*/
 | |
|   GTypeInterface g_iface;
 | |
| 
 | |
|   /*< public >*/
 | |
| 
 | |
|   /* VTable - not signals */
 | |
| 
 | |
|   gboolean     (* row_draggable)        (GtkTreeDragSource   *drag_source,
 | |
|                                          GtkTreePath         *path);
 | |
| 
 | |
|   gboolean     (* drag_data_get)        (GtkTreeDragSource   *drag_source,
 | |
|                                          GtkTreePath         *path,
 | |
|                                          GtkSelectionData    *selection_data);
 | |
| 
 | |
|   gboolean     (* drag_data_delete)     (GtkTreeDragSource *drag_source,
 | |
|                                          GtkTreePath       *path);
 | |
| };
 | |
| 
 | |
| GDK_AVAILABLE_IN_ALL
 | |
| GType           gtk_tree_drag_source_get_type   (void) G_GNUC_CONST;
 | |
| 
 | |
| /* Returns whether the given row can be dragged */
 | |
| GDK_AVAILABLE_IN_ALL
 | |
| gboolean gtk_tree_drag_source_row_draggable    (GtkTreeDragSource *drag_source,
 | |
|                                                 GtkTreePath       *path);
 | |
| 
 | |
| /* Deletes the given row, or returns FALSE if it can't */
 | |
| GDK_AVAILABLE_IN_ALL
 | |
| gboolean gtk_tree_drag_source_drag_data_delete (GtkTreeDragSource *drag_source,
 | |
|                                                 GtkTreePath       *path);
 | |
| 
 | |
| /* Fills in selection_data with type selection_data->target based on
 | |
|  * the row denoted by path, returns TRUE if it does anything
 | |
|  */
 | |
| GDK_AVAILABLE_IN_ALL
 | |
| gboolean gtk_tree_drag_source_drag_data_get    (GtkTreeDragSource *drag_source,
 | |
|                                                 GtkTreePath       *path,
 | |
|                                                 GtkSelectionData  *selection_data);
 | |
| 
 | |
| #define GTK_TYPE_TREE_DRAG_DEST            (gtk_tree_drag_dest_get_type ())
 | |
| #define GTK_TREE_DRAG_DEST(obj)            (G_TYPE_CHECK_INSTANCE_CAST ((obj), GTK_TYPE_TREE_DRAG_DEST, GtkTreeDragDest))
 | |
| #define GTK_IS_TREE_DRAG_DEST(obj)         (G_TYPE_CHECK_INSTANCE_TYPE ((obj), GTK_TYPE_TREE_DRAG_DEST))
 | |
| #define GTK_TREE_DRAG_DEST_GET_IFACE(obj)  (G_TYPE_INSTANCE_GET_INTERFACE ((obj), GTK_TYPE_TREE_DRAG_DEST, GtkTreeDragDestIface))
 | |
| 
 | |
| typedef struct _GtkTreeDragDest      GtkTreeDragDest; /* Dummy typedef */
 | |
| typedef struct _GtkTreeDragDestIface GtkTreeDragDestIface;
 | |
| 
 | |
| /**
 | |
|  * GtkTreeDragDestIface:
 | |
|  * @drag_data_received: Asks the #GtkTreeDragDest to insert a row
 | |
|  *    before the path dest, deriving the contents of the row from
 | |
|  *    selection_data.
 | |
|  * @row_drop_possible: Determines whether a drop is possible before
 | |
|  *    the given dest_path, at the same depth as dest_path.
 | |
|  */
 | |
| struct _GtkTreeDragDestIface
 | |
| {
 | |
|   /*< private >*/
 | |
|   GTypeInterface g_iface;
 | |
| 
 | |
|   /*< public >*/
 | |
| 
 | |
|   /* VTable - not signals */
 | |
| 
 | |
|   gboolean     (* drag_data_received) (GtkTreeDragDest   *drag_dest,
 | |
|                                        GtkTreePath       *dest,
 | |
|                                        GtkSelectionData  *selection_data);
 | |
| 
 | |
|   gboolean     (* row_drop_possible)  (GtkTreeDragDest   *drag_dest,
 | |
|                                        GtkTreePath       *dest_path,
 | |
| 				       GtkSelectionData  *selection_data);
 | |
| };
 | |
| 
 | |
| GDK_AVAILABLE_IN_ALL
 | |
| GType           gtk_tree_drag_dest_get_type   (void) G_GNUC_CONST;
 | |
| 
 | |
| /* Inserts a row before dest which contains data in selection_data,
 | |
|  * or returns FALSE if it can't
 | |
|  */
 | |
| GDK_AVAILABLE_IN_ALL
 | |
| gboolean gtk_tree_drag_dest_drag_data_received (GtkTreeDragDest   *drag_dest,
 | |
| 						GtkTreePath       *dest,
 | |
| 						GtkSelectionData  *selection_data);
 | |
| 
 | |
| 
 | |
| /* Returns TRUE if we can drop before path; path may not exist. */
 | |
| GDK_AVAILABLE_IN_ALL
 | |
| gboolean gtk_tree_drag_dest_row_drop_possible  (GtkTreeDragDest   *drag_dest,
 | |
| 						GtkTreePath       *dest_path,
 | |
| 						GtkSelectionData  *selection_data);
 | |
| 
 | |
| 
 | |
| /* The selection data would normally have target type GTK_TREE_MODEL_ROW in this
 | |
|  * case. If the target is wrong these functions return FALSE.
 | |
|  */
 | |
| GDK_AVAILABLE_IN_ALL
 | |
| gboolean gtk_tree_set_row_drag_data            (GtkSelectionData  *selection_data,
 | |
| 						GtkTreeModel      *tree_model,
 | |
| 						GtkTreePath       *path);
 | |
| GDK_AVAILABLE_IN_ALL
 | |
| gboolean gtk_tree_get_row_drag_data            (GtkSelectionData  *selection_data,
 | |
| 						GtkTreeModel     **tree_model,
 | |
| 						GtkTreePath      **path);
 | |
| 
 | |
| G_END_DECLS
 | |
| 
 | |
| #endif /* __GTK_TREE_DND_H__ */
 |