mirror of
https://gitlab.gnome.org/GNOME/gtk.git
synced 2025-01-04 17:50:18 +00:00
Don't start a drag if we are not resizable
This was caused by get_drag_edge() returning -1 to mean 'no drag', but callers didn't really pay attention. Change get_drag_edge() to return a boolean instead.
This commit is contained in:
parent
803233cc14
commit
5e1d8814ca
@ -5015,15 +5015,15 @@ get_grip_edge (GtkWidget *widget)
|
||||
: GDK_WINDOW_EDGE_SOUTH_WEST;
|
||||
}
|
||||
|
||||
static GdkWindowEdge
|
||||
get_drag_edge (GtkWidget *widget)
|
||||
static gboolean
|
||||
get_drag_edge (GtkWidget *widget,
|
||||
GdkWindowEdge *edge)
|
||||
{
|
||||
GdkGeometry geometry;
|
||||
guint flags;
|
||||
gboolean hresizable;
|
||||
gboolean vresizable;
|
||||
GtkTextDirection dir;
|
||||
GdkWindowEdge edge;
|
||||
|
||||
gtk_window_compute_hints (GTK_WINDOW (widget), &geometry, &flags);
|
||||
|
||||
@ -5041,15 +5041,15 @@ get_drag_edge (GtkWidget *widget)
|
||||
dir = gtk_widget_get_direction (widget);
|
||||
|
||||
if (hresizable && vresizable)
|
||||
edge = dir == GTK_TEXT_DIR_LTR ? GDK_WINDOW_EDGE_SOUTH_EAST : GDK_WINDOW_EDGE_SOUTH_WEST;
|
||||
*edge = dir == GTK_TEXT_DIR_LTR ? GDK_WINDOW_EDGE_SOUTH_EAST : GDK_WINDOW_EDGE_SOUTH_WEST;
|
||||
else if (hresizable)
|
||||
edge = dir == GTK_TEXT_DIR_LTR ? GDK_WINDOW_EDGE_EAST : GDK_WINDOW_EDGE_WEST;
|
||||
*edge = dir == GTK_TEXT_DIR_LTR ? GDK_WINDOW_EDGE_EAST : GDK_WINDOW_EDGE_WEST;
|
||||
else if (vresizable)
|
||||
edge = GDK_WINDOW_EDGE_SOUTH;
|
||||
*edge = GDK_WINDOW_EDGE_SOUTH;
|
||||
else
|
||||
edge = (GdkWindowEdge)-1;
|
||||
return FALSE;
|
||||
|
||||
return edge;
|
||||
return TRUE;
|
||||
}
|
||||
|
||||
static void
|
||||
@ -5057,17 +5057,21 @@ set_grip_cursor (GtkWindow *window)
|
||||
{
|
||||
GtkWidget *widget = GTK_WIDGET (window);
|
||||
GtkWindowPrivate *priv = window->priv;
|
||||
GdkWindowEdge edge;
|
||||
GdkDisplay *display;
|
||||
GdkCursorType cursor_type;
|
||||
GdkCursor *cursor;
|
||||
|
||||
if (priv->grip_window == NULL)
|
||||
return;
|
||||
|
||||
if (gtk_widget_is_sensitive (widget))
|
||||
{
|
||||
edge = get_drag_edge (widget);
|
||||
GdkWindowEdge edge;
|
||||
GdkDisplay *display;
|
||||
GdkCursorType cursor_type;
|
||||
GdkCursor *cursor;
|
||||
|
||||
cursor_type = GDK_LEFT_PTR;
|
||||
|
||||
if (get_drag_edge (widget, &edge))
|
||||
{
|
||||
switch (edge)
|
||||
{
|
||||
case GDK_WINDOW_EDGE_EAST:
|
||||
@ -5085,9 +5089,8 @@ set_grip_cursor (GtkWindow *window)
|
||||
case GDK_WINDOW_EDGE_WEST:
|
||||
cursor_type = GDK_LEFT_SIDE;
|
||||
break;
|
||||
default:
|
||||
cursor_type = GDK_LEFT_PTR;
|
||||
break;
|
||||
default: ;
|
||||
}
|
||||
}
|
||||
|
||||
display = gtk_widget_get_display (widget);
|
||||
@ -5718,11 +5721,13 @@ gtk_window_button_press_event (GtkWidget *widget,
|
||||
GdkEventButton *event)
|
||||
{
|
||||
GtkWindowPrivate *priv = GTK_WINDOW (widget)->priv;
|
||||
GdkWindowEdge edge;
|
||||
|
||||
if (event->window == priv->grip_window)
|
||||
{
|
||||
if (get_drag_edge (widget, &edge))
|
||||
gtk_window_begin_resize_drag (GTK_WINDOW (widget),
|
||||
get_drag_edge (widget),
|
||||
edge,
|
||||
event->button,
|
||||
event->x_root,
|
||||
event->y_root,
|
||||
|
Loading…
Reference in New Issue
Block a user