[gtk/present-toplevel-2: 3/59] window: Use GdkToplevel
- From: Matthias Clasen <matthiasc src gnome org>
- To: commits-list gnome org
- Cc:
- Subject: [gtk/present-toplevel-2: 3/59] window: Use GdkToplevel
- Date: Thu, 12 Mar 2020 18:57:39 +0000 (UTC)
commit 92668816911ed4ae3a105b48e5ffc74a79132356
Author: Matthias Clasen <mclasen redhat com>
Date: Sat Feb 29 06:53:24 2020 -0500
window: Use GdkToplevel
gtk/gtkwindow.c | 253 +++++++++++++++++++++++++++++---------------------------
1 file changed, 129 insertions(+), 124 deletions(-)
---
diff --git a/gtk/gtkwindow.c b/gtk/gtkwindow.c
index 0e89f42f09..ad8089049d 100644
--- a/gtk/gtkwindow.c
+++ b/gtk/gtkwindow.c
@@ -500,6 +500,11 @@ static void gtk_window_state_flags_changed (GtkWidget *widget,
GtkStateFlags previous_state);
static void _gtk_window_set_is_active (GtkWindow *window,
gboolean is_active);
+static void gtk_window_present_toplevel (GtkWindow *window);
+static void gtk_window_update_toplevel (GtkWindow *window);
+static GdkToplevelLayout * gtk_window_compute_layout (GtkWindow *window,
+ int min_width,
+ int min_height);
static GListStore *toplevel_list = NULL;
static guint window_signals[LAST_SIGNAL] = { 0 };
@@ -1303,9 +1308,9 @@ gtk_window_titlebar_action (GtkWindow *window,
_gtk_window_toggle_maximized (window);
}
else if (g_str_equal (action, "lower"))
- gdk_surface_lower (priv->surface);
+ gdk_toplevel_lower (GDK_TOPLEVEL (priv->surface));
else if (g_str_equal (action, "minimize"))
- gdk_surface_minimize (priv->surface);
+ gdk_toplevel_minimize (GDK_TOPLEVEL (priv->surface));
else if (g_str_equal (action, "menu"))
gtk_window_do_popup (window, (GdkEventButton*) event);
else
@@ -1377,7 +1382,7 @@ click_gesture_pressed_cb (GtkGestureClick *gesture,
event_widget = gtk_get_event_widget ((GdkEvent *) event);
if (region == GTK_WINDOW_REGION_TITLE)
- gdk_surface_raise (priv->surface);
+ gtk_window_update_toplevel (window);
switch (region)
{
@@ -2393,7 +2398,7 @@ gtk_window_set_title_internal (GtkWindow *window,
priv->title = new_title;
if (_gtk_widget_get_realized (GTK_WIDGET (window)))
- gdk_surface_set_title (priv->surface, new_title != NULL ? new_title : "");
+ gdk_toplevel_set_title (GDK_TOPLEVEL (priv->surface), new_title != NULL ? new_title : "");
if (update_titlebar && GTK_IS_HEADER_BAR (priv->title_box))
gtk_header_bar_set_title (GTK_HEADER_BAR (priv->title_box), new_title != NULL ? new_title : "");
@@ -2491,7 +2496,7 @@ gtk_window_set_startup_id (GtkWindow *window,
gtk_window_present_with_time (window, timestamp);
else
{
- gdk_surface_set_startup_id (priv->surface, priv->startup_id);
+ gdk_toplevel_set_startup_id (GDK_TOPLEVEL (priv->surface), priv->startup_id);
/* If window is mapped, terminate the startup-notification too */
if (_gtk_widget_get_mapped (widget) && !disable_startup_notification)
@@ -2847,9 +2852,8 @@ gtk_window_set_modal (GtkWindow *window,
priv->modal = modal;
widget = GTK_WIDGET (window);
- /* adjust desired modality state */
if (_gtk_widget_get_realized (widget))
- gdk_surface_set_modal_hint (priv->surface, priv->modal);
+ gdk_toplevel_set_modal (GDK_TOPLEVEL (priv->surface), modal);
if (gtk_widget_get_visible (widget))
{
@@ -3010,7 +3014,7 @@ gtk_window_transient_parent_realized (GtkWidget *parent,
GtkWindowPrivate *priv = gtk_window_get_instance_private (GTK_WINDOW (window));
GtkWindowPrivate *parent_priv = gtk_window_get_instance_private (GTK_WINDOW (parent));
if (_gtk_widget_get_realized (window))
- gdk_surface_set_transient_for (priv->surface, parent_priv->surface);
+ gdk_toplevel_set_transient_for (GDK_TOPLEVEL (priv->surface), parent_priv->surface);
}
static void
@@ -3019,7 +3023,7 @@ gtk_window_transient_parent_unrealized (GtkWidget *parent,
{
GtkWindowPrivate *priv = gtk_window_get_instance_private (GTK_WINDOW (window));
if (_gtk_widget_get_realized (window))
- gdk_surface_set_transient_for (priv->surface, NULL);
+ gdk_toplevel_set_transient_for (GDK_TOPLEVEL (priv->surface), NULL);
}
static void
@@ -3033,7 +3037,7 @@ gtk_window_transient_parent_display_changed (GtkWindow *parent,
}
static void
-gtk_window_unset_transient_for (GtkWindow *window)
+gtk_window_unset_transient_for (GtkWindow *window)
{
GtkWindowPrivate *priv = gtk_window_get_instance_private (window);
@@ -3341,7 +3345,7 @@ gtk_window_set_accept_focus (GtkWindow *window,
{
priv->accept_focus = setting;
if (_gtk_widget_get_realized (GTK_WIDGET (window)))
- gdk_surface_set_accept_focus (priv->surface, priv->accept_focus);
+ gdk_toplevel_set_accept_focus (GDK_TOPLEVEL (priv->surface), priv->accept_focus);
g_object_notify_by_pspec (G_OBJECT (window), window_props[PROP_ACCEPT_FOCUS]);
}
}
@@ -3387,7 +3391,7 @@ gtk_window_set_focus_on_map (GtkWindow *window,
{
priv->focus_on_map = setting;
if (_gtk_widget_get_realized (GTK_WIDGET (window)))
- gdk_surface_set_focus_on_map (priv->surface, priv->focus_on_map);
+ gdk_toplevel_set_focus_on_map (GDK_TOPLEVEL (priv->surface), priv->focus_on_map);
g_object_notify_by_pspec (G_OBJECT (window), window_props[PROP_FOCUS_ON_MAP]);
}
}
@@ -3741,17 +3745,7 @@ gtk_window_set_decorated (GtkWindow *window,
priv->decorated = setting;
if (priv->surface)
- {
- if (priv->decorated)
- {
- if (priv->client_decorated)
- gdk_surface_set_decorations (priv->surface, 0);
- else
- gdk_surface_set_decorations (priv->surface, GDK_DECOR_ALL);
- }
- else
- gdk_surface_set_decorations (priv->surface, 0);
- }
+ gdk_toplevel_set_decorated (GDK_TOPLEVEL (priv->surface), priv->decorated && !priv->client_decorated);
update_window_buttons (window);
gtk_widget_queue_resize (GTK_WIDGET (window));
@@ -3810,13 +3804,7 @@ gtk_window_set_deletable (GtkWindow *window,
priv->deletable = setting;
if (priv->surface)
- {
- if (priv->deletable)
- gdk_surface_set_functions (priv->surface, GDK_FUNC_ALL);
- else
- gdk_surface_set_functions (priv->surface,
- GDK_FUNC_ALL | GDK_FUNC_CLOSE);
- }
+ gdk_toplevel_set_deletable (GDK_TOPLEVEL (priv->surface), priv->deletable);
update_window_buttons (window);
@@ -4002,7 +3990,7 @@ gtk_window_realize_icon (GtkWindow *window)
info->realized = TRUE;
- gdk_surface_set_icon_list (priv->surface, icon_list);
+ gdk_toplevel_set_icon_list (GDK_TOPLEVEL (priv->surface), icon_list);
if (GTK_IS_HEADER_BAR (priv->title_box))
_gtk_header_bar_update_window_icon (GTK_HEADER_BAR (priv->title_box), window);
@@ -4817,13 +4805,75 @@ gtk_window_hide (GtkWidget *widget)
gtk_grab_remove (widget);
}
+static GdkToplevelLayout *
+gtk_window_compute_layout (GtkWindow *window,
+ int min_width,
+ int min_height)
+{
+ GtkWindowPrivate *priv = gtk_window_get_instance_private (window);
+ GdkToplevelLayout *layout;
+
+ layout = gdk_toplevel_layout_new (min_width, min_height);
+
+ gdk_toplevel_layout_set_resizable (layout, priv->resizable);
+ gdk_toplevel_layout_set_maximized (layout, priv->maximize_initially);
+ gdk_toplevel_layout_set_fullscreen (layout,
+ priv->fullscreen_initially,
+ priv->initial_fullscreen_monitor);
+
+ return layout;
+}
+
+static void
+gtk_window_present_toplevel (GtkWindow *window)
+{
+ GtkWindowPrivate *priv = gtk_window_get_instance_private (window);
+ GdkToplevelLayout *layout;
+ GdkRectangle request;
+ GdkGeometry geometry;
+ GdkSurfaceHints flags;
+
+ gtk_window_compute_configure_request (window, &request,
+ &geometry, &flags);
+
+ if (!(flags & GDK_HINT_MIN_SIZE))
+ geometry.min_width = geometry.min_height = 1;
+
+ layout = gtk_window_compute_layout (window, geometry.min_width, geometry.min_height);
+
+ gdk_toplevel_present (GDK_TOPLEVEL (priv->surface),
+ request.width,
+ request.height,
+ layout);
+ gdk_toplevel_layout_unref (layout);
+}
+
+static void
+gtk_window_update_toplevel (GtkWindow *window)
+{
+ GtkWindowPrivate *priv = gtk_window_get_instance_private (window);
+
+
+ if (priv->surface && gdk_surface_get_mapped (priv->surface))
+ {
+ GdkToplevelLayout *layout;
+
+ layout = gtk_window_compute_layout (window, 1, 1);
+ gdk_toplevel_present (GDK_TOPLEVEL (priv->surface),
+ gdk_surface_get_width (priv->surface),
+ gdk_surface_get_height (priv->surface),
+ layout);
+ gdk_toplevel_layout_unref (layout);
+ }
+}
+
static void
gtk_window_map (GtkWidget *widget)
{
GtkWidget *child;
GtkWindow *window = GTK_WINDOW (widget);
GtkWindowPrivate *priv = gtk_window_get_instance_private (window);
- GdkSurface *surface;
+ GdkToplevelLayout *layout;
GTK_WIDGET_CLASS (gtk_window_parent_class)->map (widget);
@@ -4836,44 +4886,30 @@ gtk_window_map (GtkWidget *widget)
gtk_widget_get_child_visible (priv->title_box))
gtk_widget_map (priv->title_box);
- surface = priv->surface;
-
- if (priv->maximize_initially)
- gdk_surface_maximize (surface);
- else
- gdk_surface_unmaximize (surface);
-
- if (priv->stick_initially)
- gdk_surface_stick (surface);
- else
- gdk_surface_unstick (surface);
+ gdk_toplevel_set_sticky (GDK_TOPLEVEL (priv->surface), priv->stick_initially);
+ gdk_toplevel_set_keep_above (GDK_TOPLEVEL (priv->surface), priv->above_initially);
+ gdk_toplevel_set_keep_below (GDK_TOPLEVEL (priv->surface), priv->below_initially);
+
+ layout = gdk_toplevel_layout_new (1, 1);
+ gdk_toplevel_layout_set_resizable (layout, priv->resizable);
+ gdk_toplevel_layout_set_maximized (layout, priv->maximize_initially);
+ gdk_toplevel_layout_set_fullscreen (layout,
+ priv->fullscreen_initially,
+ priv->initial_fullscreen_monitor);
+ gdk_toplevel_present (GDK_TOPLEVEL (priv->surface),
+ gdk_surface_get_width (priv->surface),
+ gdk_surface_get_height (priv->surface),
+ layout);
+ gdk_toplevel_layout_unref (layout);
if (priv->minimize_initially)
- gdk_surface_minimize (surface);
- else
- gdk_surface_unminimize (surface);
-
- if (priv->fullscreen_initially)
- {
- if (priv->initial_fullscreen_monitor)
- gdk_surface_fullscreen_on_monitor (surface, priv->initial_fullscreen_monitor);
- else
- gdk_surface_fullscreen (surface);
- }
- else
- gdk_surface_unfullscreen (surface);
-
- gdk_surface_set_keep_above (surface, priv->above_initially);
-
- gdk_surface_set_keep_below (surface, priv->below_initially);
+ gdk_toplevel_minimize (GDK_TOPLEVEL (priv->surface));
gtk_window_set_theme_variant (window);
/* No longer use the default settings */
priv->need_default_size = FALSE;
- gdk_surface_show (surface);
-
if (!disable_startup_notification)
{
/* Do we have a custom startup-notification id? */
@@ -5454,39 +5490,25 @@ gtk_window_realize (GtkWidget *widget)
_gtk_widget_get_realized (GTK_WIDGET (priv->transient_parent)))
{
GtkWindowPrivate *parent_priv = gtk_window_get_instance_private (priv->transient_parent);
- gdk_surface_set_transient_for (surface, parent_priv->surface);
+ gdk_toplevel_set_transient_for (GDK_TOPLEVEL (surface), parent_priv->surface);
}
- gdk_surface_set_type_hint (surface, priv->type_hint);
-
if (priv->title)
- gdk_surface_set_title (surface, priv->title);
+ gdk_toplevel_set_title (GDK_TOPLEVEL (surface), priv->title);
- if (!priv->decorated || priv->client_decorated)
- gdk_surface_set_decorations (surface, 0);
+ gdk_toplevel_set_decorated (GDK_TOPLEVEL (surface), priv->decorated && !priv->client_decorated);
+ gdk_toplevel_set_deletable (GDK_TOPLEVEL (surface), priv->deletable);
#ifdef GDK_WINDOWING_WAYLAND
if (priv->client_decorated && GDK_IS_WAYLAND_SURFACE (surface))
gdk_wayland_surface_announce_csd (surface);
#endif
- if (!priv->deletable)
- gdk_surface_set_functions (surface, GDK_FUNC_ALL | GDK_FUNC_CLOSE);
-
- if (gtk_window_get_accept_focus (window))
- gdk_surface_set_accept_focus (surface, TRUE);
- else
- gdk_surface_set_accept_focus (surface, FALSE);
-
- if (gtk_window_get_focus_on_map (window))
- gdk_surface_set_focus_on_map (surface, TRUE);
- else
- gdk_surface_set_focus_on_map (surface, FALSE);
-
- if (priv->modal)
- gdk_surface_set_modal_hint (surface, TRUE);
- else
- gdk_surface_set_modal_hint (surface, FALSE);
+ gdk_toplevel_set_accept_focus (GDK_TOPLEVEL (surface),
+ gtk_window_get_accept_focus (window));
+ gdk_toplevel_set_focus_on_map (GDK_TOPLEVEL (surface),
+ gtk_window_get_focus_on_map (window));
+ gdk_toplevel_set_modal (GDK_TOPLEVEL (surface), priv->modal);
if (priv->startup_id)
{
@@ -5499,7 +5521,7 @@ gtk_window_realize (GtkWidget *widget)
}
#endif
if (!startup_id_is_fake (priv->startup_id))
- gdk_surface_set_startup_id (surface, priv->startup_id);
+ gdk_toplevel_set_startup_id (GDK_TOPLEVEL (surface), priv->startup_id);
}
#ifdef GDK_WINDOWING_X11
@@ -6656,15 +6678,7 @@ static void
maximize_window_clicked (GtkModelButton *button,
gpointer user_data)
{
- GtkWindow *window = GTK_WINDOW (user_data);
- GdkSurfaceState state;
-
- state = gtk_window_get_state (window);
-
- if (state & GDK_SURFACE_STATE_MINIMIZED)
- gtk_window_unminimize (window);
-
- gtk_window_maximize (window);
+ gtk_window_maximize (GTK_WINDOW (user_data));
}
static void
@@ -6804,7 +6818,7 @@ gtk_window_do_popup (GtkWindow *window,
{
GtkWindowPrivate *priv = gtk_window_get_instance_private (window);
- if (!gdk_surface_show_window_menu (priv->surface, (GdkEvent *) event))
+ if (!gdk_toplevel_show_window_menu (GDK_TOPLEVEL (priv->surface), (GdkEvent *) event))
gtk_window_do_popup_fallback (window, event);
}
@@ -6978,6 +6992,7 @@ gtk_window_move_resize (GtkWindow *window)
gboolean hints_changed; /* do we need to send these again */
GtkWindowLastGeometryInfo saved_last_info;
int current_width, current_height;
+ GdkToplevelLayout *layout;
widget = GTK_WIDGET (window);
@@ -7069,13 +7084,6 @@ gtk_window_move_resize (GtkWindow *window)
hints_changed = TRUE;
}
- /* Set hints if necessary
- */
- if (hints_changed)
- gdk_surface_set_geometry_hints (priv->surface,
- &new_geometry,
- new_flags);
-
current_width = gdk_surface_get_width (priv->surface);
current_height = gdk_surface_get_height (priv->surface);
@@ -7199,8 +7207,11 @@ gtk_window_move_resize (GtkWindow *window)
if (configure_request_pos_changed)
g_warning ("configure request position changed. This should not happen. Ignoring the position");
- gdk_surface_resize (priv->surface,
- new_request.width, new_request.height);
+ layout = gtk_window_compute_layout (window, 1, 1);
+ gdk_toplevel_present (GDK_TOPLEVEL (priv->surface),
+ new_request.width, new_request.height,
+ layout);
+ gdk_toplevel_layout_unref (layout);
}
else
{
@@ -7558,7 +7569,7 @@ gtk_window_present_with_time (GtkWindow *window,
g_assert (surface != NULL);
- gdk_surface_show (surface);
+ gtk_window_present_toplevel (window);
/* Translate a timestamp of GDK_CURRENT_TIME appropriately */
if (timestamp == GDK_CURRENT_TIME)
@@ -7576,7 +7587,7 @@ gtk_window_present_with_time (GtkWindow *window,
timestamp = gtk_get_current_event_time ();
}
- gdk_surface_focus (surface, timestamp);
+ gdk_toplevel_focus (GDK_TOPLEVEL (surface), timestamp);
}
else
{
@@ -7614,7 +7625,7 @@ gtk_window_minimize (GtkWindow *window)
priv->minimize_initially = TRUE;
if (priv->surface)
- gdk_surface_minimize (priv->surface);
+ gdk_toplevel_minimize (GDK_TOPLEVEL (priv->surface));
}
/**
@@ -7641,8 +7652,7 @@ gtk_window_unminimize (GtkWindow *window)
priv->minimize_initially = FALSE;
- if (priv->surface)
- gdk_surface_unminimize (priv->surface);
+ gtk_window_update_toplevel (window);
}
/**
@@ -7672,7 +7682,7 @@ gtk_window_stick (GtkWindow *window)
priv->stick_initially = TRUE;
if (priv->surface)
- gdk_surface_stick (priv->surface);
+ gdk_toplevel_set_sticky (GDK_TOPLEVEL (priv->surface), TRUE);
}
/**
@@ -7699,7 +7709,7 @@ gtk_window_unstick (GtkWindow *window)
priv->stick_initially = FALSE;
if (priv->surface)
- gdk_surface_unstick (priv->surface);
+ gdk_toplevel_set_sticky (GDK_TOPLEVEL (priv->surface), FALSE);
}
/**
@@ -7731,8 +7741,7 @@ gtk_window_maximize (GtkWindow *window)
priv->maximize_initially = TRUE;
- if (priv->surface)
- gdk_surface_maximize (priv->surface);
+ gtk_window_update_toplevel (window);
}
/**
@@ -7759,8 +7768,7 @@ gtk_window_unmaximize (GtkWindow *window)
priv->maximize_initially = FALSE;
- if (priv->surface)
- gdk_surface_unmaximize (priv->surface);
+ gtk_window_update_toplevel (window);
}
/**
@@ -7786,8 +7794,7 @@ gtk_window_fullscreen (GtkWindow *window)
priv->fullscreen_initially = TRUE;
- if (priv->surface)
- gdk_surface_fullscreen (priv->surface);
+ gtk_window_update_toplevel (window);
}
static void
@@ -7833,8 +7840,7 @@ gtk_window_fullscreen_on_monitor (GtkWindow *window,
priv->fullscreen_initially = TRUE;
- if (priv->surface)
- gdk_surface_fullscreen_on_monitor (priv->surface, monitor);
+ gtk_window_update_toplevel (window);
}
/**
@@ -7861,8 +7867,7 @@ gtk_window_unfullscreen (GtkWindow *window)
unset_fullscreen_monitor (window);
priv->fullscreen_initially = FALSE;
- if (priv->surface)
- gdk_surface_unfullscreen (priv->surface);
+ gtk_window_update_toplevel (window);
}
/**
@@ -7904,7 +7909,7 @@ gtk_window_set_keep_above (GtkWindow *window,
priv->below_initially &= !setting;
if (priv->surface)
- gdk_surface_set_keep_above (priv->surface, setting);
+ gdk_toplevel_set_keep_above (GDK_TOPLEVEL (priv->surface), setting);
}
/**
@@ -7946,7 +7951,7 @@ gtk_window_set_keep_below (GtkWindow *window,
priv->above_initially &= !setting;
if (priv->surface)
- gdk_surface_set_keep_below (priv->surface, setting);
+ gdk_toplevel_set_keep_below (GDK_TOPLEVEL (priv->surface), setting);
}
/**
[
Date Prev][
Date Next] [
Thread Prev][
Thread Next]
[
Thread Index]
[
Date Index]
[
Author Index]