| // 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 |
| |