commit
b8ab681e86
@ -0,0 +1 @@
|
||||
SOURCES/gtk+-3.22.30.tar.xz
|
@ -0,0 +1 @@
|
||||
1be769c97b4dac9221d63f62f61ef724c55a14a3 SOURCES/gtk+-3.22.30.tar.xz
|
@ -0,0 +1,79 @@
|
||||
From 044383fe4533c59a0bbd58c977ed2ba5fb5862b8 Mon Sep 17 00:00:00 2001
|
||||
From: Matthias Clasen <mclasen@redhat.com>
|
||||
Date: Fri, 31 May 2019 11:46:19 -0400
|
||||
Subject: [PATCH 1/2] Add a gtk-overlay-scrolling setting
|
||||
|
||||
This is in preparation for letting user opt out of
|
||||
overlay scrolling in the control-center.
|
||||
---
|
||||
gdk/wayland/gdkscreen-wayland.c | 2 +-
|
||||
gdk/x11/gdksettings.c | 1 +
|
||||
gtk/gtksettings.c | 21 ++++++++++++++++++++-
|
||||
3 files changed, 22 insertions(+), 2 deletions(-)
|
||||
|
||||
diff --git a/gdk/wayland/gdkscreen-wayland.c b/gdk/wayland/gdkscreen-wayland.c
|
||||
index 6aff3a5a1a..5e156072f2 100644
|
||||
--- a/gdk/wayland/gdkscreen-wayland.c
|
||||
+++ b/gdk/wayland/gdkscreen-wayland.c
|
||||
@@ -502,6 +502,7 @@ static TranslationEntry translations[] = {
|
||||
{ FALSE, "org.gnome.desktop.interface", "gtk-im-module", "gtk-im-module", G_TYPE_STRING, { .s = "simple" } },
|
||||
{ FALSE, "org.gnome.desktop.interface", "enable-animations", "gtk-enable-animations", G_TYPE_BOOLEAN, { .b = TRUE } },
|
||||
{ FALSE, "org.gnome.desktop.interface", "gtk-enable-primary-paste", "gtk-enable-primary-paste", G_TYPE_BOOLEAN, { .b = TRUE } },
|
||||
+ { FALSE, "org.gnome.desktop.interface", "overlay-scrolling", "gtk-overlay-scrolling", G_TYPE_BOOLEAN, { .b = TRUE } },
|
||||
{ FALSE, "org.gnome.settings-daemon.peripherals.mouse", "double-click", "gtk-double-click-time", G_TYPE_INT, { .i = 400 } },
|
||||
{ FALSE, "org.gnome.settings-daemon.peripherals.mouse", "drag-threshold", "gtk-dnd-drag-threshold", G_TYPE_INT, {.i = 8 } },
|
||||
{ FALSE, "org.gnome.desktop.sound", "theme-name", "gtk-sound-theme-name", G_TYPE_STRING, { .s = "freedesktop" } },
|
||||
diff --git a/gdk/x11/gdksettings.c b/gdk/x11/gdksettings.c
|
||||
index f8bb6d896b..869c239b18 100644
|
||||
--- a/gdk/x11/gdksettings.c
|
||||
+++ b/gdk/x11/gdksettings.c
|
||||
@@ -69,6 +69,7 @@ static const struct {
|
||||
{"Gtk/RecentFilesMaxAge", "gtk-recent-files-max-age"},
|
||||
{"Gtk/RecentFilesEnabled", "gtk-recent-files-enabled"},
|
||||
{"Gtk/KeynavUseCaret", "gtk-keynav-use-caret"},
|
||||
+ {"Gtk/OverlayScrolling", "gtk-overlay-scrolling"},
|
||||
|
||||
/* These are here in order to be recognized, but are not sent to
|
||||
gtk as they are handled internally by gdk: */
|
||||
diff --git a/gtk/gtksettings.c b/gtk/gtksettings.c
|
||||
index 571ae11cd4..b83d9d5561 100644
|
||||
--- a/gtk/gtksettings.c
|
||||
+++ b/gtk/gtksettings.c
|
||||
@@ -224,7 +224,8 @@ enum {
|
||||
PROP_ENABLE_PRIMARY_PASTE,
|
||||
PROP_RECENT_FILES_ENABLED,
|
||||
PROP_LONG_PRESS_TIME,
|
||||
- PROP_KEYNAV_USE_CARET
|
||||
+ PROP_KEYNAV_USE_CARET,
|
||||
+ PROP_OVERLAY_SCROLLING
|
||||
};
|
||||
|
||||
/* --- prototypes --- */
|
||||
@@ -1767,6 +1768,24 @@ gtk_settings_class_init (GtkSettingsClass *class)
|
||||
GTK_PARAM_READWRITE),
|
||||
NULL);
|
||||
g_assert (result == PROP_KEYNAV_USE_CARET);
|
||||
+
|
||||
+ /**
|
||||
+ * GtkSettings:gtk-overlay-scrolling:
|
||||
+ *
|
||||
+ * Whether scrolled windows may use overlayed scrolling indicators.
|
||||
+ * If this is set to %FALSE, scrolled windows will have permanent
|
||||
+ * scrollbars.
|
||||
+ *
|
||||
+ * Since: 3.24.9
|
||||
+ */
|
||||
+ result = settings_install_property_parser (class,
|
||||
+ g_param_spec_boolean ("gtk-overlay-scrolling",
|
||||
+ P_("Whether to use overlay scrollbars"),
|
||||
+ P_("Whether to use overlay scrollbars"),
|
||||
+ TRUE,
|
||||
+ GTK_PARAM_READWRITE),
|
||||
+ NULL);
|
||||
+ g_assert (result == PROP_OVERLAY_SCROLLING);
|
||||
}
|
||||
|
||||
static void
|
||||
--
|
||||
2.23.0
|
||||
|
@ -0,0 +1,29 @@
|
||||
From abcc4773173ed8becb822971edad3f8d14a7a482 Mon Sep 17 00:00:00 2001
|
||||
From: Matthias Clasen <mclasen@redhat.com>
|
||||
Date: Mon, 21 May 2018 17:15:41 -0400
|
||||
Subject: [PATCH] Remove the "without parent" warning
|
||||
|
||||
We've had it for a long time, and it hasn't really made
|
||||
a difference. And I don't think we are prepared to turn
|
||||
this into a hard error. So just drop it.
|
||||
---
|
||||
gtk/gtkdialog.c | 3 ---
|
||||
1 file changed, 3 deletions(-)
|
||||
|
||||
diff --git a/gtk/gtkdialog.c b/gtk/gtkdialog.c
|
||||
index 273c370935..0ef0f08b24 100644
|
||||
--- a/gtk/gtkdialog.c
|
||||
+++ b/gtk/gtkdialog.c
|
||||
@@ -776,9 +776,6 @@ gtk_dialog_map (GtkWidget *widget)
|
||||
GtkWindow *window = GTK_WINDOW (widget);
|
||||
GtkDialog *dialog = GTK_DIALOG (widget);
|
||||
|
||||
- if (gtk_window_get_transient_for (window) == NULL)
|
||||
- g_message ("GtkDialog mapped without a transient parent. This is discouraged.");
|
||||
-
|
||||
GTK_WIDGET_CLASS (gtk_dialog_parent_class)->map (widget);
|
||||
|
||||
focus = gtk_window_get_focus (window);
|
||||
--
|
||||
2.37.0
|
||||
|
@ -0,0 +1,41 @@
|
||||
From 6b91ab848b86aa7968bb421f2f3f30b1c8ad6ba2 Mon Sep 17 00:00:00 2001
|
||||
From: Olivier Fourdan <ofourdan@redhat.com>
|
||||
Date: Mon, 10 Dec 2018 17:05:53 +0100
|
||||
Subject: [PATCH] a11y: Check X11 display at runtime
|
||||
|
||||
`gtk_widget_accessible_grab_focus()` code checks that X11 isenabled at
|
||||
build time and uses X11 specific functions such as
|
||||
`gdk_x11_get_server_time()` regardless of the actual backend being used.
|
||||
|
||||
Check that we are using an X11 display when X11 is backend enabled, so
|
||||
we do not crash when running on Wayland
|
||||
|
||||
Closes: https://gitlab.gnome.org/GNOME/gtk/issues/1507
|
||||
---
|
||||
gtk/a11y/gtkwidgetaccessible.c | 9 +++++----
|
||||
1 file changed, 5 insertions(+), 4 deletions(-)
|
||||
|
||||
diff --git a/gtk/a11y/gtkwidgetaccessible.c b/gtk/a11y/gtkwidgetaccessible.c
|
||||
index 2154e88239..b1b866c39c 100644
|
||||
--- a/gtk/a11y/gtkwidgetaccessible.c
|
||||
+++ b/gtk/a11y/gtkwidgetaccessible.c
|
||||
@@ -648,11 +648,12 @@ gtk_widget_accessible_grab_focus (AtkComponent *component)
|
||||
if (gtk_widget_is_toplevel (toplevel))
|
||||
{
|
||||
#ifdef GDK_WINDOWING_X11
|
||||
- gtk_window_present_with_time (GTK_WINDOW (toplevel),
|
||||
- gdk_x11_get_server_time (gtk_widget_get_window (widget)));
|
||||
-#else
|
||||
- gtk_window_present (GTK_WINDOW (toplevel));
|
||||
+ if (GDK_IS_X11_DISPLAY (gtk_widget_get_display (toplevel)))
|
||||
+ gtk_window_present_with_time (GTK_WINDOW (toplevel),
|
||||
+ gdk_x11_get_server_time (gtk_widget_get_window (widget)));
|
||||
+ else
|
||||
#endif
|
||||
+ gtk_window_present (GTK_WINDOW (toplevel));
|
||||
}
|
||||
return TRUE;
|
||||
}
|
||||
--
|
||||
2.19.2
|
||||
|
@ -0,0 +1,40 @@
|
||||
From e91197a37f6841ada71204cd41f7d0459adffd9a Mon Sep 17 00:00:00 2001
|
||||
From: Olivier Fourdan <ofourdan@redhat.com>
|
||||
Date: Mon, 17 Dec 2018 14:13:05 +0100
|
||||
Subject: [PATCH] a11y: Check display in `*grab_cell_focus()`
|
||||
|
||||
Calling the accessibility function `grab_focus()` on a `GtkCell` under
|
||||
Wayland will cause the client to crash.
|
||||
|
||||
This is another case of `gdk_x11_get_server_time()` being called
|
||||
regardless of the actual windowing backend used.
|
||||
|
||||
Closes: https://gitlab.gnome.org/GNOME/gtk/issues/1507
|
||||
---
|
||||
gtk/a11y/gtktreeviewaccessible.c | 9 +++++----
|
||||
1 file changed, 5 insertions(+), 4 deletions(-)
|
||||
|
||||
diff --git a/gtk/a11y/gtktreeviewaccessible.c b/gtk/a11y/gtktreeviewaccessible.c
|
||||
index efb9c9bc53..eec4480f29 100644
|
||||
--- a/gtk/a11y/gtktreeviewaccessible.c
|
||||
+++ b/gtk/a11y/gtktreeviewaccessible.c
|
||||
@@ -1174,11 +1174,12 @@ gtk_tree_view_accessible_grab_cell_focus (GtkCellAccessibleParent *parent,
|
||||
if (gtk_widget_is_toplevel (toplevel))
|
||||
{
|
||||
#ifdef GDK_WINDOWING_X11
|
||||
- gtk_window_present_with_time (GTK_WINDOW (toplevel),
|
||||
- gdk_x11_get_server_time (gtk_widget_get_window (widget)));
|
||||
-#else
|
||||
- gtk_window_present (GTK_WINDOW (toplevel));
|
||||
+ if (GDK_IS_X11_DISPLAY (gtk_widget_get_display (toplevel)))
|
||||
+ gtk_window_present_with_time (GTK_WINDOW (toplevel),
|
||||
+ gdk_x11_get_server_time (gtk_widget_get_window (widget)));
|
||||
+ else
|
||||
#endif
|
||||
+ gtk_window_present (GTK_WINDOW (toplevel));
|
||||
}
|
||||
|
||||
return TRUE;
|
||||
--
|
||||
2.20.1
|
||||
|
@ -0,0 +1,290 @@
|
||||
From bc1c0584b76e19d5d65bfa2ae809f95113e53c83 Mon Sep 17 00:00:00 2001
|
||||
From: Benjamin Otte <otte@redhat.com>
|
||||
Date: Sun, 21 Jul 2019 23:15:00 +0200
|
||||
Subject: [PATCH] a11y: Include window management buttons in headerbar
|
||||
|
||||
---
|
||||
gtk/a11y/Makefile.inc | 2 +
|
||||
gtk/a11y/gtkheaderbaraccessible.c | 87 +++++++++++++++++++++++++++++++
|
||||
gtk/a11y/gtkheaderbaraccessible.h | 55 +++++++++++++++++++
|
||||
gtk/gtkcontainerprivate.h | 1 +
|
||||
gtk/gtkheaderbar.c | 3 +-
|
||||
6 files changed, 149 insertions(+), 1 deletion(-)
|
||||
create mode 100644 gtk/a11y/gtkheaderbaraccessible.c
|
||||
create mode 100644 gtk/a11y/gtkheaderbaraccessible.h
|
||||
|
||||
diff --git a/gtk/a11y/Makefile.inc b/gtk/a11y/Makefile.inc
|
||||
index 8529c7ae57..3ed6c5decd 100644
|
||||
--- a/gtk/a11y/Makefile.inc
|
||||
+++ b/gtk/a11y/Makefile.inc
|
||||
@@ -14,6 +14,7 @@ a11y_h_sources = \
|
||||
a11y/gtkflowboxaccessible.h \
|
||||
a11y/gtkflowboxchildaccessible.h \
|
||||
a11y/gtkframeaccessible.h \
|
||||
+ a11y/gtkheaderbaraccessible.h \
|
||||
a11y/gtkiconviewaccessible.h \
|
||||
a11y/gtkimageaccessible.h \
|
||||
a11y/gtkimagecellaccessible.h \
|
||||
@@ -88,6 +89,7 @@ a11y_c_sources = \
|
||||
a11y/gtkflowboxaccessible.c \
|
||||
a11y/gtkflowboxchildaccessible.c \
|
||||
a11y/gtkframeaccessible.c \
|
||||
+ a11y/gtkheaderbaraccessible.c \
|
||||
a11y/gtkiconviewaccessible.c \
|
||||
a11y/gtkimageaccessible.c \
|
||||
a11y/gtkimagecellaccessible.c \
|
||||
--- a/gtk/Makefile.in
|
||||
+++ b/gtk/Makefile.in
|
||||
@@ -281,6 +281,7 @@
|
||||
a11y/gtkcontainercellaccessible.c a11y/gtkentryaccessible.c \
|
||||
a11y/gtkexpanderaccessible.c a11y/gtkflowboxaccessible.c \
|
||||
a11y/gtkflowboxchildaccessible.c a11y/gtkframeaccessible.c \
|
||||
+ a11y/gtkheaderbaraccessible.c \
|
||||
a11y/gtkiconviewaccessible.c a11y/gtkimageaccessible.c \
|
||||
a11y/gtkimagecellaccessible.c a11y/gtklabelaccessible.c \
|
||||
a11y/gtklevelbaraccessible.c a11y/gtklinkbuttonaccessible.c \
|
||||
@@ -487,6 +488,7 @@
|
||||
a11y/libgtk_3_la-gtkflowboxaccessible.lo \
|
||||
a11y/libgtk_3_la-gtkflowboxchildaccessible.lo \
|
||||
a11y/libgtk_3_la-gtkframeaccessible.lo \
|
||||
+ a11y/libgtk_3_la-gtkheaderbaraccessible.lo \
|
||||
a11y/libgtk_3_la-gtkiconviewaccessible.lo \
|
||||
a11y/libgtk_3_la-gtkimageaccessible.lo \
|
||||
a11y/libgtk_3_la-gtkimagecellaccessible.lo \
|
||||
@@ -1389,6 +1391,7 @@
|
||||
a11y/gtkflowboxaccessible.h \
|
||||
a11y/gtkflowboxchildaccessible.h \
|
||||
a11y/gtkframeaccessible.h \
|
||||
+ a11y/gtkheaderbaraccessible.h \
|
||||
a11y/gtkiconviewaccessible.h \
|
||||
a11y/gtkimageaccessible.h \
|
||||
a11y/gtkimagecellaccessible.h \
|
||||
@@ -1463,6 +1466,7 @@
|
||||
a11y/gtkflowboxaccessible.c \
|
||||
a11y/gtkflowboxchildaccessible.c \
|
||||
a11y/gtkframeaccessible.c \
|
||||
+ a11y/gtkheaderbaraccessible.c \
|
||||
a11y/gtkiconviewaccessible.c \
|
||||
a11y/gtkimageaccessible.c \
|
||||
a11y/gtkimagecellaccessible.c \
|
||||
@@ -2702,6 +2706,8 @@
|
||||
a11y/$(DEPDIR)/$(am__dirstamp)
|
||||
a11y/libgtk_3_la-gtkframeaccessible.lo: a11y/$(am__dirstamp) \
|
||||
a11y/$(DEPDIR)/$(am__dirstamp)
|
||||
+a11y/libgtk_3_la-gtkheaderbaraccessible.lo: a11y/$(am__dirstamp) \
|
||||
+ a11y/$(DEPDIR)/$(am__dirstamp)
|
||||
a11y/libgtk_3_la-gtkiconviewaccessible.lo: a11y/$(am__dirstamp) \
|
||||
a11y/$(DEPDIR)/$(am__dirstamp)
|
||||
a11y/libgtk_3_la-gtkimageaccessible.lo: a11y/$(am__dirstamp) \
|
||||
@@ -3447,6 +3453,7 @@
|
||||
@AMDEP_TRUE@@am__include@ @am__quote@a11y/$(DEPDIR)/libgtk_3_la-gtkflowboxaccessible.Plo@am__quote@
|
||||
@AMDEP_TRUE@@am__include@ @am__quote@a11y/$(DEPDIR)/libgtk_3_la-gtkflowboxchildaccessible.Plo@am__quote@
|
||||
@AMDEP_TRUE@@am__include@ @am__quote@a11y/$(DEPDIR)/libgtk_3_la-gtkframeaccessible.Plo@am__quote@
|
||||
+@AMDEP_TRUE@@am__include@ @am__quote@a11y/$(DEPDIR)/libgtk_3_la-gtkheaderbaraccessible.Plo@am__quote@
|
||||
@AMDEP_TRUE@@am__include@ @am__quote@a11y/$(DEPDIR)/libgtk_3_la-gtkiconviewaccessible.Plo@am__quote@
|
||||
@AMDEP_TRUE@@am__include@ @am__quote@a11y/$(DEPDIR)/libgtk_3_la-gtkimageaccessible.Plo@am__quote@
|
||||
@AMDEP_TRUE@@am__include@ @am__quote@a11y/$(DEPDIR)/libgtk_3_la-gtkimagecellaccessible.Plo@am__quote@
|
||||
@@ -3705,6 +3712,13 @@
|
||||
@AMDEP_TRUE@@am__fastdepCC_FALSE@ DEPDIR=$(DEPDIR) $(CCDEPMODE) $(depcomp) @AMDEPBACKSLASH@
|
||||
@am__fastdepCC_FALSE@ $(AM_V_CC@am__nodep@)$(LIBTOOL) $(AM_V_lt) --tag=CC $(AM_LIBTOOLFLAGS) $(LIBTOOLFLAGS) --mode=compile $(CC) $(DEFS) $(DEFAULT_INCLUDES) $(INCLUDES) $(AM_CPPFLAGS) $(CPPFLAGS) $(libgtk_3_la_CFLAGS) $(CFLAGS) -c -o a11y/libgtk_3_la-gtkframeaccessible.lo `test -f 'a11y/gtkframeaccessible.c' || echo '$(srcdir)/'`a11y/gtkframeaccessible.c
|
||||
|
||||
+a11y/libgtk_3_la-gtkheaderbaraccessible.lo: a11y/gtkheaderbaraccessible.c
|
||||
+@am__fastdepCC_TRUE@ $(AM_V_CC)$(LIBTOOL) $(AM_V_lt) --tag=CC $(AM_LIBTOOLFLAGS) $(LIBTOOLFLAGS) --mode=compile $(CC) $(DEFS) $(DEFAULT_INCLUDES) $(INCLUDES) $(AM_CPPFLAGS) $(CPPFLAGS) $(libgtk_3_la_CFLAGS) $(CFLAGS) -MT a11y/libgtk_3_la-gtkheaderbaraccessible.lo -MD -MP -MF a11y/$(DEPDIR)/libgtk_3_la-gtkheaderbaraccessible.Tpo -c -o a11y/libgtk_3_la-gtkheaderbaraccessible.lo `test -f 'a11y/gtkheaderbaraccessible.c' || echo '$(srcdir)/'`a11y/gtkheaderbaraccessible.c
|
||||
+@am__fastdepCC_TRUE@ $(AM_V_at)$(am__mv) a11y/$(DEPDIR)/libgtk_3_la-gtkheaderbaraccessible.Tpo a11y/$(DEPDIR)/libgtk_3_la-gtkheaderbaraccessible.Plo
|
||||
+@AMDEP_TRUE@@am__fastdepCC_FALSE@ $(AM_V_CC)source='a11y/gtkheaderbaraccessible.c' object='a11y/libgtk_3_la-gtkheaderbaraccessible.lo' libtool=yes @AMDEPBACKSLASH@
|
||||
+@AMDEP_TRUE@@am__fastdepCC_FALSE@ DEPDIR=$(DEPDIR) $(CCDEPMODE) $(depcomp) @AMDEPBACKSLASH@
|
||||
+@am__fastdepCC_FALSE@ $(AM_V_CC@am__nodep@)$(LIBTOOL) $(AM_V_lt) --tag=CC $(AM_LIBTOOLFLAGS) $(LIBTOOLFLAGS) --mode=compile $(CC) $(DEFS) $(DEFAULT_INCLUDES) $(INCLUDES) $(AM_CPPFLAGS) $(CPPFLAGS) $(libgtk_3_la_CFLAGS) $(CFLAGS) -c -o a11y/libgtk_3_la-gtkheaderbaraccessible.lo `test -f 'a11y/gtkheaderbaraccessible.c' || echo '$(srcdir)/'`a11y/gtkheaderbaraccessible.c
|
||||
+
|
||||
a11y/libgtk_3_la-gtkiconviewaccessible.lo: a11y/gtkiconviewaccessible.c
|
||||
@am__fastdepCC_TRUE@ $(AM_V_CC)$(LIBTOOL) $(AM_V_lt) --tag=CC $(AM_LIBTOOLFLAGS) $(LIBTOOLFLAGS) --mode=compile $(CC) $(DEFS) $(DEFAULT_INCLUDES) $(INCLUDES) $(AM_CPPFLAGS) $(CPPFLAGS) $(libgtk_3_la_CFLAGS) $(CFLAGS) -MT a11y/libgtk_3_la-gtkiconviewaccessible.lo -MD -MP -MF a11y/$(DEPDIR)/libgtk_3_la-gtkiconviewaccessible.Tpo -c -o a11y/libgtk_3_la-gtkiconviewaccessible.lo `test -f 'a11y/gtkiconviewaccessible.c' || echo '$(srcdir)/'`a11y/gtkiconviewaccessible.c
|
||||
@am__fastdepCC_TRUE@ $(AM_V_at)$(am__mv) a11y/$(DEPDIR)/libgtk_3_la-gtkiconviewaccessible.Tpo a11y/$(DEPDIR)/libgtk_3_la-gtkiconviewaccessible.Plo
|
||||
diff --git a/gtk/a11y/gtkheaderbaraccessible.c b/gtk/a11y/gtkheaderbaraccessible.c
|
||||
new file mode 100644
|
||||
index 0000000000..3610ac0d1f
|
||||
--- /dev/null
|
||||
+++ b/gtk/a11y/gtkheaderbaraccessible.c
|
||||
@@ -0,0 +1,87 @@
|
||||
+/* GTK+ - accessibility implementations
|
||||
+ * Copyright 2001, 2002, 2003 Sun Microsystems Inc.
|
||||
+ *
|
||||
+ * This library is free software; you can redistribute it and/or
|
||||
+ * modify it under the terms of the GNU Lesser 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
|
||||
+ * Lesser General Public License for more details.
|
||||
+ *
|
||||
+ * You should have received a copy of the GNU Lesser General Public
|
||||
+ * License along with this library. If not, see <http://www.gnu.org/licenses/>.
|
||||
+ */
|
||||
+
|
||||
+#include "config.h"
|
||||
+
|
||||
+#include "gtkheaderbaraccessible.h"
|
||||
+
|
||||
+#include "gtkcontainerprivate.h"
|
||||
+
|
||||
+G_DEFINE_TYPE (GtkHeaderBarAccessible, gtk_header_bar_accessible, GTK_TYPE_CONTAINER_ACCESSIBLE)
|
||||
+
|
||||
+static void
|
||||
+count_widget (GtkWidget *widget,
|
||||
+ gint *count)
|
||||
+{
|
||||
+ (*count)++;
|
||||
+}
|
||||
+
|
||||
+static gint
|
||||
+gtk_header_bar_accessible_get_n_children (AtkObject* obj)
|
||||
+{
|
||||
+ GtkWidget *widget;
|
||||
+ gint count = 0;
|
||||
+
|
||||
+ widget = gtk_accessible_get_widget (GTK_ACCESSIBLE (obj));
|
||||
+ if (widget == NULL)
|
||||
+ return 0;
|
||||
+
|
||||
+ gtk_container_forall (GTK_CONTAINER (widget), (GtkCallback) count_widget, &count);
|
||||
+ return count;
|
||||
+}
|
||||
+
|
||||
+static AtkObject *
|
||||
+gtk_header_bar_accessible_ref_child (AtkObject *obj,
|
||||
+ gint i)
|
||||
+{
|
||||
+ GList *children, *tmp_list;
|
||||
+ AtkObject *accessible;
|
||||
+ GtkWidget *widget;
|
||||
+
|
||||
+ widget = gtk_accessible_get_widget (GTK_ACCESSIBLE (obj));
|
||||
+ if (widget == NULL)
|
||||
+ return NULL;
|
||||
+
|
||||
+ children = gtk_container_get_all_children (GTK_CONTAINER (widget));
|
||||
+ tmp_list = g_list_nth (children, i);
|
||||
+ if (!tmp_list)
|
||||
+ {
|
||||
+ g_list_free (children);
|
||||
+ return NULL;
|
||||
+ }
|
||||
+ accessible = gtk_widget_get_accessible (GTK_WIDGET (tmp_list->data));
|
||||
+
|
||||
+ g_list_free (children);
|
||||
+ g_object_ref (accessible);
|
||||
+
|
||||
+ return accessible;
|
||||
+}
|
||||
+
|
||||
+static void
|
||||
+gtk_header_bar_accessible_class_init (GtkHeaderBarAccessibleClass *klass)
|
||||
+{
|
||||
+ AtkObjectClass *class = ATK_OBJECT_CLASS (klass);
|
||||
+
|
||||
+ class->get_n_children = gtk_header_bar_accessible_get_n_children;
|
||||
+ class->ref_child = gtk_header_bar_accessible_ref_child;
|
||||
+}
|
||||
+
|
||||
+static void
|
||||
+gtk_header_bar_accessible_init (GtkHeaderBarAccessible *header_bar)
|
||||
+{
|
||||
+}
|
||||
+
|
||||
diff --git a/gtk/a11y/gtkheaderbaraccessible.h b/gtk/a11y/gtkheaderbaraccessible.h
|
||||
new file mode 100644
|
||||
index 0000000000..fca9428a94
|
||||
--- /dev/null
|
||||
+++ b/gtk/a11y/gtkheaderbaraccessible.h
|
||||
@@ -0,0 +1,55 @@
|
||||
+/* GTK+ - accessibility implementations
|
||||
+ * Copyright 2001, 2002, 2003 Sun Microsystems 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_HEADER_BAR_ACCESSIBLE_H__
|
||||
+#define __GTK_HEADER_BAR_ACCESSIBLE_H__
|
||||
+
|
||||
+#if !defined (__GTK_A11Y_H_INSIDE__) && !defined (GTK_COMPILATION)
|
||||
+#error "Only <gtk/gtk-a11y.h> can be included directly."
|
||||
+#endif
|
||||
+
|
||||
+#include <gtk/a11y/gtkcontaineraccessible.h>
|
||||
+
|
||||
+G_BEGIN_DECLS
|
||||
+
|
||||
+#define GTK_TYPE_HEADER_BAR_ACCESSIBLE (gtk_header_bar_accessible_get_type ())
|
||||
+#define GTK_HEADER_BAR_ACCESSIBLE(obj) (G_TYPE_CHECK_INSTANCE_CAST ((obj), GTK_TYPE_HEADER_BAR_ACCESSIBLE, GtkHeaderBarAccessible))
|
||||
+#define GTK_HEADER_BAR_ACCESSIBLE_CLASS(klass) (G_TYPE_CHECK_CLASS_CAST ((klass), GTK_TYPE_HEADER_BAR_ACCESSIBLE, GtkHeaderBarAccessibleClass))
|
||||
+#define GTK_IS_HEADER_BAR_ACCESSIBLE(obj) (G_TYPE_CHECK_INSTANCE_TYPE ((obj), GTK_TYPE_HEADER_BAR_ACCESSIBLE))
|
||||
+#define GTK_IS_HEADER_BAR_ACCESSIBLE_CLASS(klass) (G_TYPE_CHECK_CLASS_TYPE ((klass), GTK_TYPE_HEADER_BAR_ACCESSIBLE))
|
||||
+#define GTK_HEADER_BAR_ACCESSIBLE_GET_CLASS(obj) (G_TYPE_INSTANCE_GET_CLASS ((obj), GTK_TYPE_HEADER_BAR_ACCESSIBLE, GtkHeaderBarAccessibleClass))
|
||||
+
|
||||
+typedef struct _GtkHeaderBarAccessible GtkHeaderBarAccessible;
|
||||
+typedef struct _GtkHeaderBarAccessibleClass GtkHeaderBarAccessibleClass;
|
||||
+typedef struct _GtkHeaderBarAccessiblePrivate GtkHeaderBarAccessiblePrivate;
|
||||
+
|
||||
+struct _GtkHeaderBarAccessible
|
||||
+{
|
||||
+ GtkContainerAccessible parent;
|
||||
+};
|
||||
+
|
||||
+struct _GtkHeaderBarAccessibleClass
|
||||
+{
|
||||
+ GtkContainerAccessibleClass parent_class;
|
||||
+};
|
||||
+
|
||||
+GDK_AVAILABLE_IN_ALL
|
||||
+GType gtk_header_bar_accessible_get_type (void);
|
||||
+
|
||||
+G_END_DECLS
|
||||
+
|
||||
+#endif /* __GTK_HEADER_BAR_ACCESSIBLE_H__ */
|
||||
diff --git a/gtk/gtkcontainerprivate.h b/gtk/gtkcontainerprivate.h
|
||||
index 7402a6676b..547e0295c3 100644
|
||||
--- a/gtk/gtkcontainerprivate.h
|
||||
+++ b/gtk/gtkcontainerprivate.h
|
||||
@@ -42,6 +42,7 @@ void _gtk_container_maybe_start_idle_sizer (GtkContainer *container);
|
||||
gboolean _gtk_container_get_border_width_set (GtkContainer *container);
|
||||
void _gtk_container_set_border_width_set (GtkContainer *container,
|
||||
gboolean border_width_set);
|
||||
+GList * gtk_container_get_all_children (GtkContainer *container);
|
||||
void gtk_container_get_children_clip (GtkContainer *container,
|
||||
GtkAllocation *out_clip);
|
||||
void gtk_container_set_default_resize_mode (GtkContainer *container,
|
||||
diff --git a/gtk/gtkheaderbar.c b/gtk/gtkheaderbar.c
|
||||
index dd7d2093c9..0ef94e3c84 100644
|
||||
--- a/gtk/gtkheaderbar.c
|
||||
+++ b/gtk/gtkheaderbar.c
|
||||
@@ -30,7 +30,7 @@
|
||||
#include "gtkwindowprivate.h"
|
||||
#include "gtkwidgetprivate.h"
|
||||
#include "gtkcontainerprivate.h"
|
||||
-#include "a11y/gtkcontaineraccessible.h"
|
||||
+#include "a11y/gtkheaderbaraccessible.h"
|
||||
|
||||
#include <string.h>
|
||||
|
||||
@@ -2118,6 +2118,7 @@ gtk_header_bar_class_init (GtkHeaderBarClass *class)
|
||||
|
||||
g_object_class_install_properties (object_class, LAST_PROP, header_bar_props);
|
||||
|
||||
+ gtk_widget_class_set_accessible_type (widget_class, GTK_TYPE_HEADER_BAR_ACCESSIBLE);
|
||||
gtk_widget_class_set_accessible_role (widget_class, ATK_ROLE_PANEL);
|
||||
gtk_widget_class_set_css_name (widget_class, "headerbar");
|
||||
}
|
||||
--
|
||||
2.21.0
|
||||
|
@ -0,0 +1,41 @@
|
||||
From 12a00f024c16a4540d5f457389fada2a4886d884 Mon Sep 17 00:00:00 2001
|
||||
From: Matthias Clasen <mclasen@redhat.com>
|
||||
Date: Tue, 25 May 2021 16:07:58 -0400
|
||||
Subject: [PATCH] entry: Only offer Emoji if requested
|
||||
|
||||
Only offer the "Insert Emoji" context menu when input
|
||||
hints explicitly suggest supporting Emoji.
|
||||
---
|
||||
gtk/gtkentry.c | 2 +-
|
||||
gtk/gtktextview.c | 2 +-
|
||||
2 files changed, 2 insertions(+), 2 deletions(-)
|
||||
|
||||
diff --git a/gtk/gtkentry.c b/gtk/gtkentry.c
|
||||
index a01684101f..1f5a790ccc 100644
|
||||
--- a/gtk/gtkentry.c
|
||||
+++ b/gtk/gtkentry.c
|
||||
@@ -9591,7 +9591,7 @@ popup_targets_received (GtkClipboard *clipboard,
|
||||
gtk_menu_shell_append (GTK_MENU_SHELL (menu), menuitem);
|
||||
|
||||
if (info_entry_priv->show_emoji_icon ||
|
||||
- (gtk_entry_get_input_hints (entry) & GTK_INPUT_HINT_NO_EMOJI) == 0)
|
||||
+ (gtk_entry_get_input_hints (entry) & GTK_INPUT_HINT_EMOJI) != 0)
|
||||
{
|
||||
menuitem = gtk_menu_item_new_with_mnemonic (_("Insert _Emoji"));
|
||||
gtk_widget_set_sensitive (menuitem,
|
||||
diff --git a/gtk/gtktextview.c b/gtk/gtktextview.c
|
||||
index e0b1e20e87..eb53843fa6 100644
|
||||
--- a/gtk/gtktextview.c
|
||||
+++ b/gtk/gtktextview.c
|
||||
@@ -9521,7 +9521,7 @@ popup_targets_received (GtkClipboard *clipboard,
|
||||
gtk_widget_show (menuitem);
|
||||
gtk_menu_shell_append (GTK_MENU_SHELL (priv->popup_menu), menuitem);
|
||||
|
||||
- if ((gtk_text_view_get_input_hints (text_view) & GTK_INPUT_HINT_NO_EMOJI) == 0)
|
||||
+ if ((gtk_text_view_get_input_hints (text_view) & GTK_INPUT_HINT_EMOJI) != 0)
|
||||
{
|
||||
menuitem = gtk_menu_item_new_with_mnemonic (_("Insert _Emoji"));
|
||||
gtk_widget_set_sensitive (menuitem, can_insert);
|
||||
--
|
||||
2.31.1
|
||||
|
@ -0,0 +1,72 @@
|
||||
diff --git a/gtk/gtkscrolledwindow.c b/gtk/gtkscrolledwindow.c
|
||||
index 19090772201388c31bffba9f56db0e6e707f6093..a931d2bad5094aec76fc91c57792034357ed94d1 100644
|
||||
--- a/gtk/gtkscrolledwindow.c
|
||||
+++ b/gtk/gtkscrolledwindow.c
|
||||
@@ -1900,10 +1900,19 @@ gtk_scrolled_window_measure (GtkCssGadget *gadget,
|
||||
*/
|
||||
if (policy_may_be_visible (priv->hscrollbar_policy))
|
||||
{
|
||||
- minimum_req.width = MAX (minimum_req.width, hscrollbar_requisition.width + sborder.left + sborder.right);
|
||||
- natural_req.width = MAX (natural_req.width, hscrollbar_requisition.width + sborder.left + sborder.right);
|
||||
+ int vscrollbar_extra_size;
|
||||
|
||||
- if (!priv->use_indicators && priv->hscrollbar_policy == GTK_POLICY_ALWAYS)
|
||||
+ if (!priv->use_indicators && policy_may_be_visible (priv->vscrollbar_policy))
|
||||
+ vscrollbar_extra_size = vscrollbar_requisition.width;
|
||||
+ else
|
||||
+ vscrollbar_extra_size = 0;
|
||||
+
|
||||
+ minimum_req.width = MAX (minimum_req.width,
|
||||
+ hscrollbar_requisition.width + sborder.left + sborder.right + vscrollbar_extra_size);
|
||||
+ natural_req.width = MAX (natural_req.width,
|
||||
+ hscrollbar_requisition.width + sborder.left + sborder.right + vscrollbar_extra_size);
|
||||
+
|
||||
+ if (!priv->use_indicators)
|
||||
{
|
||||
minimum_req.height += scrollbar_spacing + hscrollbar_requisition.height;
|
||||
natural_req.height += scrollbar_spacing + hscrollbar_requisition.height;
|
||||
@@ -1912,10 +1921,19 @@ gtk_scrolled_window_measure (GtkCssGadget *gadget,
|
||||
|
||||
if (policy_may_be_visible (priv->vscrollbar_policy))
|
||||
{
|
||||
- minimum_req.height = MAX (minimum_req.height, vscrollbar_requisition.height + sborder.top + sborder.bottom);
|
||||
- natural_req.height = MAX (natural_req.height, vscrollbar_requisition.height + sborder.top + sborder.bottom);
|
||||
+ int hscrollbar_extra_size;
|
||||
+
|
||||
+ if (!priv->use_indicators && policy_may_be_visible (priv->hscrollbar_policy))
|
||||
+ hscrollbar_extra_size = hscrollbar_requisition.height;
|
||||
+ else
|
||||
+ hscrollbar_extra_size = 0;
|
||||
+
|
||||
+ minimum_req.height = MAX (minimum_req.height,
|
||||
+ vscrollbar_requisition.height + sborder.top + sborder.bottom + hscrollbar_extra_size);
|
||||
+ natural_req.height = MAX (natural_req.height,
|
||||
+ vscrollbar_requisition.height + sborder.top + sborder.bottom + hscrollbar_extra_size);
|
||||
|
||||
- if (!priv->use_indicators && priv->vscrollbar_policy == GTK_POLICY_ALWAYS)
|
||||
+ if (!priv->use_indicators)
|
||||
{
|
||||
minimum_req.width += scrollbar_spacing + vscrollbar_requisition.width;
|
||||
natural_req.width += scrollbar_spacing + vscrollbar_requisition.width;
|
||||
diff --git a/testsuite/gtk/scrolledwindow.c b/testsuite/gtk/scrolledwindow.c
|
||||
index c6093d8256e52071e00885d266d92b5bb7e664f7..e141fe35baa628592114e6cceebe8863b7b078dd 100644
|
||||
--- a/testsuite/gtk/scrolledwindow.c
|
||||
+++ b/testsuite/gtk/scrolledwindow.c
|
||||
@@ -58,7 +58,7 @@ test_size (gboolean overlay,
|
||||
/* If the relevant scrollbar is non-overlay and always shown, it is added
|
||||
* to the preferred size. When comparing to the expected size, we need to
|
||||
* to exclude that extra, as we are only interested in the content size */
|
||||
- if (!overlay && policy == GTK_POLICY_ALWAYS)
|
||||
+ if (!overlay)
|
||||
{
|
||||
GtkWidget *scrollbar = gtk_scrolled_window_get_vscrollbar (GTK_SCROLLED_WINDOW (scrolledwindow));
|
||||
gtk_widget_get_preferred_width (scrollbar, &scrollbar_size, NULL);
|
||||
@@ -87,7 +87,7 @@ test_size (gboolean overlay,
|
||||
gtk_widget_get_preferred_height (box, &child_size, NULL);
|
||||
}
|
||||
|
||||
- if (!overlay && policy == GTK_POLICY_ALWAYS)
|
||||
+ if (!overlay)
|
||||
{
|
||||
GtkWidget *scrollbar = gtk_scrolled_window_get_hscrollbar (GTK_SCROLLED_WINDOW (scrolledwindow));
|
||||
gtk_widget_get_preferred_height (scrollbar, &scrollbar_size, NULL);
|
@ -0,0 +1,70 @@
|
||||
From b541ad48d1c7060e2d38205d4874675e27578b9b Mon Sep 17 00:00:00 2001
|
||||
From: Matthias Clasen <mclasen@redhat.com>
|
||||
Date: Mon, 19 Jul 2021 13:10:31 -0400
|
||||
Subject: [PATCH] reftests: Enforce default settings
|
||||
|
||||
Set all settings to their default values, so we
|
||||
are less dependent on the environment to be set
|
||||
up just right. In particular, this fixes animations
|
||||
being disabled when we happen to run in a vm.
|
||||
---
|
||||
testsuite/reftests/gtk-reftest.c | 36 ++++++++++++++++++++++++++++++++
|
||||
1 file changed, 36 insertions(+)
|
||||
|
||||
diff --git a/testsuite/reftests/gtk-reftest.c b/testsuite/reftests/gtk-reftest.c
|
||||
index 585e1c393d..1a51a9756b 100644
|
||||
--- a/testsuite/reftests/gtk-reftest.c
|
||||
+++ b/testsuite/reftests/gtk-reftest.c
|
||||
@@ -368,6 +368,40 @@ add_test_for_file (GFile *file)
|
||||
g_list_free_full (files, g_object_unref);
|
||||
}
|
||||
|
||||
+static void
|
||||
+enforce_default_settings (void)
|
||||
+{
|
||||
+ GtkSettings *settings;
|
||||
+ GTypeClass *klass;
|
||||
+ GParamSpec **pspecs;
|
||||
+ guint n_pspecs;
|
||||
+ int i;
|
||||
+
|
||||
+ settings = gtk_settings_get_default ();
|
||||
+
|
||||
+ klass = g_type_class_ref (G_OBJECT_TYPE (settings));
|
||||
+
|
||||
+ pspecs = g_object_class_list_properties (klass, &n_pspecs);
|
||||
+ for (i = 0; i < n_pspecs; i++)
|
||||
+ {
|
||||
+ GParamSpec *pspec = pspecs[i];
|
||||
+ const GValue *value;
|
||||
+
|
||||
+ if ((pspec->flags & G_PARAM_WRITABLE) == 0)
|
||||
+ continue;
|
||||
+
|
||||
+ if (pspec->value_type == G_TYPE_HASH_TABLE)
|
||||
+ continue;
|
||||
+
|
||||
+ value = g_param_spec_get_default_value (pspec);
|
||||
+ g_object_set_property (settings, pspec->name, value);
|
||||
+ }
|
||||
+
|
||||
+ g_free (pspecs);
|
||||
+
|
||||
+ g_type_class_unref (klass);
|
||||
+}
|
||||
+
|
||||
int
|
||||
main (int argc, char **argv)
|
||||
{
|
||||
@@ -382,6 +416,8 @@ main (int argc, char **argv)
|
||||
if (!parse_command_line (&argc, &argv))
|
||||
return 1;
|
||||
|
||||
+ enforce_default_settings ();
|
||||
+
|
||||
if (arg_base_dir)
|
||||
basedir = arg_base_dir;
|
||||
else
|
||||
--
|
||||
2.31.1
|
||||
|
@ -0,0 +1,50 @@
|
||||
From 26b24916c8570a73bdc9d7a736584ceb68384c81 Mon Sep 17 00:00:00 2001
|
||||
From: Matthias Clasen <mclasen@redhat.com>
|
||||
Date: Fri, 31 May 2019 11:51:20 -0400
|
||||
Subject: [PATCH 2/2] scrolled window: respect overlay-scrolling setting
|
||||
|
||||
If the gtk-overlay-scrolling setting is FALSE,
|
||||
don't use overlay scrollbars.
|
||||
---
|
||||
gtk/gtkscrolledwindow.c | 10 +++++++++-
|
||||
1 file changed, 9 insertions(+), 1 deletion(-)
|
||||
|
||||
diff --git a/gtk/gtkscrolledwindow.c b/gtk/gtkscrolledwindow.c
|
||||
index d52ccf646c..b2dc1d1c79 100644
|
||||
--- a/gtk/gtkscrolledwindow.c
|
||||
+++ b/gtk/gtkscrolledwindow.c
|
||||
@@ -704,6 +704,9 @@ gtk_scrolled_window_class_init (GtkScrolledWindowClass *class)
|
||||
* is present. Otherwise, they are overlayed on top of the content,
|
||||
* as narrow indicators.
|
||||
*
|
||||
+ * Note that overlay scrolling can also be globally disabled, with
|
||||
+ * the #GtkSettings::gtk-overlay-scrolling setting.
|
||||
+ *
|
||||
* Since: 3.16
|
||||
*/
|
||||
properties[PROP_OVERLAY_SCROLLING] =
|
||||
@@ -4163,6 +4166,7 @@ gtk_scrolled_window_map (GtkWidget *widget)
|
||||
GTK_WIDGET_CLASS (gtk_scrolled_window_parent_class)->map (widget);
|
||||
|
||||
gtk_scrolled_window_update_animating (scrolled_window);
|
||||
+ gtk_scrolled_window_update_use_indicators (scrolled_window);
|
||||
}
|
||||
|
||||
static void
|
||||
@@ -4439,8 +4443,12 @@ gtk_scrolled_window_update_use_indicators (GtkScrolledWindow *scrolled_window)
|
||||
{
|
||||
GtkScrolledWindowPrivate *priv = scrolled_window->priv;
|
||||
gboolean use_indicators;
|
||||
+ GtkSettings *settings = gtk_widget_get_settings (GTK_WIDGET (scrolled_window));
|
||||
+ gboolean overlay_scrolling;
|
||||
+
|
||||
+ g_object_get (settings, "gtk-overlay-scrolling", &overlay_scrolling, NULL);
|
||||
|
||||
- use_indicators = priv->overlay_scrolling;
|
||||
+ use_indicators = overlay_scrolling && priv->overlay_scrolling;
|
||||
|
||||
if (g_strcmp0 (g_getenv ("GTK_OVERLAY_SCROLLING"), "0") == 0)
|
||||
use_indicators = FALSE;
|
||||
--
|
||||
2.23.0
|
||||
|
@ -0,0 +1,40 @@
|
||||
From 4ba89f25b8a88616afc1915bdb4fb87d13efae6f Mon Sep 17 00:00:00 2001
|
||||
From: Benjamin Otte <otte@redhat.com>
|
||||
Date: Tue, 15 Jun 2021 19:34:37 +0200
|
||||
Subject: [PATCH] cellarea: Don't shrink area too much
|
||||
|
||||
Do not compute rectangles with negative width/height. This avoids
|
||||
assertion failures further down when those rectangles were actually
|
||||
checked.
|
||||
|
||||
https://bugzilla.redhat.com/show_bug.cgi?id=1962215
|
||||
---
|
||||
gtk/gtkcellarea.c | 10 ++++++++++
|
||||
1 file changed, 10 insertions(+)
|
||||
|
||||
diff --git a/gtk/gtkcellarea.c b/gtk/gtkcellarea.c
|
||||
index 575e1c7fde..d1b3b1a279 100644
|
||||
--- a/gtk/gtkcellarea.c
|
||||
+++ b/gtk/gtkcellarea.c
|
||||
@@ -3563,8 +3563,18 @@ gtk_cell_area_inner_cell_area (GtkCellArea *area,
|
||||
|
||||
*inner_area = *cell_area;
|
||||
|
||||
+ if (border.left + border.right > cell_area->width)
|
||||
+ {
|
||||
+ border.left = cell_area->width / 2;
|
||||
+ border.right = (cell_area->width + 1) / 2;
|
||||
+ }
|
||||
inner_area->x += border.left;
|
||||
inner_area->width -= border.left + border.right;
|
||||
+ if (border.top + border.bottom > cell_area->height)
|
||||
+ {
|
||||
+ border.top = cell_area->height / 2;
|
||||
+ border.bottom = (cell_area->height + 1) / 2;
|
||||
+ }
|
||||
inner_area->y += border.top;
|
||||
inner_area->height -= border.top + border.bottom;
|
||||
}
|
||||
--
|
||||
GitLab
|
||||
|
@ -0,0 +1,91 @@
|
||||
From d4f62b44d47e3dddfb57add4f1f76cab0297584d Mon Sep 17 00:00:00 2001
|
||||
From: Matthias Clasen <mclasen@redhat.com>
|
||||
Date: Fri, 11 Jun 2021 08:53:46 -0400
|
||||
Subject: [PATCH 1/2] a11y: Fix ref counting in tree views
|
||||
|
||||
GtkContainerCellAccessible wasn't unsetting accessible
|
||||
parents. Fix that.
|
||||
|
||||
By itself, this doesn't help for freeing a memory leak,
|
||||
since AtkObject keeps a ref on its parent, so we never
|
||||
free the GtkContainerCellAccessible as long as it has children.
|
||||
---
|
||||
gtk/a11y/gtkcontainercellaccessible.c | 10 +++++++++-
|
||||
1 file changed, 9 insertions(+), 1 deletion(-)
|
||||
|
||||
diff --git a/gtk/a11y/gtkcontainercellaccessible.c b/gtk/a11y/gtkcontainercellaccessible.c
|
||||
index a756e3cadf..a40446fb47 100644
|
||||
--- a/gtk/a11y/gtkcontainercellaccessible.c
|
||||
+++ b/gtk/a11y/gtkcontainercellaccessible.c
|
||||
@@ -30,12 +30,19 @@ struct _GtkContainerCellAccessiblePrivate
|
||||
G_DEFINE_TYPE_WITH_PRIVATE (GtkContainerCellAccessible, gtk_container_cell_accessible, GTK_TYPE_CELL_ACCESSIBLE)
|
||||
|
||||
|
||||
+static void
|
||||
+unset_child (gpointer child)
|
||||
+{
|
||||
+ atk_object_set_parent (ATK_OBJECT (child), NULL);
|
||||
+ g_object_unref (child);
|
||||
+}
|
||||
+
|
||||
static void
|
||||
gtk_container_cell_accessible_finalize (GObject *obj)
|
||||
{
|
||||
GtkContainerCellAccessible *container = GTK_CONTAINER_CELL_ACCESSIBLE (obj);
|
||||
|
||||
- g_list_free_full (container->priv->children, g_object_unref);
|
||||
+ g_list_free_full (container->priv->children, unset_child);
|
||||
|
||||
G_OBJECT_CLASS (gtk_container_cell_accessible_parent_class)->finalize (obj);
|
||||
}
|
||||
@@ -157,6 +164,7 @@ gtk_container_cell_accessible_remove_child (GtkContainerCellAccessible *containe
|
||||
g_return_if_fail (GTK_IS_CELL_ACCESSIBLE (child));
|
||||
g_return_if_fail (container->priv->n_children > 0);
|
||||
|
||||
+ atk_object_set_parent (ATK_OBJECT (child), NULL);
|
||||
container->priv->children = g_list_remove (container->priv->children, child);
|
||||
container->priv->n_children--;
|
||||
|
||||
--
|
||||
GitLab
|
||||
|
||||
|
||||
From 21f8098261486417db371b202bc0494c12017468 Mon Sep 17 00:00:00 2001
|
||||
From: Matthias Clasen <mclasen@redhat.com>
|
||||
Date: Fri, 11 Jun 2021 08:55:48 -0400
|
||||
Subject: [PATCH 2/2] a11y: Plug a memory leak with treeviews
|
||||
|
||||
We need to explicitly remove the children from
|
||||
a GtkContainerCellAccessible, since they otherwise
|
||||
keep the parent alive.
|
||||
|
||||
Fixes: #3981
|
||||
---
|
||||
gtk/a11y/gtktreeviewaccessible.c | 11 +++++++++++
|
||||
1 file changed, 11 insertions(+)
|
||||
|
||||
diff --git a/gtk/a11y/gtktreeviewaccessible.c b/gtk/a11y/gtktreeviewaccessible.c
|
||||
index adad462064..c1a2097a1e 100644
|
||||
--- a/gtk/a11y/gtktreeviewaccessible.c
|
||||
+++ b/gtk/a11y/gtktreeviewaccessible.c
|
||||
@@ -104,6 +104,17 @@ static void
|
||||
cell_info_free (GtkTreeViewAccessibleCellInfo *cell_info)
|
||||
{
|
||||
gtk_accessible_set_widget (GTK_ACCESSIBLE (cell_info->cell), NULL);
|
||||
+ if (GTK_IS_CONTAINER_CELL_ACCESSIBLE (cell_info->cell))
|
||||
+ {
|
||||
+ GList *children;
|
||||
+
|
||||
+ while ((children = gtk_container_cell_accessible_get_children (GTK_CONTAINER_CELL_ACCESSIBLE (cell_info->cell))) != NULL)
|
||||
+ {
|
||||
+ GtkCellAccessible *child = children->data;
|
||||
+ gtk_container_cell_accessible_remove_child (GTK_CONTAINER_CELL_ACCESSIBLE (cell_info->cell), child);
|
||||
+ }
|
||||
+ }
|
||||
+
|
||||
g_object_unref (cell_info->cell);
|
||||
|
||||
g_free (cell_info);
|
||||
--
|
||||
GitLab
|
||||
|
@ -0,0 +1,27 @@
|
||||
From cc977be580b9a7c2683810fe36fe485ee8583ec0 Mon Sep 17 00:00:00 2001
|
||||
From: Matthias Clasen <mclasen@redhat.com>
|
||||
Date: Fri, 11 Feb 2022 18:39:55 -0500
|
||||
Subject: [PATCH] Fix a leak of cell accessibles
|
||||
|
||||
gtk_container_cell_accessible_add_child is transfer none,
|
||||
so we need to drop the reference we hold, otherwise it
|
||||
leaks.
|
||||
---
|
||||
gtk/a11y/gtktreeviewaccessible.c | 1 +
|
||||
1 file changed, 1 insertion(+)
|
||||
|
||||
diff --git a/gtk/a11y/gtktreeviewaccessible.c b/gtk/a11y/gtktreeviewaccessible.c
|
||||
index c1a2097a1e..c2b7e8add0 100644
|
||||
--- a/gtk/a11y/gtktreeviewaccessible.c
|
||||
+++ b/gtk/a11y/gtktreeviewaccessible.c
|
||||
@@ -413,6 +413,7 @@ create_cell_accessible (GtkTreeView *treeview,
|
||||
{
|
||||
cell = create_cell_accessible_for_renderer (l->data, GTK_WIDGET (treeview), ATK_OBJECT (container));
|
||||
gtk_container_cell_accessible_add_child (container, cell);
|
||||
+ g_object_unref (cell);
|
||||
}
|
||||
|
||||
cell = GTK_CELL_ACCESSIBLE (container);
|
||||
--
|
||||
GitLab
|
||||
|
@ -0,0 +1,51 @@
|
||||
From c3503fcc84eec0bcf857cc744580aa9a4d5dc7eb Mon Sep 17 00:00:00 2001
|
||||
From: Matthias Clasen <mclasen@redhat.com>
|
||||
Date: Tue, 13 Apr 2021 14:10:27 -0400
|
||||
Subject: [PATCH] x11: Be quiet on exit by default
|
||||
|
||||
The condition we check for to catch X servers going away
|
||||
may not be accurate anymore, and the warning shows up in
|
||||
logs, causing customers to be concerned. So, be quiet by
|
||||
default, unless the user explicitly asked for a message.
|
||||
---
|
||||
gdk/x11/gdkmain-x11.c | 23 ++++++-----------------
|
||||
1 file changed, 6 insertions(+), 17 deletions(-)
|
||||
|
||||
diff --git a/gdk/x11/gdkmain-x11.c b/gdk/x11/gdkmain-x11.c
|
||||
index 64c7cb4302..cd877ce3e4 100644
|
||||
--- a/gdk/x11/gdkmain-x11.c
|
||||
+++ b/gdk/x11/gdkmain-x11.c
|
||||
@@ -240,24 +240,13 @@ gdk_x_io_error (Display *display)
|
||||
/* This is basically modelled after the code in XLib. We need
|
||||
* an explicit error handler here, so we can disable our atexit()
|
||||
* which would otherwise cause a nice segfault.
|
||||
- * We fprintf(stderr, instead of g_warning() because g_warning()
|
||||
- * could possibly be redirected to a dialog
|
||||
+ * We g_debug() instead of g_warning(), because g_warning()
|
||||
+ * could possibly be redirected to the log
|
||||
*/
|
||||
- if (errno == EPIPE)
|
||||
- {
|
||||
- g_message ("The application '%s' lost its connection to the display %s;\n"
|
||||
- "most likely the X server was shut down or you killed/destroyed\n"
|
||||
- "the application.\n",
|
||||
- g_get_prgname (),
|
||||
- display ? DisplayString (display) : gdk_get_display_arg_name ());
|
||||
- }
|
||||
- else
|
||||
- {
|
||||
- g_message ("%s: Fatal IO error %d (%s) on X server %s.\n",
|
||||
- g_get_prgname (),
|
||||
- errno, g_strerror (errno),
|
||||
- display ? DisplayString (display) : gdk_get_display_arg_name ());
|
||||
- }
|
||||
+ g_debug ("%s: Fatal IO error %d (%s) on X server %s.\n",
|
||||
+ g_get_prgname (),
|
||||
+ errno, g_strerror (errno),
|
||||
+ display ? DisplayString (display) : gdk_get_display_arg_name ());
|
||||
|
||||
_exit (1);
|
||||
}
|
||||
--
|
||||
GitLab
|
||||
|
File diff suppressed because it is too large
Load Diff
Loading…
Reference in new issue