From 85e6e0e04ae19670b071820947d941e521d1200e Mon Sep 17 00:00:00 2001 From: =?utf8?q?Jan=20Kundr=C3=A1t?= Date: Sat, 5 May 2018 10:59:52 +0200 Subject: [PATCH] dev-cpp/glibmm: Fix build with GCC 8 Patch taken from upstream and adapted to actually touch the pregenerated file shipped with the release tarbal as well. That code appears to have been always wrong, with no chance to build. This probably means that GCC 8 is suddenly being detected in some other way, making the code use that include file which was previously apparently kept unused. But anyway, upstream killed that include in a later release, so let's just let this build and watch the eventual breakage. Upstream says: > Fixed in the glibmm-2-54 branch. No fix is necessary in the master > branch. The threads.hg and threads.h files don't exist there. Closes: https://bugs.gentoo.org/654776 Bug: https://bugzilla.gnome.org/show_bug.cgi?id=791711 Closes: https://github.com/gentoo/gentoo/pull/8324 --- .../files/glibmm-fix-threads-gobject.patch | 34 +++++++++++++++++++ dev-cpp/glibmm/glibmm-2.52.1.ebuild | 6 ++++ 2 files changed, 40 insertions(+) create mode 100644 dev-cpp/glibmm/files/glibmm-fix-threads-gobject.patch diff --git a/dev-cpp/glibmm/files/glibmm-fix-threads-gobject.patch b/dev-cpp/glibmm/files/glibmm-fix-threads-gobject.patch new file mode 100644 index 000000000000..2da4a5621992 --- /dev/null +++ b/dev-cpp/glibmm/files/glibmm-fix-threads-gobject.patch @@ -0,0 +1,34 @@ +From 37d57ae9572b7d74aa385a30313eceae7f2d3fce Mon Sep 17 00:00:00 2001 +From: Kjell Ahlstedt +Date: Wed, 20 Dec 2017 20:00:32 +0100 +Subject: [PATCH] Glib::Threads::Private: Fix gobj() + +Bug 791711 +--- + glib/src/threads.hg | 2 +- + 1 file changed, 1 insertion(+), 1 deletion(-) + +diff --git a/glib/src/threads.hg b/glib/src/threads.hg +index 86d7a17b..c82a6130 100644 +--- a/glib/src/threads.hg ++++ b/glib/src/threads.hg +@@ -628,7 +628,7 @@ public: + */ + inline void replace(T* data); + +- GPrivate* gobj() { return gobject_; } ++ GPrivate* gobj() { return &gobject_; } + + private: + GPrivate gobject_; +--- a/glib/glibmm/threads.h 2017-09-04 15:27:31.000000000 +0200 ++++ b/glib/glibmm/threads.h 2018-05-05 10:53:44.339288554 +0200 +@@ -657,7 +657,7 @@ + */ + inline void replace(T* data); + +- GPrivate* gobj() { return gobject_; } ++ GPrivate* gobj() { return &gobject_; } + + private: + GPrivate gobject_; diff --git a/dev-cpp/glibmm/glibmm-2.52.1.ebuild b/dev-cpp/glibmm/glibmm-2.52.1.ebuild index 925442a83aeb..18a948873dbe 100644 --- a/dev-cpp/glibmm/glibmm-2.52.1.ebuild +++ b/dev-cpp/glibmm/glibmm-2.52.1.ebuild @@ -22,6 +22,12 @@ DEPEND="${RDEPEND} " # dev-cpp/mm-common needed for eautoreconf +PATCHES=( + # Fix build with GCC-8 + # https://bugs.gentoo.org/654776 + "${FILESDIR}"/${PN}-fix-threads-gobject.patch +) + src_prepare() { if ! use test; then # don't waste time building tests -- 2.26.2