summaryrefslogtreecommitdiff
path: root/gcc/testsuite/gfortran.dg/transfer_simplify_14.f90
blob: dfb997d81b2dd52e5e3786abbbe4c8d82aa54c3b (plain)
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
! { dg-do compile }
! { dg-options "-fdump-tree-original" }
! PR fortran/104128 - ICE in gfc_widechar_to_char
! Contributed by G.Steinmetz

program p
  implicit none
  integer,      parameter :: k = 4
  character(*), parameter :: a = 'abc'
  character(*,kind=4), parameter :: b = 'abc'
  character(2,kind=k), parameter :: s = k_"FG"
  character(*,kind=1), parameter :: x = transfer (s, 'abcdefgh')
  character(2,kind=k), parameter :: t = transfer (x, s)
  character(2,kind=k)            :: u = transfer (x, s)
  logical,             parameter :: l = (s == t)
  print *, transfer (a , 4_'xy', size=2)
  print *, transfer ('xyz', [b], size=2)
  print *, s
  print *, t
  print *, u
  if (.not. l) stop 1
  if (t /= s)  stop 2
  if (u /= s)  stop 3  ! not optimized away
end

! { dg-final { scan-tree-dump-times "_gfortran_stop_numeric" 1 "original" } }
! { dg-final { scan-tree-dump "_gfortran_stop_numeric \\(3, 0\\);" "original" } }