summaryrefslogtreecommitdiff
path: root/libstdc++-v3/testsuite/20_util/function/cons/noexcept.cc
blob: 59f20ba9843f532f0cad79fd121bff957e51fd31 (plain)
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
// { dg-do compile { target c++11 } }
// { dg-require-effective-target hosted }

#include <functional>

struct X
{
  void operator()(X*);

  char bigness[100];
};

using F = std::function<void(X*)>;

static_assert( std::is_nothrow_constructible<F>::value, "" );
static_assert( std::is_nothrow_constructible<F, F>::value, "" );
static_assert( ! std::is_nothrow_constructible<F, F&>::value, "" );
static_assert( ! std::is_nothrow_constructible<F, const F&>::value, "" );
static_assert( std::is_nothrow_constructible<F, std::nullptr_t>::value, "" );

static_assert( ! std::is_nothrow_constructible<F, X>::value, "" );
using R = std::reference_wrapper<X>;
static_assert( std::is_nothrow_constructible<F, R>::value, "" );


// The standard requires that construction from a function pointer type
// does not throw, but doesn't require that the construction is noexcept.
// Strengthening that noexcept for these types is a GCC extension.
static_assert( std::is_nothrow_constructible<F, void(*)(X*)>::value, "" );
// This is a GCC extension, not required by the standard:
static_assert( std::is_nothrow_constructible<F, void(&)(X*)>::value, "" );
// This is a GCC extension, not required by the standard:
static_assert( std::is_nothrow_constructible<F, void(X::*)()>::value, "" );

auto c = [](X*){};
static_assert( std::is_nothrow_constructible<F, decltype(+c)>::value, "" );
// The standard allows this to throw, but as a GCC extenension we store
// closures with no captures in the std::function, so this is noexcept too:
static_assert( std::is_nothrow_constructible<F, decltype(c)>::value, "" );