8sa1-gcc/gcc/testsuite/g++.dg/cpp2a/constexpr-init1.C
Jason Merrill b04445d4a8 c++: Replace "C++2a" with "C++20".
C++20 isn't final quite yet, but all that remains is formalities, so let's
go ahead and change all the references.

I think for the next C++ standard we can just call it C++23 rather than
C++2b, since the committee has been consistent about time-based releases
rather than feature-based.

gcc/c-family/ChangeLog
2020-05-13  Jason Merrill  <jason@redhat.com>

	* c.opt (std=c++20): Make c++2a the alias.
	(std=gnu++20): Likewise.
	* c-common.h (cxx_dialect): Change cxx2a to cxx20.
	* c-opts.c: Adjust.
	* c-cppbuiltin.c: Adjust.
	* c-ubsan.c: Adjust.
	* c-warn.c: Adjust.

gcc/cp/ChangeLog
2020-05-13  Jason Merrill  <jason@redhat.com>

	* call.c, class.c, constexpr.c, constraint.cc, decl.c, init.c,
	lambda.c, lex.c, method.c, name-lookup.c, parser.c, pt.c, tree.c,
	typeck2.c: Change cxx2a to cxx20.

libcpp/ChangeLog
2020-05-13  Jason Merrill  <jason@redhat.com>

	* include/cpplib.h (enum c_lang): Change CXX2A to CXX20.
	* init.c, lex.c: Adjust.
2020-05-13 15:16:49 -04:00

100 lines
1.7 KiB
C

// PR c++/91353 - P1331R2: Allow trivial default init in constexpr contexts.
// { dg-do compile { target c++20 } }
// Test basic use.
struct S {
int i;
constexpr S(bool b) {
if (b)
i = 42;
}
};
constexpr S s1(true);
constexpr S s2(false); // { dg-error "not a constant expression" }
constexpr int
fn1 (int x)
{
int a;
a = 5;
return x + a;
}
static_assert (fn1 (2) == 7);
constexpr int
fn2 (int x)
{
const int a; // { dg-error "uninitialized .const a." }
constexpr int b; // { dg-error "uninitialized .const b." }
return x;
}
constexpr int
fn3 (int x)
{
int a; // { dg-message ".int a. is not const" }
return x + a; // { dg-error "the value of .a. is not usable in a constant expression" }
}
constexpr int a = fn3 (5); // { dg-message "in .constexpr. expansion of" }
constexpr int
fn4 ()
{
struct S { int a = -5; int b; } s;
return s.a;
}
static_assert (fn4 () == -5);
constexpr int
fn5 ()
{
struct S { int a = 9; int b; } s;
return s.b;
}
constexpr int b = fn5 (); // { dg-error "accessing uninitialized member" }
// { dg-message "in .constexpr. expansion of" "" { target *-*-* } .-1 }
constexpr int
fn6 ()
{
int a;
return 42;
}
static_assert (fn6 () == 42);
constexpr int
fn7 (bool b)
{
int a; // { dg-message ".int a. is not const" }
if (b)
a = 42;
return a;
}
static_assert (fn7 (true) == 42);
static_assert (fn7 (false) == 42); // { dg-error "non-constant condition|the value of .a. is not usable" }
// { dg-message "in .constexpr. expansion of" "" { target *-*-* } .-1 }
constexpr int
fn8 (int n)
{
int r;
switch (n)
{
case 1:
r = n;
return r;
case 42:
r = n;
return r;
}
}
static_assert (fn8 (1) == 1);
static_assert (fn8 (42) == 42);