forked from sagemath/sage
-
Notifications
You must be signed in to change notification settings - Fork 1
Commit
This commit does not belong to any branch on this repository, and may belong to a fork outside of the repository.
Merge pull request #1 from mkoeppe/gcc_13
Gcc 13
- Loading branch information
Showing
3 changed files
with
83 additions
and
2 deletions.
There are no files selected for viewing
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
Original file line number | Diff line number | Diff line change |
---|---|---|
@@ -0,0 +1,23 @@ | ||
From c7744bb133496cd7ac04688f345646d505e1bf52 Mon Sep 17 00:00:00 2001 | ||
From: "Benjamin A. Beasley" <code@musicinmybrain.net> | ||
Date: Thu, 19 Jan 2023 09:12:22 -0500 | ||
Subject: [PATCH] Add missing #include <cstdint> for (u)int64_t | ||
|
||
Fixes failure to compile on GCC 13. | ||
--- | ||
src/library/poly1/givdegree.h | 2 ++ | ||
1 file changed, 2 insertions(+) | ||
|
||
diff --git a/src/library/poly1/givdegree.h b/src/library/poly1/givdegree.h | ||
index 3753a425..eb85a0dd 100644 | ||
--- a/src/library/poly1/givdegree.h | ||
+++ b/src/library/poly1/givdegree.h | ||
@@ -19,6 +19,8 @@ | ||
#ifndef __GIVARO_poly1degree_H | ||
#define __GIVARO_poly1degree_H | ||
|
||
+#include <cstdint> | ||
+ | ||
#include <iostream> | ||
|
||
namespace Givaro { |
58 changes: 58 additions & 0 deletions
58
build/pkgs/zeromq/patches/438d5d88392baffa6c2c5e0737d9de19d6686f0d.patch
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
Original file line number | Diff line number | Diff line change |
---|---|---|
@@ -0,0 +1,58 @@ | ||
From 438d5d88392baffa6c2c5e0737d9de19d6686f0d Mon Sep 17 00:00:00 2001 | ||
From: Sergei Trofimovich <slyich@gmail.com> | ||
Date: Tue, 20 Dec 2022 21:45:16 +0000 | ||
Subject: [PATCH] src/secure_allocator.hpp: define missing 'rebind' type | ||
|
||
`gcc-13` added an assert to standard headers to make sure custom | ||
allocators have intended implementation of rebind type instead | ||
of inherited rebind. gcc change: | ||
https://gcc.gnu.org/git/?p=gcc.git;a=commitdiff;h=64c986b49558a7 | ||
|
||
Without the fix build fails on this week's `gcc-13` as: | ||
|
||
[ 92%] Building CXX object tests/CMakeFiles/test_security_curve.dir/test_security_curve.cpp.o | ||
In file included from /<<NIX>>/gcc-13.0.0/include/c++/13.0.0/ext/alloc_traits.h:34, | ||
from /<<NIX>>/gcc-13.0.0/include/c++/13.0.0/bits/stl_uninitialized.h:64, | ||
from /<<NIX>>/gcc-13.0.0/include/c++/13.0.0/memory:69, | ||
from tests/../src/secure_allocator.hpp:42, | ||
from tests/../src/curve_client_tools.hpp:49, | ||
from tests/test_security_curve.cpp:53: | ||
/<<NIX>>/gcc-13.0.0/include/c++/13.0.0/bits/alloc_traits.h: In instantiation of 'struct std::__allocator_traits_base::__rebind<zmq::secure_allocator_t<unsigned char>, unsigned char, void>': | ||
/<<NIX>>/gcc-13.0.0/include/c++/13.0.0/bits/alloc_traits.h:94:11: required by substitution of 'template<class _Alloc, class _Up> using std::__alloc_rebind = typename std::__allocator_traits_base::__rebind<_Alloc, _Up>::type [with _Alloc = zmq::secure_allocator_t<unsigned char>; _Up = unsigned char]' | ||
/<<NIX>>/gcc-13.0.0/include/c++/13.0.0/bits/alloc_traits.h:228:8: required by substitution of 'template<class _Alloc> template<class _Tp> using std::allocator_traits< <template-parameter-1-1> >::rebind_alloc = std::__alloc_rebind<_Alloc, _Tp> [with _Tp = unsigned char; _Alloc = zmq::secure_allocator_t<unsigned char>]' | ||
/<<NIX>>/gcc-13.0.0/include/c++/13.0.0/ext/alloc_traits.h:126:65: required from 'struct __gnu_cxx::__alloc_traits<zmq::secure_allocator_t<unsigned char>, unsigned char>::rebind<unsigned char>' | ||
/<<NIX>>/gcc-13.0.0/include/c++/13.0.0/bits/stl_vector.h:88:21: required from 'struct std::_Vector_base<unsigned char, zmq::secure_allocator_t<unsigned char> >' | ||
/<<NIX>>/gcc-13.0.0/include/c++/13.0.0/bits/stl_vector.h:423:11: required from 'class std::vector<unsigned char, zmq::secure_allocator_t<unsigned char> >' | ||
tests/../src/curve_client_tools.hpp:64:76: required from here | ||
/<<NIX>>/gcc-13.0.0/include/c++/13.0.0/bits/alloc_traits.h:70:31: error: static assertion failed: allocator_traits<A>::rebind_alloc<A::value_type> must be A | ||
70 | _Tp>::value, | ||
| ^~~~~ | ||
|
||
The change adds trivial `rebind` definition with expected return type | ||
and satisfies conversion requirements. | ||
--- | ||
src/secure_allocator.hpp | 11 +++++++++++ | ||
1 file changed, 11 insertions(+) | ||
|
||
diff --git a/src/secure_allocator.hpp b/src/secure_allocator.hpp | ||
index e0871dcc99..5e97368911 100644 | ||
--- a/src/secure_allocator.hpp | ||
+++ b/src/secure_allocator.hpp | ||
@@ -99,6 +99,17 @@ bool operator!= (const secure_allocator_t<T> &, const secure_allocator_t<U> &) | ||
#else | ||
template <typename T> struct secure_allocator_t : std::allocator<T> | ||
{ | ||
+ secure_allocator_t () ZMQ_DEFAULT; | ||
+ | ||
+ template <class U> | ||
+ secure_allocator_t (const secure_allocator_t<U> &) ZMQ_NOEXCEPT | ||
+ { | ||
+ } | ||
+ | ||
+ template <class U> struct rebind | ||
+ { | ||
+ typedef secure_allocator_t<U> other; | ||
+ }; | ||
}; | ||
#endif | ||
} |