view gcc/testsuite/g++.dg/cpp2a/constexpr-shift1.C @ 145:1830386684a0

gcc-9.2.0
author anatofuz
date Thu, 13 Feb 2020 11:34:05 +0900
parents
children
line wrap: on
line source

// { dg-do compile { target c++11 } }

constexpr int a = -42 << 0;	// { dg-error "left operand of shift expression '\\(-42 << 0\\)' is negative" "" { target c++17_down } }
constexpr int b = -42 << 1;	// { dg-error "left operand of shift expression '\\(-42 << 1\\)' is negative" "" { target c++17_down } }
constexpr int c = -42 << (__SIZEOF_INT__ * __CHAR_BIT__ - 1);	// { dg-error "left operand of shift expression '\\(-42 << \[0-9]*\\)' is negative" "" { target c++17_down } }
				// { dg-warning "result of '\\(-42 << \[0-9]*\\)' requires \[0-9]* bits to represent, but 'int' only has \[0-9]* bits" "" { target c++17_down } .-1 }
constexpr int d = 42 << (__SIZEOF_INT__ * __CHAR_BIT__ - 1);	// { dg-error "shift expression '\\(42 << \[0-9]*\\)' overflows" "" { target c++17_down } }
				// { dg-warning "result of '\\(42 << \[0-9]*\\)' requires \[0-9]* bits to represent, but 'int' only has \[0-9]* bits" "" { target c++17_down } .-1 }
constexpr int e = 32 << (__SIZEOF_INT__ * __CHAR_BIT__ - 5);	// { dg-error "shift expression '\\(32 << \[0-9]*\\)' overflows" "" { target c++17_down } }
				// { dg-warning "result of '\\(32 << \[0-9]*\\)' requires \[0-9]* bits to represent, but 'int' only has \[0-9]* bits" "" { target c++17_down } .-1 }
constexpr int f = 32 << (__SIZEOF_INT__ * __CHAR_BIT__ - 6);
constexpr int g = -42U << 0;
constexpr int h = -42U << 1;
constexpr int i = -42U << (__SIZEOF_INT__ * __CHAR_BIT__ - 1);
constexpr int j = 42U << (__SIZEOF_INT__ * __CHAR_BIT__ - 1);
constexpr int k = 32U << (__SIZEOF_INT__ * __CHAR_BIT__ - 5);
constexpr int l = 32U << (__SIZEOF_INT__ * __CHAR_BIT__ - 6);
#if __cplusplus > 201703L
static_assert (a == g);
static_assert (b == h);
static_assert (c == i);
static_assert (d == j);
static_assert (e == k);
static_assert (f == l);
#endif