1! { dg-do run } 2! { dg-options "-std=gnu" } 3 integer(kind=2) :: i2, j2, k2, l2, m2, n2, o2 4 integer(kind=4) :: i4, j4 5 integer(kind=8) :: i8, j8 6 real :: x 7 complex :: z 8 9 i2 = huge(i2) / 3 10 i8 = int8(i2) 11 i4 = long(i2) 12 j2 = short(i2) 13 k2 = int2(i2) 14 l2 = int2(i8) 15 m2 = short(i8) 16 n2 = int2(i4) 17 o2 = short(i4) 18 19 if (i8 /= i2 .or. i4 /= i2 .or. j2 /= i2 .or. k2 /= i2 & 20 .or. l2 /= i2 .or. m2 /= i2 .or. n2 /= i2 .or. o2 /= i2) call abort 21 22 x = i2 23 i8 = int8(x) 24 i4 = long(x) 25 j2 = short(x) 26 k2 = int2(x) 27 if (i8 /= i2 .or. i4 /= i2 .or. j2 /= i2 .or. k2 /= i2) call abort 28 29 z = i2 + (0.,-42.) 30 i8 = int8(z) 31 i4 = long(z) 32 j2 = short(z) 33 k2 = int2(z) 34 if (i8 /= i2 .or. i4 /= i2 .or. j2 /= i2 .or. k2 /= i2) call abort 35 36 end 37