commit:     561d2af41a1662af7b81bedefc55a3f2e7f2ff70
Author:     Peter Levine <plevine457 <AT> gmail <DOT> com>
AuthorDate: Mon Jul 24 07:26:40 2017 +0000
Commit:     Patrice Clement <monsieurp <AT> gentoo <DOT> org>
CommitDate: Mon Jul 24 14:28:12 2017 +0000
URL:        https://gitweb.gentoo.org/repo/gentoo.git/commit/?id=561d2af4

dev-python/jpype: fix building with -Werror=terminate using GCC-6.

Gentoo-Bug: https://bugs.gentoo.org/608920
Package-Manager: Portage-2.3.6, Repoman-2.3.2
Closes: https://github.com/gentoo/gentoo/pull/5194

 dev-python/jpype/files/jpype-gcc6-noexcept.patch | 57 ++++++++++++++++++++++++
 dev-python/jpype/jpype-0.6.1.ebuild              |  4 +-
 dev-python/jpype/jpype-0.6.2.ebuild              |  2 +
 3 files changed, 62 insertions(+), 1 deletion(-)

diff --git a/dev-python/jpype/files/jpype-gcc6-noexcept.patch 
b/dev-python/jpype/files/jpype-gcc6-noexcept.patch
new file mode 100644
index 00000000000..710844d3560
--- /dev/null
+++ b/dev-python/jpype/files/jpype-gcc6-noexcept.patch
@@ -0,0 +1,57 @@
+Bug: https://bugs.gentoo.org/show_bug.cgi?id=608920
+Upstream commit: 
https://github.com/originell/jpype/commit/3a4fb98938afd9c03070086d1b8fda8841410fa3
+
+From c3578c3488de35236f73b6eb27428b1f1526c45b Mon Sep 17 00:00:00 2001
+From: Peter-Levine <plevine...@gmail.com>
+Date: Sat, 11 Feb 2017 23:31:27 -0500
+Subject: [PATCH] Mark destructor that throws as noexcept(false) for >=C++11
+
+---
+ native/common/include/jp_field.h | 2 +-
+ native/common/include/jpype.h    | 6 ++++++
+ native/common/jp_field.cpp       | 2 +-
+ 3 files changed, 8 insertions(+), 2 deletions(-)
+
+diff --git a/native/common/include/jp_field.h 
b/native/common/include/jp_field.h
+index d28b795..f93752c 100644
+--- a/native/common/include/jp_field.h
++++ b/native/common/include/jp_field.h
+@@ -38,7 +38,7 @@ public :
+       /**
+        * destructor
+        */
+-      virtual ~JPField();
++      virtual ~JPField() NO_EXCEPT_FALSE;
+       
+ public :
+       bool isStatic() const;
+diff --git a/native/common/include/jpype.h b/native/common/include/jpype.h
+index 7db5832..a492d06 100644
+--- a/native/common/include/jpype.h
++++ b/native/common/include/jpype.h
+@@ -64,6 +64,12 @@
+     #define PyUnicode_FromFormat PyString_FromFormat
+ #endif
+ 
++// Define this and use to allow destructors to throw in C++11 or later
++#if __cplusplus >= 201103L
++#define NO_EXCEPT_FALSE noexcept(false)
++#else
++#define NO_EXCEPT_FALSE
++#endif
+ 
+ #include <map>
+ #include <string>
+diff --git a/native/common/jp_field.cpp b/native/common/jp_field.cpp
+index 8c75e58..5ef9d8c 100644
+--- a/native/common/jp_field.cpp
++++ b/native/common/jp_field.cpp
+@@ -63,7 +63,7 @@ JPField::JPField(const JPField& fld)
+       TRACE_OUT;
+ }
+ 
+-JPField::~JPField()
++JPField::~JPField() NO_EXCEPT_FALSE
+ {
+       TRACE_IN("JPField::~JPField");
+       JPEnv::getJava()->DeleteGlobalRef(m_Field);

diff --git a/dev-python/jpype/jpype-0.6.1.ebuild 
b/dev-python/jpype/jpype-0.6.1.ebuild
index 6ab0fe49543..090ec143ecb 100644
--- a/dev-python/jpype/jpype-0.6.1.ebuild
+++ b/dev-python/jpype/jpype-0.6.1.ebuild
@@ -1,4 +1,4 @@
-# Copyright 1999-2016 Gentoo Foundation
+# Copyright 1999-2017 Gentoo Foundation
 # Distributed under the terms of the GNU General Public License v2
 
 EAPI=5
@@ -22,6 +22,8 @@ DEPEND="
        dev-python/setuptools[${PYTHON_USEDEP}]
        >=virtual/jdk-1.6"
 
+PATCHES=( "${FILESDIR}"/${PN}-gcc6-noexcept.patch )
+
 python_compile() {
        if ! python_is_python3; then
                local CXXFLAGS="${CXXFLAGS} -fno-strict-aliasing"

diff --git a/dev-python/jpype/jpype-0.6.2.ebuild 
b/dev-python/jpype/jpype-0.6.2.ebuild
index 3ea7f1fefbc..f8dfefc0dd2 100644
--- a/dev-python/jpype/jpype-0.6.2.ebuild
+++ b/dev-python/jpype/jpype-0.6.2.ebuild
@@ -22,6 +22,8 @@ DEPEND="
        dev-python/setuptools[${PYTHON_USEDEP}]
        >=virtual/jdk-1.6"
 
+PATCHES=( "${FILESDIR}"/${PN}-gcc6-noexcept.patch )
+
 python_compile() {
        if ! python_is_python3; then
                local CXXFLAGS="${CXXFLAGS} -fno-strict-aliasing"

Reply via email to