summaryrefslogtreecommitdiff
path: root/gtk/gtklist.c
diff options
context:
space:
mode:
authorLars Hamann <lars@gtk.org>1999-01-11 23:24:41 +0000
committerLars Hamann <lars@src.gnome.org>1999-01-11 23:24:41 +0000
commit8b0955954ccd6147f8031cc4bd07e7d92bbbc74d (patch)
tree675521400ba08b28a4601f8ba911ee36259bc2d9 /gtk/gtklist.c
parentd2e69a89d4b8a0f9ceedbe87362cf9609e5b7c52 (diff)
downloadgtk+-8b0955954ccd6147f8031cc4bd07e7d92bbbc74d.tar.gz
end drag selections if necessary.
Mon Jan 11 23:52:58 1999 Lars Hamann <lars@gtk.org> * gtk/gtklist.c (gtk_list_signal_drag_begin) (gtk_list_drag_begin): end drag selections if necessary. * gtk/gtkspinbutton.c/h (gtk_spin_button_update): made function public. Manually force synchronization of spin button text and adjustment value.
Diffstat (limited to 'gtk/gtklist.c')
-rw-r--r--gtk/gtklist.c59
1 files changed, 56 insertions, 3 deletions
diff --git a/gtk/gtklist.c b/gtk/gtklist.c
index 2d4f3ccbb6..45527aa94a 100644
--- a/gtk/gtklist.c
+++ b/gtk/gtklist.c
@@ -103,6 +103,9 @@ static void gtk_list_update_extended_selection (GtkList *list,
gint row);
/** GtkListItem Signal Functions **/
+static void gtk_list_signal_drag_begin (GtkWidget *widget,
+ GdkDragContext *context,
+ GtkList *list);
static void gtk_list_signal_focus_lost (GtkWidget *item,
GdkEventKey *event,
GtkList *list);
@@ -141,6 +144,10 @@ static void gtk_list_signal_item_toggle (GtkListItem *list_item,
GtkList *list);
+static void gtk_list_drag_begin (GtkWidget *widget,
+ GdkDragContext *context);
+
+
static GtkContainerClass *parent_class = NULL;
static guint list_signals[LAST_SIGNAL] = { 0 };
@@ -229,6 +236,7 @@ gtk_list_class_init (GtkListClass *class)
widget_class->motion_notify_event = gtk_list_motion_notify;
widget_class->size_request = gtk_list_size_request;
widget_class->size_allocate = gtk_list_size_allocate;
+ widget_class->drag_begin = gtk_list_drag_begin;
container_class->add = gtk_list_add;
container_class->remove = gtk_list_remove;
@@ -542,17 +550,15 @@ gtk_list_motion_notify (GtkWidget *widget,
if (row != focus_row)
gtk_widget_grab_focus (item);
-
+
switch (list->selection_mode)
{
case GTK_SELECTION_BROWSE:
gtk_list_select_child (list, item);
break;
-
case GTK_SELECTION_EXTENDED:
gtk_list_update_extended_selection (list, row);
break;
-
default:
break;
}
@@ -1014,6 +1020,9 @@ gtk_list_insert_items (GtkList *list,
tmp_list = tmp_list->next;
gtk_widget_set_parent (widget, GTK_WIDGET (list));
+ gtk_signal_connect (GTK_OBJECT (widget), "drag_begin",
+ GTK_SIGNAL_FUNC (gtk_list_signal_drag_begin),
+ list);
gtk_signal_connect (GTK_OBJECT (widget), "focus_out_event",
GTK_SIGNAL_FUNC (gtk_list_signal_focus_lost),
list);
@@ -2613,3 +2622,47 @@ gtk_list_signal_item_toggle (GtkListItem *list_item,
break;
}
}
+
+static void
+gtk_list_signal_drag_begin (GtkWidget *widget,
+ GdkDragContext *context,
+ GtkList *list)
+{
+ g_return_if_fail (widget != NULL);
+ g_return_if_fail (GTK_IS_LIST_ITEM (widget));
+ g_return_if_fail (list != NULL);
+ g_return_if_fail (GTK_IS_LIST (list));
+
+ gtk_list_drag_begin (GTK_WIDGET (list), context);
+}
+
+static void
+gtk_list_drag_begin (GtkWidget *widget,
+ GdkDragContext *context)
+{
+ GtkList *list;
+
+ g_return_if_fail (widget != NULL);
+ g_return_if_fail (GTK_IS_LIST (widget));
+ g_return_if_fail (context != NULL);
+
+ list = GTK_LIST (widget);
+
+ if (list->drag_selection)
+ {
+ gtk_list_end_drag_selection (list);
+
+ switch (list->selection_mode)
+ {
+ case GTK_SELECTION_EXTENDED:
+ gtk_list_end_selection (list);
+ break;
+ case GTK_SELECTION_SINGLE:
+ case GTK_SELECTION_MULTIPLE:
+ list->undo_focus_child = NULL;
+ break;
+ default:
+ break;
+ }
+ }
+}