// RUN: %clang_cc1 -verify %s
/* WG14 N736: yes
* preprocessor arithmetic done in intmax_t/uintmax_t
*/
// There is not a standard requirement that this relationships holds. If these
// asserts fail, it means we have another test scenario to consider.
_Static_assert(__INTMAX_MAX__ == __LONG_LONG_MAX__,
"intmax_t is not the same width as long long?");
_Static_assert((-__INTMAX_MAX__ - 1) == (-__LONG_LONG_MAX__ - 1LL),
"intmax_t is not the same width as long long?");
_Static_assert(__UINTMAX_MAX__ == (__LONG_LONG_MAX__ * 2ULL + 1ULL),
"uintmax_t is not the same width as unsigned long long?");
// Test that arithmetic on the largest positive signed intmax_t works.
#if 9223372036854775807LL + 0LL != 9223372036854775807LL
#error "uh oh"
#endif
// Same for negative.
#if -9223372036854775807LL - 1LL + 0LL != -9223372036854775807LL - 1LL
#error "uh oh"
#endif
// Then test the same for unsigned
#if 18446744073709551615ULL + 0ULL != 18446744073709551615ULL
#error "uh oh"
#endif
// Test that unsigned overflow causes silent wraparound.
#if 18446744073709551615ULL + 1ULL != 0 // Silently wraps to 0.
#error "uh oh"
#endif
#if 0ULL - 1ULL != 18446744073709551615ULL // Silently wraps to 0xFFFF'FFFF'FFFF'FFFF.
#error "uh oh"
#endif
// Now test that signed arithmetic that pushes us over a limit is properly
// diagnosed.
#if 9223372036854775807LL + 1LL // expected-warning {{integer overflow in preprocessor expression}}
#endif
#if -9223372036854775807LL - 2LL // expected-warning {{integer overflow in preprocessor expression}}
#endif