]> Pileus Git - ~andy/gtk/blobdiff - gtk/gtktreeselection.h
GtkTextView: don't popdown a bubble if we don't have one
[~andy/gtk] / gtk / gtktreeselection.h
index 325cad8a8189509ed6afbffe5843929f78c2d1fd..4600930ce745cc1a5ff0fd184678a2cba92d5b58 100644 (file)
  * 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, write to the
- * Free Software Foundation, Inc., 59 Temple Place - Suite 330,
- * Boston, MA 02111-1307, USA.
+ * License along with this library. If not, see <http://www.gnu.org/licenses/>.
  */
 
 #ifndef __GTK_TREE_SELECTION_H__
 #define __GTK_TREE_SELECTION_H__
 
-#include <gobject/gobject.h>
-#include <gtk/gtkobject.h>
+#if !defined (__GTK_H_INSIDE__) && !defined (GTK_COMPILATION)
+#error "Only <gtk/gtk.h> can be included directly."
+#endif
+
 #include <gtk/gtktreeview.h>
 
-#ifdef __cplusplus
-extern "C" {
-#endif /* __cplusplus */
+G_BEGIN_DECLS
 
-#warning "Die GTK_TREE_SELECTION, DIE"
-#undef GTK_TREE_SELECTION
 
 #define GTK_TYPE_TREE_SELECTION                        (gtk_tree_selection_get_type ())
-#define GTK_TREE_SELECTION(obj)                        (GTK_CHECK_CAST ((obj), GTK_TYPE_TREE_SELECTION, GtkTreeSelection))
-#define GTK_TREE_SELECTION_CLASS(klass)                (GTK_CHECK_CLASS_CAST ((klass), GTK_TYPE_TREE_SELECTION, GtkTreeSelectionClass))
-#define GTK_IS_TREE_SELECTION(obj)             (GTK_CHECK_TYPE ((obj), GTK_TYPE_TREE_SELECTION))
-#define GTK_IS_TREE_SELECTION_CLASS(klass)     (GTK_CHECK_CLASS_TYPE ((obj), GTK_TYPE_TREE_SELECTION))
-
-typedef enum
-{
-  GTK_TREE_SELECTION_SINGLE,
-  GTK_TREE_SELECTION_MULTI
-} GtkTreeSelectionType;
-
+#define GTK_TREE_SELECTION(obj)                        (G_TYPE_CHECK_INSTANCE_CAST ((obj), GTK_TYPE_TREE_SELECTION, GtkTreeSelection))
+#define GTK_TREE_SELECTION_CLASS(klass)                (G_TYPE_CHECK_CLASS_CAST ((klass), GTK_TYPE_TREE_SELECTION, GtkTreeSelectionClass))
+#define GTK_IS_TREE_SELECTION(obj)             (G_TYPE_CHECK_INSTANCE_TYPE ((obj), GTK_TYPE_TREE_SELECTION))
+#define GTK_IS_TREE_SELECTION_CLASS(klass)     (G_TYPE_CHECK_CLASS_TYPE ((klass), GTK_TYPE_TREE_SELECTION))
+#define GTK_TREE_SELECTION_GET_CLASS(obj)      (G_TYPE_INSTANCE_GET_CLASS ((obj), GTK_TYPE_TREE_SELECTION, GtkTreeSelectionClass))
+
+typedef struct _GtkTreeSelectionPrivate      GtkTreeSelectionPrivate;
+
+/**
+ * GtkTreeSelectionFunc:
+ * @selection: A #GtkTreeSelection
+ * @model: A #GtkTreeModel being viewed
+ * @path: The #GtkTreePath of the row in question
+ * @path_currently_selected: %TRUE, if the path is currently selected
+ * @data: (closure): user data
+ *
+ * A function used by gtk_tree_selection_set_select_function() to filter
+ * whether or not a row may be selected.  It is called whenever a row's
+ * state might change.  A return value of %TRUE indicates to @selection
+ * that it is okay to change the selection.
+ *
+ * Returns: %TRUE, if the selection state of the row can be toggled
+ */
 typedef gboolean (* GtkTreeSelectionFunc)    (GtkTreeSelection  *selection,
                                              GtkTreeModel      *model,
                                              GtkTreePath       *path,
+                                              gboolean           path_currently_selected,
                                              gpointer           data);
+
+/**
+ * GtkTreeSelectionForeachFunc:
+ * @model: The #GtkTreeModel being viewed
+ * @path: The #GtkTreePath of a selected row
+ * @iter: A #GtkTreeIter pointing to a selected row
+ * @data: (closure): user data
+ *
+ * A function used by gtk_tree_selection_selected_foreach() to map all
+ * selected rows.  It will be called on every selected row in the view.
+ */
 typedef void (* GtkTreeSelectionForeachFunc) (GtkTreeModel      *model,
-                                             GtkTreeNode       *node,
+                                             GtkTreePath       *path,
+                                             GtkTreeIter       *iter,
                                              gpointer           data);
 
 struct _GtkTreeSelection
 {
-  GtkObject parent;
+  /*< private >*/
+  GObject parent;
 
-  GtkTreeView *tree_view;
-  GtkTreeSelectionType type;
-  GtkTreeSelectionFunc user_func;
-  gpointer user_data;
+  GtkTreeSelectionPrivate *priv;
 };
 
 struct _GtkTreeSelectionClass
 {
-  GtkObjectClass parent_class;
-
-  void (* row_selected)   (GtkTreeView  *tree_view,
-                          GtkTreeModel *tree_model,
-                          GtkTreeNode  *node);
-  void (* row_unselected) (GtkTreeView  *tree_view,
-                          GtkTreeModel *tree_model,
-                          GtkTreeNode  *node);
+  GObjectClass parent_class;
+
+  void (* changed) (GtkTreeSelection *selection);
+
+  /* Padding for future expansion */
+  void (*_gtk_reserved1) (void);
+  void (*_gtk_reserved2) (void);
+  void (*_gtk_reserved3) (void);
+  void (*_gtk_reserved4) (void);
 };
 
 
-GtkType          gtk_tree_selection_get_type            (void);
-GtkObject       *gtk_tree_selection_new                 (void);
-void             gtk_tree_selection_set_type            (GtkTreeSelection            *selection,
-                                                        GtkTreeSelectionType         type);
+GType            gtk_tree_selection_get_type            (void) G_GNUC_CONST;
+
+void             gtk_tree_selection_set_mode            (GtkTreeSelection            *selection,
+                                                        GtkSelectionMode             type);
+GtkSelectionMode gtk_tree_selection_get_mode        (GtkTreeSelection            *selection);
 void             gtk_tree_selection_set_select_function (GtkTreeSelection            *selection,
                                                         GtkTreeSelectionFunc         func,
-                                                        gpointer                     data);
+                                                        gpointer                     data,
+                                                        GDestroyNotify               destroy);
 gpointer         gtk_tree_selection_get_user_data       (GtkTreeSelection            *selection);
-
-
-/* Only meaningful if GTK_TREE_SELECTION_SINGLE is set */
-/* Use selected_foreach for GTK_TREE_SELECTION_MULTI */
-GtkTreeNode     *gtk_tree_selection_get_selected        (GtkTreeSelection            *selection);
-/* FIXME: Get a more convenient get_selection function????  one returning GSList?? */
+GtkTreeView*     gtk_tree_selection_get_tree_view       (GtkTreeSelection            *selection);
+
+GtkTreeSelectionFunc gtk_tree_selection_get_select_function (GtkTreeSelection        *selection);
+
+/* Only meaningful if GTK_SELECTION_SINGLE or GTK_SELECTION_BROWSE is set */
+/* Use selected_foreach or get_selected_rows for GTK_SELECTION_MULTIPLE */
+gboolean         gtk_tree_selection_get_selected        (GtkTreeSelection            *selection,
+                                                        GtkTreeModel               **model,
+                                                        GtkTreeIter                 *iter);
+GList *          gtk_tree_selection_get_selected_rows   (GtkTreeSelection            *selection,
+                                                         GtkTreeModel               **model);
+gint             gtk_tree_selection_count_selected_rows (GtkTreeSelection            *selection);
 void             gtk_tree_selection_selected_foreach    (GtkTreeSelection            *selection,
                                                         GtkTreeSelectionForeachFunc  func,
                                                         gpointer                     data);
@@ -95,26 +123,24 @@ void             gtk_tree_selection_select_path         (GtkTreeSelection
                                                         GtkTreePath                 *path);
 void             gtk_tree_selection_unselect_path       (GtkTreeSelection            *selection,
                                                         GtkTreePath                 *path);
-void             gtk_tree_selection_select_node         (GtkTreeSelection            *selection,
-                                                        GtkTreeNode                 *tree_node);
-void             gtk_tree_selection_unselect_node       (GtkTreeSelection            *selection,
-                                                        GtkTreeNode                 *tree_node);
+void             gtk_tree_selection_select_iter         (GtkTreeSelection            *selection,
+                                                        GtkTreeIter                 *iter);
+void             gtk_tree_selection_unselect_iter       (GtkTreeSelection            *selection,
+                                                        GtkTreeIter                 *iter);
+gboolean         gtk_tree_selection_path_is_selected    (GtkTreeSelection            *selection,
+                                                        GtkTreePath                 *path);
+gboolean         gtk_tree_selection_iter_is_selected    (GtkTreeSelection            *selection,
+                                                        GtkTreeIter                 *iter);
 void             gtk_tree_selection_select_all          (GtkTreeSelection            *selection);
 void             gtk_tree_selection_unselect_all        (GtkTreeSelection            *selection);
 void             gtk_tree_selection_select_range        (GtkTreeSelection            *selection,
                                                         GtkTreePath                 *start_path,
                                                         GtkTreePath                 *end_path);
+void             gtk_tree_selection_unselect_range      (GtkTreeSelection            *selection,
+                                                         GtkTreePath                 *start_path,
+                                                        GtkTreePath                 *end_path);
 
 
-/*< private >*/
-GtkObject       *gtk_tree_selection_new_with_tree_view  (GtkTreeView                 *tree_view);
-void             gtk_tree_selection_set_tree_view       (GtkTreeSelection            *selection,
-                                                        GtkTreeView                 *tree_view);
-
-#ifdef __cplusplus
-}
-#endif /* __cplusplus */
-
+G_END_DECLS
 
 #endif /* __GTK_TREE_SELECTION_H__ */
-