view gcc/testsuite/gfortran.dg/boz_3.f90 @ 131:84e7813d76e9

gcc-8.2
author mir3636
date Thu, 25 Oct 2018 07:37:49 +0900
parents 04ced10e8804
children 1830386684a0
line wrap: on
line source

! { dg-do run }
! { dg-options "-std=gnu" }
! Test that the BOZ constant on the RHS, which are of different KIND than
! the LHS, are correctly converted.
!
program boz

   implicit none

   integer(1), parameter :: b1 = b'000000000001111'
   integer(2), parameter :: b2 = b'00000000000000000111000011110000'
   integer(4), parameter :: &
   &  b4 = b'0000000000000000000000000000000001110000111100001111000011110000'

   integer(1), parameter :: o1 = o'0012'
   integer(2), parameter :: o2 = o'0004321'
   integer(4), parameter :: o4 = o'0000000043210765'

   integer(1), parameter :: z1 = z'0a'
   integer(2), parameter :: z2 = z'00ab'
   integer(4), parameter :: z4 = z'0000dead'

   if (b1 /= 15_1) STOP 1
   if (b2 /= 28912_2) STOP 2
   if (b4 /= 1894838512_4) STOP 3

   if (o1 /= 10_1) STOP 4
   if (o2 /= 2257_2) STOP 5
   if (o4 /= 9245173_4) STOP 6

   if (z1 /= 10_1) STOP 7
   if (z2 /= 171_2) STOP 8
   if (z4 /= 57005_4) STOP 9

end program boz