blob: c2e58bfe750ca670bd55efc971f53fa1763a26e2 [file] [log] [blame]
/* Test C2x enumerations with values not representable in int. Test overflow
of __int128 is diagnosed. */
/* { dg-do compile { target { int128 } } } */
/* { dg-options "-std=c2x" } */
enum e1 { e1a = (__int128) (((unsigned __int128) -1) >> 1), e1b }; /* { dg-error "overflow in enumeration values" } */
enum e2 { e2a = (unsigned __int128) -1, e2b }; /* { dg-error "overflow in enumeration values" } */
/* Likewise, when it's the enum as a whole that can't fit in __int128 or
unsigned __int128, but the individual enumerators fit (some fitting __int128
and some fitting unsigned __int128). */
enum e3 { e3a = -(__int128) (((unsigned __int128) -1) >> 1) - 1,
e3b = (unsigned __int128) -1 }; /* { dg-warning "enumeration values exceed range of largest integer" } */