annotate gcc/testsuite/g++.dg/cpp0x/constexpr-pos1.C @ 131:84e7813d76e9

gcc-8.2
author mir3636
date Thu, 25 Oct 2018 07:37:49 +0900
parents 04ced10e8804
children
Ignore whitespace changes - Everywhere: Within whitespace: At end of lines:
rev   line source
111
kono
parents:
diff changeset
1 // Positive examples from N3092 (FCD)
kono
parents:
diff changeset
2 // { dg-do compile { target c++11 } }
kono
parents:
diff changeset
3
kono
parents:
diff changeset
4 #define SA(X) static_assert(X, #X)
kono
parents:
diff changeset
5
kono
parents:
diff changeset
6 constexpr int bufsz = 1024; // OK: definition
kono
parents:
diff changeset
7 SA (bufsz == 1024);
kono
parents:
diff changeset
8
kono
parents:
diff changeset
9 constexpr int square(int x); // OK: declaration
kono
parents:
diff changeset
10
kono
parents:
diff changeset
11 struct pixel {
kono
parents:
diff changeset
12 int x;
kono
parents:
diff changeset
13 int y;
kono
parents:
diff changeset
14 // OK: declaration
kono
parents:
diff changeset
15 constexpr pixel(int);
kono
parents:
diff changeset
16 };
kono
parents:
diff changeset
17 constexpr pixel::pixel(int a) // OK: definition
kono
parents:
diff changeset
18 : x(square(a)), y(square(a))
kono
parents:
diff changeset
19 { }
kono
parents:
diff changeset
20
kono
parents:
diff changeset
21 constexpr int square(int x) // OK: definition
kono
parents:
diff changeset
22 { return x * x; }
kono
parents:
diff changeset
23
kono
parents:
diff changeset
24 constexpr pixel large(4); // OK: square defined
kono
parents:
diff changeset
25 SA(large.x == 16 && large.y==16);
kono
parents:
diff changeset
26
kono
parents:
diff changeset
27 constexpr long long_max() // OK
kono
parents:
diff changeset
28 { return 2147483647; }
kono
parents:
diff changeset
29
kono
parents:
diff changeset
30 SA(long_max() == 2147483647);
kono
parents:
diff changeset
31
kono
parents:
diff changeset
32 constexpr int abs(int x) // OK
kono
parents:
diff changeset
33 { return x < 0 ? -x : x; }
kono
parents:
diff changeset
34
kono
parents:
diff changeset
35 SA(abs(-1) == 1);
kono
parents:
diff changeset
36 SA(abs(24) == 24);
kono
parents:
diff changeset
37
kono
parents:
diff changeset
38 struct Length {
kono
parents:
diff changeset
39 explicit constexpr Length(int i = 0) : val(i) { }
kono
parents:
diff changeset
40 private:
kono
parents:
diff changeset
41 int val;
kono
parents:
diff changeset
42 };
kono
parents:
diff changeset
43
kono
parents:
diff changeset
44 constexpr Length l1;
kono
parents:
diff changeset
45 constexpr Length l2(12);
kono
parents:
diff changeset
46
kono
parents:
diff changeset
47 struct pixel2 {
kono
parents:
diff changeset
48 int x, y;
kono
parents:
diff changeset
49 };
kono
parents:
diff changeset
50 constexpr pixel2 ur = { 1294, 1024 };// OK
kono
parents:
diff changeset
51
kono
parents:
diff changeset
52 SA(ur.x == 1294 && ur.y == 1024);
kono
parents:
diff changeset
53
kono
parents:
diff changeset
54 constexpr const int* addr(const int& ir) { return &ir; } // OK
kono
parents:
diff changeset
55 static const int x = 5;
kono
parents:
diff changeset
56 extern constexpr const int* xp = addr(x); // OK: (const int*)&(const int&)x
kono
parents:
diff changeset
57 // is an address contant expression
kono
parents:
diff changeset
58 SA(xp == &x);
kono
parents:
diff changeset
59 extern constexpr int x2 = *addr(5);
kono
parents:
diff changeset
60 SA(x2 == 5);